zl程序教程

您现在的位置是:首页 >  数据库

当前栏目

sql2000清空后让表的id从1开始等数据库操作

数据库 操作 ID 开始 清空 sql2000
2023-06-13 09:14:42 时间
truncatetable表名(
数据不可恢复性的删除truncate标识列会重排)
LinqUtil.Db.ExecuteCommand("TRUNCATETABLEwarehousing");//warehousing为表名,此种删除效率更高,且会清空计数器,但是有外键的表则不能用,可以通过删除外键后使用
LinqUtil.Db.ExecuteCommand("deleteioinfo");//因为此种删除不能清空计数器,所以下面还的清空
LinqUtil.Db.ExecuteCommand("dbcccheckident(ioinfo,reseed,0)");//清空计数器,ioinfo为表名
LinqUtil.Db.SubmitChanges();
清空表后执行
DBCCCHECKIDENT(表名,reseed,起始值)
如:
你要把表Employee的ID清空后从1开始
DBCCCHECKIDENT(Employee,reseed,0)--你添加了一条数据,从起始值开始加1
-------------------------------------------------------------------------------------
使用SQL语句清空数据库所有表的数据
近来发现数据库过大,空间不足,因此打算将数据库的数据进行全面的清理,但表非常多,一张一张的清空,实在麻烦,因此就想利用SQL语句一次清空所有数据.找到了三种方法进行清空.使用的数据库为MSSQLSERVER.

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.利用微软未公开的存储过程
execsp_msforeachtable"truncatetable?"
该方法可以一次清空所有表,但不能加过滤条件.
-----------------------------------------------------------------------------
清空表sql语句
可以使用delete清空表
DELETEFROMt表名
也可以使用truncate命令
truncatetable表名
CREATETABLE表名[表约束]
(列名1数据类型[缺省值1,列约束1]
(列名2数据类型[缺省值2,列约束2]

列名n数据类型[缺省值n,列约束n]
[TABLESPACE表空间名称]
[STORAGE(存贮的子句)]
[ENABLE约束名]
[DISABLE约束名]
?插入数据
INSERTINTO表名[(列名1,…)]
VALUES(值1,值2,…,值n)
?修改数据
UPDATE表名SET列名1=表达式1,列名2=表达式2,…
WHERE条件;
?删除数据
删除表中已有数据,不能删除不存在的数据。
语句句法:
DELETEFROM表名WHERE条件;
?表结构的修改
在已存在的表中增加新列,语句句法:
ALTERTABLE表名ADD(新列名数据类型(长度));
例如:
ALTERTABLESTUDENTADD(DEPARTMENTCHAR(8));
b.增加已有列的数据类型。
例如:
ALTERTABLESTUDENTMODIFY(NAMEVARCHAR2(25));
?表的删除
将已经存在的表删除,语句句法:
DROPTABLE表名;
例如:
DROPTABLEEMP;
?查询语句
SELECT命令的语法为:
SELECT[DISTINCT|ALL]{*|模式名.]{表名|视图名|
快照名].*…|{表达式[列别名]…}}[,[模式名.]{表名|
视图名|}.*…|表达式[列别名]]…
FROM[模式名.]{表名|视图名|快照名}[@数据库链名][表别名]
[,[模式名.]{表名|视图名|快照名}[@数据库链名]
[表别名]]…
[WHERE条件]
[STARTWITH条件CONNECTBY条件]
[GROUPBY表达式[,表达式]…[HAVING条件]
[UNION|UNIONALL|INTERSECT|MINUS]SELECT命令
[ORDERBY{表达式|位置}[ASC|DESC][,{表达式|位置[ASC|DESC]}]…]