在存储过程中怎么清空表的数据
① 怎么样用oracle存储过程循环清空多张的表数据
你这多张表要有某种联系。
比如说表名按照日期取名:
这样可以按照这种规律将表名作为参数传入到存储过程中去。
过程中有条件,循环语句来控制。
你试试看。
如果有问题请详细说明。
② 如何在oracle中写一个存储过程,它的作用是清空emp表中的数据
使用动态sql,过程如下:
CREATE OR REPLACE PROCEDURE Prc_Delete_Emp IS
Lv_Sql VARCHAR2(200);
BEGIN
Lv_Sql := 'delete emp';
EXECUTE IMMEDIATE Lv_Sql;
COMMIT;
END;
③ 如何一个SQL语句就删除表中所有的数据
用SQL语句一次清空所有数据.找到了三种方法进行清空.使用的数据库为MS SQL SERVER.(表之间不能有外键关系)
1.搜索出所有表名,构造为一条SQL语句
declare@trun_namevarchar(8000)
set@trun_name=''
select@trun_name=@trun_name+'truncatetable'+[name]+''fromsysobjectswherextype='U'andstatus>0
exec(@trun_name)
该方法适合表不是非常多的情况,否则表数量过多,超过字符串的长度,不能进行完全清理.
2.利用游标清理所有表
declare@trun_namevarchar(50)
declarename_cursorcursorfor
select'truncatetable'+namefromsysobjectswherextype='U'andstatus>0
openname_cursor
fetchnextfromname_cursorinto@trun_name
while@@FETCH_STATUS=0
begin
exec(@trun_name)
print'truncatedtable'+@trun_name
fetchnextfromname_cursorinto@trun_name
end
closename_cursor
deallocatename_cursor
这是我自己构造的,可以做为存储过程调用, 能够一次清空所有表的数据,并且还可以进行有选择的清空表.
3.利用微软未公开的存储过程(前提是使用sql server 2005以上版本)
execsp_msforeachtable"truncatetable?"
--删除当前数据库所有表中的数据sp_MSforeachtable@command1='Deletefrom?'sp_MSforeachtable@command1="TRUNCATETABLE?"
该方法可以一次清空所有表,但不能加过滤条件.
引:csdn,blog.csdn.net/feiji323/article/details/5669775
④ 如何在DB2的SQL存储过程中实现清空表求答案
db2
create
table
ttt
(c1
char(6))
not
logged
initially
插入一些数据:
然后,以下SQL存储过程为例:
在SQL存储过程中,以EXCECUTE
IMMEDIATE
执行
alter
table
...
activate
not
logged
initially
with
empty
table
CREATE
PROCEDURE
HUANGDK.truncat_t
(
)
DYNAMIC
RESULT
SETS
1
------------------------------------------------------------------------
⑤ sqlserver存储过程如何定期删除表中的数据 求代码
方法一:
企业管理器
--管理
--SQL Server代理
--右键作业
--新建作业
--"常规"项中输入作业名称
--"步骤"项
--新建
--"步骤名"中输入步骤名
--"类型"中选择"Transact-SQL 脚本(TSQL)"
--"数据库"选择执行命令的数据库
--"命令"中输入要执行的语句:
update table set columns=0 where id=1
--确定
--"调度"项
--新建调度
--"名称"中输入调度名称
--"调度类型"中选择你的作业执行安排
--如果选择"反复出现"
--点"更改"来设置你的时间安排为一天一次
然后将SQL Agent服务启动,并设置为自动启动,否则你的作业不会被执行
设置方法: 我的电脑--控制面板--管理工具--服务--右键 SQLSERVERAGENT--属性--启动类型--选择"自动启动"--确定.
⑥ Mysql表通过存储过程删除生产表数据
在建设实时数仓的过程中,用到了Mysql存放增量的结果数据,所以需要定时清理历史数据,为了避免影响的线上的实时数据写入,采用了按照最后更改时间,分段删除的方法。对应的存储过程如下:
⑦ sql 存储过程中如何清空一个表数据
delete from table_name
或
truncate table table_name
⑧ 清空数据库所有表,所有存储过程SQL语句
近来发现数据库过大,空间不足,因此打算将数据库的数据进行全面的清理,但表非常多,一张一张的清空,实在麻烦,因此就想利用SQL语句一次清空所有数据.找到了三种方法进行清空.使用的数据库为MS SQL SERVER.
1.搜索出所有表名,构造为一条SQL语句
declare @trun_name varchar(8000)
set @trun_name=''
select @trun_name=@trun_name + 'truncate table ' + [name] + ' ' from sysobjects where xtype='U' and status > 0
exec (@trun_name)
该方法适合表不是非常多的情况,否则表数量过多,超过字符串的长度,不能进行完全清理.
2.利用游标清理所有表
declare @trun_name varchar(50)
declare name_cursor cursor for
select 'truncate table ' + name from sysobjects where xtype='U' and status > 0
open name_cursor
fetch next from name_cursor into @trun_name
while @@FETCH_STATUS = 0
begin
exec (@trun_name)
print 'truncated table ' + @trun_name
fetch next from name_cursor into @trun_name
end
close name_cursor
deallocate name_cursor
这是我自己构造的,可以做为存储过程调用, 能够一次清空所有表的数据,并且还可以进行有选择的清空表.
3.利用微软未公开的存储过程
exec sp_msforeachtable "truncate table ?"
该方法可以一次清空所有表,但不能加过滤条件.