存储过程批量删除数据
❶ 怎么使用sql语句批量删除多个表的相同字段
不知道您用的是什么数据库了。
不过做法肯定是一样,用两个游标,第一个游标从数据字典中检索出所有的表,第二个游标从每个表中检索所有的字段,然后遇到有要和你删除名称相同的字段的时候,执行alter
table
tablename
drop
column
columnname的操作。
不过这个执行不能直接这么执行,而是设置一个字符串的变量,例如SQLSERVER,需要@delsql
=
'alter
table
'
+
@tablename
+
'
drop
column
'
+
@columnname
exec(@delsql)
而oracle也一样delsql
=
'alter
table
'
+
tablename
+
'
drop
column
'
+
columnname;
execute
immediate
delsql;
要使用这样的写法。
不可能使用一个SQL直接删除所有的。
❷ sql能否批量删除多个行
1、首先我们打开SQL Server 2012资源管理器,在已创建好的数据库表t_call_info,查询和比较表记录。
❸ 用SQL语句怎么删除表中的所有数据
从一个表中删除数据,使用DELETE语句仔配。从表中删除所有行
DELETE FROMtable_name;
或DELETE * FROMtable_name;
或DELETE FROM Customers
WHERE cust_id = '10000006';
DELETE不需要列名和通配符,它是删除整行而不是删除列,要删除指定的列,请使用update语句;并且DELETE语句从表中删除行,甚至是删除表中所有行,而不是删除表本身。
如果想删除表中的所有行,可以使用TRUNCATE TABLE语句,完成相同的工作,而速度更快。
(3)存储过程批量删除数据扩展阅读
drop直接删掉表。
truncate删除的是表中的数据,再插入数据时自增长的数据id又重新从1开始。
delete删除表中数据,可以在后面添加where字句
(1)DELETE语句执行删除操作的过程是每次从表中删除一行,并且同时将该行的删除操岩基作作为事务记录在日志中保存以便进行进行回滚操作。TRUNCATE TABLE 则一次性地从表中删除所有的数据并不把单独的删除操作记录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。
(2) 表和索引所占空间。当表被TRUNCATE 后,这个表和索引所占用的空间会恢复到初始大小,而DELETE操作不会减少表或索引所占念枣指用的空间。drop语句将表所占用的空间全释放掉。
(3) 一般而言,drop > truncate > delete
(4) 应用范围。TRUNCATE 只能对TABLE;DELETE可以是table和view
(5) TRUNCATE 和DELETE只删除数据,而DROP则删除整个表(结构和数据)。
(6) truncate与不带where的delete :只删除数据,而不删除表的结构(定义)drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger)索引(index);依赖于该表的存储过程/函数将被保留,但其状态会变为:invalid。
❹ 批量删除(修改标记) update ERPInfo set IfDel=0 where ID in ("+ID+") 在sql2005中存储过程怎么写。
两种办法处理.
1. 使用动态SQL
也就是把你要执行的 SQL 语句, 存储到一个 varchar 变量里面。
然后你存储过程里面,执行的时候, 动态的拼接一个 SQL 语句,然后执行。
SQL Server 动态SQL 的例子:
http://hi..com/wangqing999/blog/item/6f6da5fee476db869f51465d.html
2.使用 CHARINDEX 替代 IN 的功能
例子:
http://hi..com/wangqing999/blog/item/1b8698fe14d68d8258ee9014.html