使用普通用户登陆 MySQL 服务器,你可能需要特定的权限来创建或者删除 MySQL 数据库,所以我们这边使用 root 用户登录,root 用户拥有最高权限。...在删除数据库过程中,务必要十分谨慎,因为在执行删除命令后,所有数据将会消失。...drop 命令删除数据库 drop 命令格式: drop database ; 例如删除名为 RUNOOB 的数据库: mysql> drop database RUNOOB; 使用 mysqladmin...删除数据库 你也可以使用 mysql mysqladmin 命令在终端来执行删除命令。...规定要使用的 MySQL 连接。 query 必需,规定查询字符串。 resultmode 可选。一个常量。
SQL命令 DROP FUNCTION 删除函数 大纲 DROP FUNCTION name [ FROM className ] 参数 name - 要删除的函数的名称。名称是一个标识符。...但是,如果找不到此名称的函数,或者找到多个此名称的函数,则会返回错误代码。如果删除函数会导致空类,则DROP函数也会删除该类。 描述 DROP Function命令用于删除函数。...当删除某个函数时, IRIS会将其从已授予该函数的所有用户和角色中撤消,并将其从数据库中删除。 要删除函数,必须拥有由GRANT命令指定的%DROP_Function管理权限。...如果指定的函数不存在,DROP Function将生成SQLCODE-362错误。如果指定的类不存在,DROP函数将生成SQLCODE-360错误。...如果指定的函数可以引用两个或多个函数,DROP Function将生成SQLCODE-361错误;必须指定一个className来解决此歧义。
SQL命令 DROP VIEW 删除视图 大纲 DROP VIEW view-name [CASCADE | RESTRICT] 参数 view-name 要删除的视图的名称。...描述 DROP VIEW命令删除视图,但不删除基础表或数据。...也可以使用DropView()方法调用来调用拖放视图操作: $SYSTEM.SQL.Schema.DropView(viewname,SQLCODE,%msg) 权限 DROP VIEW命令是特权操作。...如果拥有适当的授予权限,则可以使用GRANT命令分配%DROP_VIEW权限。...如果设置为1(“Yes”),则为不存在的视图和表发出DROP VIEW或DROP TABLE不会执行任何操作,也不会发出错误消息。
SQL命令 DROP USER 删除用户帐户。 大纲 DROP USER user-name 参数 user-name 要删除的用户名。 描述 DROP USER命令可删除用户帐户。...此用户帐户是使用CREATE USER创建的,并指定了用户名。如果指定的用户名与现有用户帐户不对应, IRIS将发出SQLCODE-118错误。...在此用户帐户表上,可以单击要删除的用户帐户的删除。 权限 DROP USER命令是特权操作。在嵌入式SQL中使用DROP USER之前,必须以具有适当权限的用户身份登录。...使用$SYSTEM.Security.Login()方法分配具有适当权限的用户: DO $SYSTEM.Security.Login("_SYSTEM","SYS") &sql(...示例 可以通过下面的语句来删除PSMITH: DROP USER psmith
SQL命令 DROP ROLE 删除角色 大纲 DROP ROLE role-name 参数 role-name - 要删除的角色的名称。名称是一个标识符。角色名称不区分大小写。...描述 DROP ROLE语句删除角色。删除角色时, IRIS会将其从已授予该角色的所有用户和角色中撤消,并将其从数据库中删除。...如果尝试删除不存在(或已被删除)的角色,则DROP ROLE将发出SQLCODE-118错误。 权限 DROP ROLE命令是特权操作。...在嵌入式SQL中使用DROP ROLE之前,至少需要满足以下要求之一: 必须具有%Admin_Secure:USE权限。 该角色的所有者。 已被授予具有管理员选项的角色。...,"没有创建角色的权限" } else { w !
SQL命令 DROP TABLE 删除表及其数据(可选)。...%DELDATA,%NODELDATA - 可选-这些关键字指定在删除表时是否删除与表关联的数据。默认情况下,删除表格数据。 描述 DROP TABLE命令删除一个表及其对应的持久化类定义。...如果拥有适当的授予权限,则可以使用GRANT命令分配%DROP_TABLE权限。 即使DROP TABLE操作同时删除了表和表数据,用户也不必具有指定表的DELETE OBJECT权限。...由于这些原因,通常建议在删除表之前使用REVOKE命令撤消表中的对象权限。 包含数据的表 默认情况下,DROP TABLE删除表定义和表数据。...如果其中任何一个适用,DROP TABLE将使用效率较低的DELETE RECORD操作删除表的数据。 可以使用TRUNCATE TABLE命令删除表的数据,而不删除表定义。
SQL命令 DROP METHOD 删除方法 大纲 DROP METHOD name [ FROM className ] 参数 name - 要删除的方法的名称。名称是一个标识符。...但是,如果找不到此名称的方法,或者找到多个此名称的方法,则会返回错误代码。如果删除该方法会导致空类,则Drop方法也会删除该类。 描述 DROP METHOD命令可删除方法。...删除方法时, IRIS会将其从已授予该方法的所有用户和角色中撤消,并将其从数据库中删除。 要删除方法,必须具有GRANT命令指定的%DROP_METHOD管理权限。...如果指定的方法不存在,Drop Method将生成SQLCODE-362错误。如果指定的className不存在,Drop方法将生成SQLCODE-360错误。...使用PROCEDURE关键字定义的方法可以通过DROP方法或DROP PROCEDURE删除。 还可以删除方法,方法是从类定义中移除方法,然后重新编译类,或者删除整个类。
删除查询 大纲 DROP QUERY name [ FROM className ] 参数 name - 要删除的查询的名称。名称是一个标识符。不要指定查询的参数括号。...如果删除查询导致空类,则DROP QUERY也会删除该类。 描述 DROP QUERY命令删除查询。删除查询时, IRIS将从所有已授予该查询的用户和角色中吊销该查询,并将其从数据库中删除。...要删除查询,必须具有GRANT命令指定的%DROP_QUERY管理权限。如果要尝试删除具有已定义所有者的类的查询,则必须以类的所有者身份登录。否则,系统会生成SQLCODE-99错误(权限冲突)。...如果指定的查询不存在,DROP QUERY将生成SQLCODE-362错误。如果指定的类不存在,DROP QUERY将生成SQLCODE-360错误。...如果指定的查询可以引用两个或多个查询,DROP QUERY将生成SQLCODE-361错误;必须指定一个类名来解决此歧义。
SQL命令 DROP AGGREGATE 删除用户定义的聚合函数。 大纲 DROP AGGREGATE name 参数 name - 要删除的用户定义聚合函数的名称。...名称可以是限定的(schema.aggname),也可以是非限定的(aggname)。非限定名称采用默认架构名称。 描述 DROP Aggregate命令删除用户定义的聚合函数(UDAF)。...使用CREATE Aggregate命令创建用户定义的聚合函数。...如果尝试删除不存在的UDAF,SQL会发出SQLCODE-428错误,并显示如下消息:User Defined Aggregate Function Sample.SecondHighest does...删除UDAF会自动清除引用该UDAF的所有缓存查询。
SQL命令 DROP TRIGGER 删除触发器 大纲 DROP TRIGGER name [ FROM table ] 参数 name - 要删除的触发器的名称。...如果未指定FROM子句,则在NAME中指定的整个架构中搜索命名触发器。 描述 DROP TRIGGER命令删除触发器。...DROP TRIGGER命令是特权操作。用户必须具有%DROP_TRIGGER管理权限才能执行DROP TRIGGER。...如果拥有适当的授予权限,则可以使用GRANT命令分配%DROP_TRIGGER和%ALTER权限。...DROP TRIGGER不能用于从部署的持久类投射的表。
权限与锁 DROP INDEX命令是特权操作。用户必须具有%ALTER_TABLE管理权限才能执行DROP INDEX。...否则将导致%msg用户‘name’没有%ALTER_TABLE权限的SQLCODE-99错误。如果拥有适当的授予权限,则可以使用GRANT命令将%ALTER_TABLE权限分配给用户或角色。...可以通过调用%CHECKPRIV命令来确定当前用户是否具有%ALTER特权。可以使用GRANT命令将%ALTER权限分配给指定表。...DROP INDEX语句获取对table-name的表级锁。这可以防止其他进程修改表的数据。此锁在DROP INDEX操作结束时自动释放。...,"SQLCODE=",SQLCODE," 删除索引" } 下面的命令删除一个不存在的索引。
SQL命令 DROP DATABASE 删除数据库(命名空间)。...大纲 DROP DATABASE dbname [RETAIN_FILES] 参数 dbname - 要删除的数据库(命名空间)的名称。...描述 DROP DATABASE命令删除命名空间及其关联的数据库。 指定的dbname是包含相应数据库文件的命名空间和目录的名称。指定dbname作为标识符。命名空间名称不区分大小写。...如果指定的DBNAME命名空间不存在, IRIS将发出SQLCODE-340错误。 DROP DATABASE命令是一个特权操作。...在使用DROP DATABASE之前,必须以%Admin_Manage资源的用户身份登录。 用户还必须拥有用于例程和全局数据库定义的资源的READ权限。
如果删除过程导致空类,则DROP PROCEDURE也会删除该类。 描述 DROP PROCEDURE命令删除当前命名空间中的过程。...删除过程时, IRIS会将其从已授予该过程的所有用户和角色中撤消,并将其从数据库中删除。 要删除过程,必须具有GRANT命令指定的%DROP_PROCEDURE管理权限。...如果指定的过程不存在,DROP PROCEDURE将生成SQLCODE-362错误。如果指定的类不存在,DROP PROCEDURE将生成SQLCODE-360错误。...如果指定的过程可以引用两个或多个过程,DROP PROCEDURE将生成SQLCODE-361错误;必须指定一个类名来解决此歧义。...可以使用DROP PROCEDURE删除使用PROCEDURE关键字定义的方法。
一、MySQL清空表数据三种方法1.1 清空表数据:truncatesql命令#清空多张表、库中所有表的数据truncate table table_name1,table_name2,......数truncate删除数据后不写服务器log,整体删除速度快1.2 删除表:dropsql命令drop table table_name;drop table if exists table_name;...注意:drop会删除整个表,包括表结构和数据,释放空间立即执行,执行速度最快不可回滚1.3 删除/清空表数据:deletesql命令#删除部分数据delete from tb_name where clause...,可回滚如果不加where条件,表示删除表中所有数据,仅删除数据、保留表结构,同时也不释放表空间MySQL、Mariadb、PostgreSQL删除表数据、清空表命令 都可用以上三种命令。...三、truncate、drop、delete区别truncate、delete和drop都是用于删除数据或表的操作,但它们之间有一些关键的区别:操作类型:truncate:删除表中的所有数据,保留表结构
通过使用 DROP 语句,可以轻松地删除索引、表和数据库。...例如,删除一个表,表名为 table1 的表: drop table ; drop table table1 ; drop删除数据库 test1: drop database ; drop database test1;
MySQL中drop、delete与truncate的区别 在MySQL中,drop、delete和truncate是用来删除表中数据或整个表的命令。...DROP命令 DROP命令用于删除整个表,包括表的结构和数据。它的语法如下: DROP TABLE tablename; 使用DROP命令将完全删除指定的表以及表中的所有数据。...这意味着一旦执行了DROP命令,将无法恢复表的数据。因此,在使用DROP命令之前,务必要做好备份工作。 2. DELETE命令 DELETE命令用于删除表中的一行或多行数据,但保留表的结构。...4.1 使用DROP命令 DROP TABLE students; 使用DROP命令后,"students"表将被完全删除,包括表的结构和数据。...执行该命令后,如果我们再查询该表,将会得到一个空表。 5. 结论 在MySQL中,DROP、DELETE和TRUNCATE是用于删除表中数据或整个表的命令。
1. delete# delete属于数据管理语言(DML),会执行事务,也会触发触发器,可以回滚数据,常见的命令用法如下: # ① 删除表中的所有记录 delete from table_name;...在InnoDB引擎中,这种删除方式并不是真正的删除,即不会释放磁盘空间,只是给这些删除的记录打上一个标记,表示记录已经删除了;虽然未释放磁盘空间,但是下次有其他记录插入的时候,可以直接使用这部分空间。...table table_name; truncate命令从表中删除所有行,但表结构及其列,约束,索引等保持不变。...执行truncate需要drop权限,最好提前备份数据库表,因为无法通过binlog回滚。 3. drop# drop也属于数据定义语言(DDL),也不可恢复。...常用命令如下: drop table table_name; 不管是InnoDB引擎还是MyISAM引擎,在执行drop命令后都会释放磁盘空间,并且会删除该数据表上依赖的约束、触发器、索引。
1、删除速度:drop>truncate>delete; 2、删除方式: (1)执行delete操作时,每次从表中删除一行,并且同时将该行的的删除操作记录在日志文件中。...(3)drop则删除整个表的结构和数据,但是被依赖的约束、触发器、索引、依赖于该表的存储过程、函数将被保留,但其状态会变为invalid 3、删除后,表和索引所占空间: (1)delete操作不会减少表或索引所占用的空间...(3)drop语句将表所占用的空间全释放掉。...4、提交方式:delete是DML,需要手动提交操作才能生效,可以回滚,可以触发触发器;truncate和drop是DDL,会隐式提交,不能回滚,不会触发触发器。...5、使用场景: (1)如果想删除表,当然用drop; (2)如果想保留表而将所有数据删除,而且和事务无关,用truncate即可; (3)如果和事务有关,或者想触发trigger,还是用delete;
MySQL之delete user和drop user 的区别 Tip:在MySQL中,我们经常需要创建用户和删除用户,创建用户时,我们一般使用create user或者grant语句来创建,create...在一些测试用户创建完成之后,做完测试,可能用户的生命周期就结束了,需要将用户删除,而删除用户在MySQL中一般有两种方法,一种是drop user,另外一种是delete from mysql.user...,此时我们使用show grants for命令查看刚才删除的用户,我们发现依旧是存在这个用户的权限说明的: mysql 15:24:21>>show grants for yeyz@'%'; +--...再开看看drop的方法删除用户 首先,我们删除掉刚才的那两个用户,然后使用show grants for语句查看他们的权限: mysql ::>>drop user yeyz@'%'; Query OK...drop user方法删除用户的时候,会连通db表和权限表一起清除,也就是说删的比较干净,不会对以后的用户产生任何影响。
关于用户创建的文章,之前写过几篇《MySQL创建用户提示1396》《小白学习MySQL - 不同版本创建用户的些许区别》。 碰巧看到技术社群的这篇文章《同样是删用户,为啥还有差别?》...#'; Query OK, 0 rows affected (0.01 sec) # 删除用户testuser01 mysql> drop user 'testuser01'@'%'; Query OK...#'; Query OK, 0 rows affected (0.01 sec) 通过上面的例子发现,第一次创建用户testuser01之后,使用的drop的方式将用户删除,我们重新创建用户,正常创建用户成功...我们知道MySQL的一个新的连接,会为新连接维护一个线程对象,然后从权限数组里查到这个用户的权限,为了获取该用户可完成的权限,还需要将权限值拷贝到这个线程对象中。...回到前面的例子当中,delete操作相当于对这张表删除一条记录,当内存中并未删除,这也就为什么导致了delete操作后,无法重新创建的原因了,而drop操作是将表内记录和内存中的内容一并删除。
领取专属 10元无门槛券
手把手带您无忧上云