blob: 939a4e11540e8bee37beef201479e860095f87b1 [file] [log] [blame]
(window.webpackJsonp=window.webpackJsonp||[]).push([[38],{436:function(e,t,s){"use strict";s.r(t);var a=s(29),r=Object(a.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"administration-management"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#administration-management"}},[e._v("#")]),e._v(" Administration Management")]),e._v(" "),t("p",[e._v("IoTDB provides users with account privilege management operations, so as to ensure data security.")]),e._v(" "),t("p",[e._v("We will show you basic user privilege management operations through the following specific examples. Detailed SQL syntax and usage details can be found in "),t("RouterLink",{attrs:{to:"/UserGuide/Master/Reference/SQL-Reference.html"}},[e._v("SQL Documentation")]),e._v(".\nAt the same time, in the JAVA programming environment, you can use the "),t("RouterLink",{attrs:{to:"/UserGuide/Master/API/Programming-JDBC.html"}},[e._v("Java JDBC")]),e._v(" to execute privilege management statements in a single or batch mode.")],1),e._v(" "),t("h2",{attrs:{id:"basic-concepts"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#basic-concepts"}},[e._v("#")]),e._v(" Basic Concepts")]),e._v(" "),t("h3",{attrs:{id:"user"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#user"}},[e._v("#")]),e._v(" User")]),e._v(" "),t("p",[e._v("The user is the legal user of the database. A user corresponds to a unique username and has a password as a means of authentication. Before using a database, a person must first provide a legitimate username and password to make himself/herself a user.")]),e._v(" "),t("h3",{attrs:{id:"privilege"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#privilege"}},[e._v("#")]),e._v(" Privilege")]),e._v(" "),t("p",[e._v("The database provides a variety of operations, and not all users can perform all operations. If a user can perform an operation, the user is said to have the privilege to perform the operation. privileges are divided into data management privilege (such as adding, deleting and modifying data) and authority management privilege (such as creation and deletion of users and roles, granting and revoking of privileges, etc.). Data management privilege often needs a path to limit its effective range. It is flexible that using "),t("RouterLink",{attrs:{to:"/UserGuide/Master/Data-Concept/Data-Model-and-Terminology.html"}},[e._v("path pattern")]),e._v(" to manage privileges.")],1),e._v(" "),t("h3",{attrs:{id:"role"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#role"}},[e._v("#")]),e._v(" Role")]),e._v(" "),t("p",[e._v("A role is a set of privileges and has a unique role name as an identifier. A user usually corresponds to a real identity (such as a traffic dispatcher), while a real identity may correspond to multiple users. These users with the same real identity tend to have the same privileges. Roles are abstractions that can unify the management of such privileges.")]),e._v(" "),t("h3",{attrs:{id:"default-user"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#default-user"}},[e._v("#")]),e._v(" Default User")]),e._v(" "),t("p",[e._v("There is a default user in IoTDB after the initial installation: root, and the default password is root. This user is an administrator user, who cannot be deleted and has all the privileges. Neither can new privileges be granted to the root user nor can privileges owned by the root user be deleted.")]),e._v(" "),t("h2",{attrs:{id:"privilege-management-operation-examples"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#privilege-management-operation-examples"}},[e._v("#")]),e._v(" Privilege Management Operation Examples")]),e._v(" "),t("p",[e._v("According to the "),t("a",{attrs:{href:"https://github.com/thulab/iotdb/files/4438687/OtherMaterial-Sample.Data.txt",target:"_blank",rel:"noopener noreferrer"}},[e._v("sample data"),t("OutboundLink")],1),e._v(", the sample data of IoTDB might belong to different power generation groups such as ln, sgcc, etc. Different power generation groups do not want others to obtain their own database data, so we need to have data privilege isolated at the group layer.")]),e._v(" "),t("h3",{attrs:{id:"create-user"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#create-user"}},[e._v("#")]),e._v(" Create User")]),e._v(" "),t("p",[e._v("We use "),t("code",[e._v("CREATE USER <userName> <password>")]),e._v(" to create users. For example, we can use root user who has all privileges to create two users for ln and sgcc groups, named ln_write_user and sgcc_write_user, with both passwords being write_pwd. It is recommended to wrap the username in backtick(`). The SQL statement is:")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("CREATE USER `ln_write_user` 'write_pwd'\nCREATE USER `sgcc_write_user` 'write_pwd'\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("p",[e._v("Then use the following SQL statement to show the user:")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("LIST USER\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("p",[e._v("As can be seen from the result shown below, the two users have been created:")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("IoTDB> CREATE USER `ln_write_user` 'write_pwd'\nMsg: The statement is executed successfully.\nIoTDB> CREATE USER `sgcc_write_user` 'write_pwd'\nMsg: The statement is executed successfully.\nIoTDB> LIST USER\n+---------------+\n| user|\n+---------------+\n| ln_write_user|\n| root|\n|sgcc_write_user|\n+---------------+\nTotal line number = 3\nIt costs 0.157s\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br"),t("span",{staticClass:"line-number"},[e._v("3")]),t("br"),t("span",{staticClass:"line-number"},[e._v("4")]),t("br"),t("span",{staticClass:"line-number"},[e._v("5")]),t("br"),t("span",{staticClass:"line-number"},[e._v("6")]),t("br"),t("span",{staticClass:"line-number"},[e._v("7")]),t("br"),t("span",{staticClass:"line-number"},[e._v("8")]),t("br"),t("span",{staticClass:"line-number"},[e._v("9")]),t("br"),t("span",{staticClass:"line-number"},[e._v("10")]),t("br"),t("span",{staticClass:"line-number"},[e._v("11")]),t("br"),t("span",{staticClass:"line-number"},[e._v("12")]),t("br"),t("span",{staticClass:"line-number"},[e._v("13")]),t("br"),t("span",{staticClass:"line-number"},[e._v("14")]),t("br")])]),t("h3",{attrs:{id:"grant-user-privilege"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#grant-user-privilege"}},[e._v("#")]),e._v(" Grant User Privilege")]),e._v(" "),t("p",[e._v("At this point, although two users have been created, they do not have any privileges, so they can not operate on the database. For example, we use ln_write_user to write data in the database, the SQL statement is:")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("INSERT INTO root.ln.wf01.wt01(timestamp,status) values(1509465600000,true)\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("p",[e._v("The SQL statement will not be executed and the corresponding error prompt is given as follows:")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("IoTDB> INSERT INTO root.ln.wf01.wt01(timestamp,status) values(1509465600000,true)\nMsg: 602: No permissions for this operation INSERT\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("p",[e._v("Now, we use root user to grant the two users write privileges to the corresponding storage groups.")]),e._v(" "),t("p",[e._v("We use "),t("code",[e._v("GRANT USER <userName> PRIVILEGES <privileges> ON <nodeName>")]),e._v(" to grant user privileges(ps: grant create user does not need path). For example:")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("GRANT USER `ln_write_user` PRIVILEGES INSERT_TIMESERIES on root.ln.**\nGRANT USER `sgcc_write_user` PRIVILEGES INSERT_TIMESERIES on root.sgcc.**\nGRANT USER `ln_write_user` PRIVILEGES CREATE_USER\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br"),t("span",{staticClass:"line-number"},[e._v("3")]),t("br")])]),t("p",[e._v("The execution result is as follows:")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("IoTDB> GRANT USER `ln_write_user` PRIVILEGES INSERT_TIMESERIES on root.ln.**\nMsg: The statement is executed successfully.\nIoTDB> GRANT USER `sgcc_write_user` PRIVILEGES INSERT_TIMESERIES on root.sgcc.**\nMsg: The statement is executed successfully.\nIoTDB> GRANT USER `ln_write_user` PRIVILEGES CREATE_USER\nMsg: The statement is executed successfully.\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br"),t("span",{staticClass:"line-number"},[e._v("3")]),t("br"),t("span",{staticClass:"line-number"},[e._v("4")]),t("br"),t("span",{staticClass:"line-number"},[e._v("5")]),t("br"),t("span",{staticClass:"line-number"},[e._v("6")]),t("br")])]),t("p",[e._v("Next, use ln_write_user to try to write data again.")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("IoTDB> INSERT INTO root.ln.wf01.wt01(timestamp, status) values(1509465600000, true)\nMsg: The statement is executed successfully.\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("h3",{attrs:{id:"revoker-user-privilege"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#revoker-user-privilege"}},[e._v("#")]),e._v(" Revoker User Privilege")]),e._v(" "),t("p",[e._v("After granting user privileges, we could use "),t("code",[e._v("REVOKE USER <userName> PRIVILEGES <privileges> ON <nodeName>")]),e._v(" to revoke the granted user privileges(ps: revoke create user does not need path). For example, use root user to revoke the privilege of ln_write_user and sgcc_write_user:")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("REVOKE USER `ln_write_user` PRIVILEGES INSERT_TIMESERIES on root.ln.**\nREVOKE USER `sgcc_write_user` PRIVILEGES INSERT_TIMESERIES on root.sgcc.**\nREVOKE USER `ln_write_user` PRIVILEGES CREATE_USER\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br"),t("span",{staticClass:"line-number"},[e._v("3")]),t("br")])]),t("p",[e._v("The execution result is as follows:")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("REVOKE USER `ln_write_user` PRIVILEGES INSERT_TIMESERIES on root.ln.**\nMsg: The statement is executed successfully.\nREVOKE USER `sgcc_write_user` PRIVILEGES INSERT_TIMESERIES on root.sgcc.**\nMsg: The statement is executed successfully.\nREVOKE USER `ln_write_user` PRIVILEGES CREATE_USER\nMsg: The statement is executed successfully.\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br"),t("span",{staticClass:"line-number"},[e._v("3")]),t("br"),t("span",{staticClass:"line-number"},[e._v("4")]),t("br"),t("span",{staticClass:"line-number"},[e._v("5")]),t("br"),t("span",{staticClass:"line-number"},[e._v("6")]),t("br")])]),t("p",[e._v("After revoking, ln_write_user has no permission to writing data to root.ln.**")]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("INSERT INTO root.ln.wf01.wt01(timestamp, status) values(1509465600000, true)\nMsg: 602: No permissions for this operation INSERT\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("h3",{attrs:{id:"sql-statements"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#sql-statements"}},[e._v("#")]),e._v(" SQL Statements")]),e._v(" "),t("p",[e._v("Here are all related SQL statements:")]),e._v(" "),t("ul",[t("li",[e._v("Create User")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("CREATE USER <userName> <password>; \nEg: IoTDB > CREATE USER `thulab` 'pwd';\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Delete User")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("DROP USER <userName>; \nEg: IoTDB > DROP USER `xiaoming`;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Create Role")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("CREATE ROLE <roleName>; \nEg: IoTDB > CREATE ROLE `admin`;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Delete Role")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("DROP ROLE <roleName>; \nEg: IoTDB > DROP ROLE `admin`;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Grant User Privileges")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("GRANT USER <userName> PRIVILEGES <privileges> ON <nodeName>; \nEg: IoTDB > GRANT USER `tempuser` PRIVILEGES DELETE_TIMESERIES on root.ln.**;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Grant User All Privileges")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("GRANT USER <userName> PRIVILEGES ALL ON <nodeName>; \nEg: IoTDB > grant user renyuhua privileges all on root.**\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Grant Role Privileges")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("GRANT ROLE <roleName> PRIVILEGES <privileges> ON <nodeName>; \nEg: IoTDB > GRANT ROLE `temprole` PRIVILEGES DELETE_TIMESERIES ON root.ln.**;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Grant Role All Privileges")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("GRANT ROLE <roleName> PRIVILEGES ALL ON <nodeName>; \nEg: IoTDB > GRANT ROLE `temprole` PRIVILEGES ALL ON root.ln.**;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Grant User Role")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("GRANT <roleName> TO <userName>; \nEg: IoTDB > GRANT `temprole` TO tempuser;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Revoke User Privileges")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("REVOKE USER <userName> PRIVILEGES <privileges> ON <nodeName>; \nEg: IoTDB > REVOKE USER `tempuser` PRIVILEGES DELETE_TIMESERIES on root.ln.**;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Revoke User All Privileges")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("REVOKE USER <userName> PRIVILEGES ALL ON <nodeName>; \nEg: IoTDB > REVOKE USER `tempuser` PRIVILEGES ALL on root.ln.**;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Revoke Role Privileges")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("REVOKE ROLE <roleName> PRIVILEGES <privileges> ON <nodeName>; \nEg: IoTDB > REVOKE ROLE `temprole` PRIVILEGES DELETE_TIMESERIES ON root.ln.**;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Revoke All Role Privileges")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("REVOKE ROLE <roleName> PRIVILEGES ALL ON <nodeName>; \nEg: IoTDB > REVOKE ROLE `temprole` PRIVILEGES ALL ON root.ln.**;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Revoke Role From User")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("REVOKE <roleName> FROM <userName>;\nEg: IoTDB > REVOKE `temprole` FROM tempuser;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("List Users")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("LIST USER\nEg: IoTDB > LIST USER\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("List Roles")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("LIST ROLE\nEg: IoTDB > LIST ROLE\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("List Related Privileges of Users(On Specific Path)")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("LIST PRIVILEGES USER <username> ON <path>;\nEg: IoTDB> LIST PRIVILEGES USER `tempuser` ON root.ln.**;\n+--------+-----------------------------------+\n| role| privilege|\n+--------+-----------------------------------+\n| | root.ln.** : ALTER_TIMESERIES|\n|temprole|root.ln.wf01.** : CREATE_TIMESERIES|\n+--------+-----------------------------------+\nTotal line number = 2\nIt costs 0.005s\nIoTDB> LIST PRIVILEGES USER `tempuser` ON root.ln.wf01.wt01.**;\n+--------+-----------------------------------+\n| role| privilege|\n+--------+-----------------------------------+\n| | root.ln.** : ALTER_TIMESERIES|\n|temprole|root.ln.wf01.** : CREATE_TIMESERIES|\n+--------+-----------------------------------+\nTotal line number = 2\nIt costs 0.005s\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br"),t("span",{staticClass:"line-number"},[e._v("3")]),t("br"),t("span",{staticClass:"line-number"},[e._v("4")]),t("br"),t("span",{staticClass:"line-number"},[e._v("5")]),t("br"),t("span",{staticClass:"line-number"},[e._v("6")]),t("br"),t("span",{staticClass:"line-number"},[e._v("7")]),t("br"),t("span",{staticClass:"line-number"},[e._v("8")]),t("br"),t("span",{staticClass:"line-number"},[e._v("9")]),t("br"),t("span",{staticClass:"line-number"},[e._v("10")]),t("br"),t("span",{staticClass:"line-number"},[e._v("11")]),t("br"),t("span",{staticClass:"line-number"},[e._v("12")]),t("br"),t("span",{staticClass:"line-number"},[e._v("13")]),t("br"),t("span",{staticClass:"line-number"},[e._v("14")]),t("br"),t("span",{staticClass:"line-number"},[e._v("15")]),t("br"),t("span",{staticClass:"line-number"},[e._v("16")]),t("br"),t("span",{staticClass:"line-number"},[e._v("17")]),t("br"),t("span",{staticClass:"line-number"},[e._v("18")]),t("br"),t("span",{staticClass:"line-number"},[e._v("19")]),t("br")])]),t("ul",[t("li",[e._v("List Privileges of Roles")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("LIST ROLE PRIVILEGES <roleName>\nEg: IoTDB > LIST ROLE PRIVILEGES `actor`;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("List Related Privileges of Roles(On Specific Path)")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("LIST PRIVILEGES ROLE <roleName> ON <path>; \nEg: IoTDB> LIST PRIVILEGES ROLE `temprole` ON root.ln.**;\n+-----------------------------------+\n| privilege|\n+-----------------------------------+\n|root.ln.wf01.** : CREATE_TIMESERIES|\n+-----------------------------------+\nTotal line number = 1\nIt costs 0.005s\nIoTDB> LIST PRIVILEGES ROLE `temprole` ON root.ln.wf01.wt01.**;\n+-----------------------------------+\n| privilege|\n+-----------------------------------+\n|root.ln.wf01.** : CREATE_TIMESERIES|\n+-----------------------------------+\nTotal line number = 1\nIt costs 0.005s\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br"),t("span",{staticClass:"line-number"},[e._v("3")]),t("br"),t("span",{staticClass:"line-number"},[e._v("4")]),t("br"),t("span",{staticClass:"line-number"},[e._v("5")]),t("br"),t("span",{staticClass:"line-number"},[e._v("6")]),t("br"),t("span",{staticClass:"line-number"},[e._v("7")]),t("br"),t("span",{staticClass:"line-number"},[e._v("8")]),t("br"),t("span",{staticClass:"line-number"},[e._v("9")]),t("br"),t("span",{staticClass:"line-number"},[e._v("10")]),t("br"),t("span",{staticClass:"line-number"},[e._v("11")]),t("br"),t("span",{staticClass:"line-number"},[e._v("12")]),t("br"),t("span",{staticClass:"line-number"},[e._v("13")]),t("br"),t("span",{staticClass:"line-number"},[e._v("14")]),t("br"),t("span",{staticClass:"line-number"},[e._v("15")]),t("br"),t("span",{staticClass:"line-number"},[e._v("16")]),t("br"),t("span",{staticClass:"line-number"},[e._v("17")]),t("br")])]),t("ul",[t("li",[e._v("List Privileges of Users")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("LIST USER PRIVILEGES <username> ; \nEg: IoTDB > LIST USER PRIVILEGES `tempuser`;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("List Roles of User")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("LIST ALL ROLE OF USER <username> ; \nEg: IoTDB > LIST ALL ROLE OF USER `tempuser`;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("List Users of Role")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("LIST ALL USER OF ROLE <roleName>;\nEg: IoTDB > LIST ALL USER OF ROLE `roleuser`;\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("Alter Password")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("ALTER USER <username> SET PASSWORD <password>;\nEg: IoTDB > ALTER USER `tempuser` SET PASSWORD 'newpwd';\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("h2",{attrs:{id:"other-instructions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#other-instructions"}},[e._v("#")]),e._v(" Other Instructions")]),e._v(" "),t("h3",{attrs:{id:"the-relationship-among-users-privileges-and-roles"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#the-relationship-among-users-privileges-and-roles"}},[e._v("#")]),e._v(" The Relationship among Users, Privileges and Roles")]),e._v(" "),t("p",[e._v("A Role is a set of privileges, and privileges and roles are both attributes of users. That is, a role can have several privileges and a user can have several roles and privileges (called the user's own privileges).")]),e._v(" "),t("p",[e._v("At present, there is no conflicting privilege in IoTDB, so the real privileges of a user is the union of the user's own privileges and the privileges of the user's roles. That is to say, to determine whether a user can perform an operation, it depends on whether one of the user's own privileges or the privileges of the user's roles permits the operation. The user's own privileges and privileges of the user's roles may overlap, but it does not matter.")]),e._v(" "),t("p",[e._v("It should be noted that if users have a privilege (corresponding to operation A) themselves and their roles contain the same privilege, then revoking the privilege from the users themselves alone can not prohibit the users from performing operation A, since it is necessary to revoke the privilege from the role, or revoke the role from the user. Similarly, revoking the privilege from the users's roles alone can not prohibit the users from performing operation A.")]),e._v(" "),t("p",[e._v("At the same time, changes to roles are immediately reflected on all users who own the roles. For example, adding certain privileges to roles will immediately give all users who own the roles corresponding privileges, and deleting certain privileges will also deprive the corresponding users of the privileges (unless the users themselves have the privileges).")]),e._v(" "),t("h3",{attrs:{id:"list-of-privileges-included-in-the-system"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#list-of-privileges-included-in-the-system"}},[e._v("#")]),e._v(" List of Privileges Included in the System")]),e._v(" "),t("p",[t("strong",[e._v("List of privileges Included in the System")])]),e._v(" "),t("table",[t("thead",[t("tr",[t("th",{staticStyle:{"text-align":"left"}},[e._v("privilege Name")]),e._v(" "),t("th",{staticStyle:{"text-align":"left"}},[e._v("Interpretation")]),e._v(" "),t("th",[e._v("Example")])])]),e._v(" "),t("tbody",[t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("SET_STORAGE_GROUP")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("set storage groups; path dependent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("set storage group to root.ln;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("DELETE_STORAGE_GROUP")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("delete storage groups; path dependent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("delete storage group root.ln;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("CREATE_TIMESERIES")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("create timeseries; path dependent")]),e._v(" "),t("td",[e._v("Eg1: create timeseries"),t("br"),t("code",[e._v("create timeseries root.ln.wf02.status with datatype=BOOLEAN,encoding=PLAIN;")]),t("br"),e._v("Eg2: create aligned timeseries"),t("br"),t("code",[e._v("create aligned timeseries root.ln.device1(latitude FLOAT encoding=PLAIN compressor=SNAPPY, longitude FLOAT encoding=PLAIN compressor=SNAPPY);")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("INSERT_TIMESERIES")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("insert data; path dependent")]),e._v(" "),t("td",[e._v("Eg1: "),t("code",[e._v("insert into root.ln.wf02(timestamp,status) values(1,true);")]),t("br"),e._v("Eg2: "),t("code",[e._v("insert into root.sg1.d1(time, s1, s2) aligned values(1, 1, 1)")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("READ_TIMESERIES")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("query data; path dependent")]),e._v(" "),t("td",[e._v("Eg1: "),t("code",[e._v("show storage group;")]),e._v(" "),t("br"),e._v("Eg2: "),t("code",[e._v("show child paths root.ln, show child nodes root.ln;")]),t("br"),e._v("Eg3: "),t("code",[e._v("show devices;")]),t("br"),e._v("Eg4: "),t("code",[e._v("show timeseries root.**;")]),t("br"),e._v("Eg5: "),t("code",[e._v("show schema templates;")]),t("br"),e._v("Eg6: "),t("code",[e._v("show all ttl")]),t("br"),e._v("Eg7: "),t("RouterLink",{attrs:{to:"/UserGuide/Master/Query-Data/Overview.html"}},[e._v("Query-Data")]),e._v("(The query statements under this section all use this permission)"),t("br"),e._v("Eg8: CVS format data export"),t("br"),t("code",[e._v("./export-csv.bat -h 127.0.0.1 -p 6667 -u tempuser -pw root -td ./")]),t("br"),e._v("Eg9: Performance Tracing Tool"),t("br"),t("code",[e._v("tracing select * from root")]),t("br"),e._v("Eg10: UDF-Query"),t("br"),t("code",[e._v("select example(*) from root.sg.d1")]),t("br"),e._v("Eg11: Triggers-Query"),t("br"),t("code",[e._v("show triggers")])],1)]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("DELETE_TIMESERIES")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("delete data or timeseries; path dependent")]),e._v(" "),t("td",[e._v("Eg1: delete timeseries"),t("br"),t("code",[e._v("delete timeseries root.ln.wf01.wt01.status")]),t("br"),e._v("Eg2: delete data"),t("br"),t("code",[e._v("delete from root.ln.wf02.wt02.status where time < 10")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("CREATE_USER")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("create users; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("create user thulab 'passwd';")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("DELETE_USER")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("delete users; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("drop user xiaoming;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("MODIFY_PASSWORD")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("modify passwords for all users; path independent; (Those who do not have this privilege can still change their own asswords. )")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("alter user tempuser SET PASSWORD 'newpwd';")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("LIST_USER")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("list all users; list a user's privileges; list a user's roles; list users of Role with four kinds of operation privileges; path independent")]),e._v(" "),t("td",[e._v("Eg1: "),t("code",[e._v("list user;")]),t("br"),e._v("Eg2: "),t("code",[e._v("list privileges user 'admin' on root.sgcc.**;")]),t("br"),e._v("Eg3: "),t("code",[e._v("list user privileges admin;")]),t("br"),e._v("Eg4: "),t("code",[e._v("list all user of role 'admin';")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("GRANT_USER_PRIVILEGE")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("grant user privileges; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("grant user tempuser privileges DELETE_TIMESERIES on root.ln.**;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("REVOKE_USER_PRIVILEGE")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("revoke user privileges; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("revoke user tempuser privileges DELETE_TIMESERIES on root.ln.**;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("GRANT_USER_ROLE")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("grant user roles; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("grant temprole to tempuser;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("REVOKE_USER_ROLE")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("revoke user roles; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("revoke temprole from tempuser;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("CREATE_ROLE")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("create roles; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("create role admin;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("DELETE_ROLE")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("delete roles; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("drop role admin;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("LIST_ROLE")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("list all roles; list the privileges of a role; list the three kinds of operation privileges of all users owning a role; path independent")]),e._v(" "),t("td",[e._v("Eg1: "),t("code",[e._v("list role")]),t("br"),e._v("Eg2: "),t("code",[e._v("list role privileges actor;")]),t("br"),e._v("Eg3: "),t("code",[e._v("list privileges role wirte_role ON root.sgcc;")]),t("br"),e._v("Eg4: "),t("code",[e._v("list all role of user admin;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("GRANT_ROLE_PRIVILEGE")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("grant role privileges; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("grant role temprole privileges DELETE_TIMESERIES ON root.ln.**;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("REVOKE_ROLE_PRIVILEGE")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("revoke role privileges; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("revoke role temprole privileges DELETE_TIMESERIES ON root.ln.**;")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("CREATE_FUNCTION")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("register UDFs; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("create function example AS 'org.apache.iotdb.udf.UDTFExample';")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("DROP_FUNCTION")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("deregister UDFs; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("drop function example")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("CREATE_TRIGGER")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("create triggers; path dependent")]),e._v(" "),t("td",[e._v("Eg1: "),t("code",[e._v("CREATE TRIGGER <TRIGGER-NAME> BEFORE INSERT ON <FULL-PATH> AS <CLASSNAME>")]),t("br"),e._v("Eg2: "),t("code",[e._v("CREATE TRIGGER <TRIGGER-NAME> AFTER INSERT ON <FULL-PATH> AS <CLASSNAME>")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("DROP_TRIGGER")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("drop triggers; path dependent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("drop trigger 'alert-listener-sg1d1s1'")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("START_TRIGGER")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("start triggers; path dependent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("start trigger lert-listener-sg1d1s1'")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("STOP_TRIGGER")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("stop triggers; path dependent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("stop trigger 'alert-listener-sg1d1s1'")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("CREATE_CONTINUOUS_QUERY")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("create continuous queries; path independent")]),e._v(" "),t("td",[e._v("Eg: "),t("code",[e._v("select s1, s1 into t1, t2 from root.sg.d1")])])]),e._v(" "),t("tr",[t("td",{staticStyle:{"text-align":"left"}},[e._v("DROP_CONTINUOUS_QUERY")]),e._v(" "),t("td",{staticStyle:{"text-align":"left"}},[e._v("drop continuous queries; path independent")]),e._v(" "),t("td",[e._v("Eg1: "),t("code",[e._v("DROP CONTINUOUS QUERY cq3")]),t("br"),e._v("Eg2: "),t("code",[e._v("DROP CQ cq3")])])])])]),e._v(" "),t("p",[e._v("Note that the following SQL statements need to be granted multiple permissions before they can be used:")]),e._v(" "),t("ul",[t("li",[e._v("Import data: Need to assign "),t("code",[e._v("READ_TIMESERIES")]),e._v(","),t("code",[e._v("INSERT_TIMESERIES")]),e._v(" two permissions.。")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > ./import-csv.bat -h 127.0.0.1 -p 6667 -u renyuhua -pw root -f dump0.csv\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("Query Write-back (SELECT INTO)")]),e._v(" "),t("li",[t("ul",[t("li",[t("code",[e._v("READ_TIMESERIES")]),e._v(" permission of source sequence in all "),t("code",[e._v("select")]),e._v(" clauses is required")]),e._v(" "),t("li",[t("code",[e._v("INSERT_TIMESERIES")]),e._v(" permission of target sequence in all "),t("code",[e._v("into")]),e._v(" clauses is required")])])])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > select s1, s1 into t1, t2 from root.sg.d1 limit 5 offset 1000\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("h3",{attrs:{id:"username-restrictions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#username-restrictions"}},[e._v("#")]),e._v(" Username Restrictions")]),e._v(" "),t("p",[e._v("IoTDB specifies that the character length of a username should not be less than 4, and the username cannot contain spaces.")]),e._v(" "),t("h3",{attrs:{id:"password-restrictions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#password-restrictions"}},[e._v("#")]),e._v(" Password Restrictions")]),e._v(" "),t("p",[e._v("IoTDB specifies that the character length of a password should have no less than 4 character length, and no spaces. The password is encrypted with MD5.")]),e._v(" "),t("h3",{attrs:{id:"role-name-restrictions"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#role-name-restrictions"}},[e._v("#")]),e._v(" Role Name Restrictions")]),e._v(" "),t("p",[e._v("IoTDB specifies that the character length of a role name should have no less than 4 character length, and no spaces.")]),e._v(" "),t("h3",{attrs:{id:"path-pattern-in-administration-management"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#path-pattern-in-administration-management"}},[e._v("#")]),e._v(" Path pattern in Administration Management")]),e._v(" "),t("p",[e._v("A path pattern's result set contains all the elements of its sub pattern's\nresult set. For example, "),t("code",[e._v("root.sg.d.*")]),e._v(" is a sub pattern of\n"),t("code",[e._v("root.sg.*.*")]),e._v(", while "),t("code",[e._v("root.sg.**")]),e._v(" is not a sub pattern of\n"),t("code",[e._v("root.sg.*.*")]),e._v(". When a user is granted privilege on a pattern, the pattern used in his DDL or DML must be a sub pattern of the privilege pattern, which guarantees that the user won't access the timeseries exceed his privilege scope.")]),e._v(" "),t("h3",{attrs:{id:"permission-cache"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#permission-cache"}},[e._v("#")]),e._v(" Permission cache")]),e._v(" "),t("p",[e._v("In distributed related permission operations, when changing permissions other than creating users and roles, all the cache information of "),t("code",[e._v("dataNode")]),e._v(" related to the user (role) will be cleared first. If any "),t("code",[e._v("dataNode")]),e._v(" cache information is clear and fails, the permission change task will fail.")]),e._v(" "),t("h3",{attrs:{id:"operations-restricted-by-non-root-users"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#operations-restricted-by-non-root-users"}},[e._v("#")]),e._v(" Operations restricted by non root users")]),e._v(" "),t("p",[e._v("At present, the following SQL statements supported by iotdb can only be operated by the "),t("code",[e._v("root")]),e._v(" user, and no corresponding permission can be given to the new user.")]),e._v(" "),t("h6",{attrs:{id:"ttl"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#ttl"}},[e._v("#")]),e._v(" TTL")]),e._v(" "),t("ul",[t("li",[e._v("set ttl")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > set ttl to root.ln 3600\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("unset ttl")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > unset ttl to root.ln\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("h6",{attrs:{id:"schema-template"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#schema-template"}},[e._v("#")]),e._v(" Schema Template")]),e._v(" "),t("ul",[t("li",[e._v("Create Schema Template")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > create schema template t1 (temperature FLOAT encoding=RLE, status BOOLEAN encoding=PLAIN compression=SNAPPY)\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("Set Schema Template")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > set schema template t1 to root.sg1.d1\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("Uset Schema Template")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > unset schema template t1 from root.sg1.d1\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("Drop Schema Template")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > drop schema template t1\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("h6",{attrs:{id:"tsfile-management"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#tsfile-management"}},[e._v("#")]),e._v(" TsFile Management")]),e._v(" "),t("ul",[t("li",[e._v("Load TsFiles")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > load '/Users/Desktop/data/1575028885956-101-0.tsfile'\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("remove a tsfile")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > remove '/Users/Desktop/data/data/root.vehicle/0/0/1575028885956-101-0.tsfile'\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("unload a tsfile and move it to a target directory")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > unload '/Users/Desktop/data/data/root.vehicle/0/0/1575028885956-101-0.tsfile' '/data/data/tmp'\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("h6",{attrs:{id:"count"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#count"}},[e._v("#")]),e._v(" Count")]),e._v(" "),t("ul",[t("li",[e._v("Count storage group/Number of nodes/device/timeseries")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > count storage group\nEg: IoTDB > count nodes root.** LEVEL=2\nEg: IoTDB > count devices root.ln.**\nEg: IoTDB > count timeseries root.**\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br"),t("span",{staticClass:"line-number"},[e._v("3")]),t("br"),t("span",{staticClass:"line-number"},[e._v("4")]),t("br")])]),t("h6",{attrs:{id:"delete-time-partition-experimental"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#delete-time-partition-experimental"}},[e._v("#")]),e._v(" Delete Time Partition (experimental)")]),e._v(" "),t("ul",[t("li",[e._v("Delete Time Partition (experimental)")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > DELETE PARTITION root.ln 0,1,2\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("h6",{attrs:{id:"continuous-query-cq"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#continuous-query-cq"}},[e._v("#")]),e._v(" Continuous Query,CQ")]),e._v(" "),t("ul",[t("li",[e._v("Continuous Query,CQ")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > CREATE CONTINUOUS QUERY cq1 BEGIN SELECT max_value(temperature) INTO temperature_max FROM root.ln.*.* GROUP BY time(10s) END\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("h6",{attrs:{id:"maintenance-command"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#maintenance-command"}},[e._v("#")]),e._v(" Maintenance Command")]),e._v(" "),t("ul",[t("li",[e._v("FLUSH")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > flush\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("MERGE")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > MERGE\nEg: IoTDB > FULL MERGE\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br")])]),t("ul",[t("li",[e._v("CLEAR CACHE")])]),e._v(" "),t("div",{staticClass:"language-sql line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-sql"}},[t("code",[e._v("Eg: IoTDB "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v(">")]),e._v(" CLEAR CACHE\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("SET STSTEM TO READONLY / WRITABLE")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > SET STSTEM TO READONLY / WRITABLE\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("SCHEMA SNAPSHOT")])]),e._v(" "),t("div",{staticClass:"language-sql line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-sql"}},[t("code",[e._v("Eg: IoTDB "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v(">")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("CREATE")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("SNAPSHOT")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("FOR")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token keyword"}},[e._v("SCHEMA")]),e._v("\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("Query abort")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > KILL QUERY 1\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("h6",{attrs:{id:"watermark-tool"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#watermark-tool"}},[e._v("#")]),e._v(" Watermark Tool")]),e._v(" "),t("ul",[t("li",[e._v("Watermark new users")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > grant watermark_embedding to Alice\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])]),t("ul",[t("li",[e._v("Watermark Detection")])]),e._v(" "),t("div",{staticClass:"language- line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-text"}},[t("code",[e._v("Eg: IoTDB > revoke watermark_embedding from Alice\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br")])])])}),[],!1,null,null,null);t.default=r.exports}}]);