⑴ sql数据库中怎么批量删除数据总共有1万多条,一条一条的删好慢啊~求大侠指点!比如:删除1-100横排
DELETEAFROMtalbeNameASA
WHEREEXISTS(SELECT1
FROM(SELECTTOP100IDFROMtalbeName)ASB
WHERE(A.ID=B.ID));
字符类型的ID要复杂些,如果ID是int类型的就更好办了。
⑵ sql server中如何快速批量删除表里的百万条记录!直接用delete top(50000)还是有点慢...
删除大量数据速度碰册是州烂正常的。
如果表里面数据都不要了,可以直接truncate
如果表里面数据只有一小部分要得,可以把小的备份出来,然后册吵漏truncate表,然后再把备份的数据导回来
如果只是删除表中部分数据,可以写成循环小批量删除脚本;如果服务器性能好,百万数据删除还是很快的
⑶ sql怎么删除一个表中的所有数据
删除表数据有两种方法: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。
(3)sql批量删除多条记录扩展阅读:
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 。
⑷ plsql批量删除表中数据
首先,在电脑中找到PLSQL Developer;