怎样删除mysql一个表中的全部数据
01
如图,比如我有一张数据表studentinfo,我想要删除studentid为1009的这条数据。
02
我们可以直接点击设计界面下方的减号来删除数据。如图,选中数据,然后点击减号按钮。
03
点击减号之后,就会弹出一个提示框,问你是否要删除这条数据。
04
之后,选中的数据记录就从数据表中删除掉了。
05
也可以使用SQL语句来删除数据记录,点击查询菜单下的“新建查询”。
06
如图,在其中输入delete from studentinfo where studentid=1001;
这样就可以删除studentid为1001 的数据记录了。
Delete from 后面接的是表名,where后面接的是条件,
因为我是要删除studentinfo表中studentid等于1001的记录,所以就这样写。07
之后,点击运行按钮来执行删除操作。
08
如图,回到之前的界面,需要点击一下下边的刷新按钮。
09
这样,我们就可以看到1001的那条记录已经被删除掉了。
10
而如果想要删除全部的数据记录,可以直接输入查询语句:delete from studentinfo;
运行之后就可以删除全部的数据记录了。11
如图,所有的数据记录都被删除掉了。
删除表数据有两种方法:delete和truncate。具体语句如下:
一、RUNCATE TABLE name :
删除表中的所有行,而不记录单个行删除操作。 在这个指令之下,表格中的资料会完全消失,可是表格本身会继续存在。
TRUNCATE TABLE 的语法:TRUNCATE TABLE name ,参数 name 是要截断的表的名称或要删除其全部行的表的名称。
二、Delete from tablename where 1=1
1、delete语法:
DELETE FROM 表名称 WHERE 列名称 = 值。
2、删除所有行:
可以在不删除表的情况下删除所有的行。这意味着表的结构、属性和索引都是完整的:DELETE FROM table_name。
扩展资料:
truncate和delete的共同点及区别:
1、 truncate和 delete只删除数据不删除表的结构(定义) 。
2、delete语句是dml,这个操作会放到rollback segement中,事务提交之后才生效;如果有相应的trigger,执行的时候将被触发。
truncate是ddl, 操作立即生效,原数据不放到rollback segment中,不能回滚. 操作不触发trigger。
3、delete语句不影响表所占用的extent, 高水线(high watermark)保持原位置不动 。truncate 语句缺省情况下见空间释放到 minextents个 extent,除非使用reuse storage; truncate会将高水线复位(回到最开始)。
4、速度,一般来说: truncate >delete 。
参考资料:
推荐于2017-11-17 · 知道合伙人数码行家
您好,提问者:
-- 清空全部数据,不写日志,不可恢复,速度极快
truncate table 表名;
-- 清空全部数据,写日志,数据可恢复,速度慢
delete from 表名
1、删除表内数据及表结构:
drop table 表名;
2、删除表内数据可用两种语句,分别是delete语句和truncate语句:
delete from 表名;
truncate table 表名;
在效率上truncate的效率远远大于delete的效率。
delete from tablename;
truncate tablename;