登录  
 加关注
查看详情
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

糟老頭的地盤

老頭的地盤听老頭的

 
 
 

日志

 
 

sql 2000数据库的操作,清空后让表的id从1开始等其他。  

2010-11-01 18:17:04|  分类: study |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

sql 清空数据库sql 2000,清空后让表的id从1开始

truncate table 表名    (

数据不可恢复性的删除  truncate  标识列会重排 

LinqUtil.Db.ExecuteCommand("TRUNCATE TABLE warehousing");   //warehousing为表名,此种删除效率更高,且会清空计数器,但是有外键的表则不能用,可以通过删除外键后使用   
LinqUtil.Db.ExecuteCommand("delete ioinfo"); //因为此种删除不能清空计数器,所以下面还的清空   
LinqUtil.Db.ExecuteCommand("dbcc checkident(ioinfo,reseed,0)"); //清空计数器,ioinfo为表名   
LinqUtil.Db.SubmitChanges();  

清空表后执行
DBCC CHECKIDENT(表名,reseed,起始值)

如:
你要把表 Employee 的ID清空后从1开始
DBCC CHECKIDENT(Employee,reseed,0)--你添加了一条数据,从起始值开始加1

 

--------------------------------------------------------------------------------

-----------------------------------------------------------------------------------

-------------------------------------------------------------------------------------

使用SQL语句清空数据库所有表的数据

近来发现数据库过大,空间不足,因此打算将数据库的数据进行全面的清理,但表非常多,一张一张的清空,实在麻烦,因此就想利用SQL语句一次清空所有数据.找到了三种方法进行清空.使用的数据库为MS SQL SERVER.
1.搜索出所有表名,构造为一条SQL语句


sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤declare @trun_name varchar(8000)
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤set @trun_name=''
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤select @trun_name=@trun_name + 'truncate table ' + [name] + ' ' from sysobjects where xtype='U' and status > 0
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤exec (@trun_name)

该方法适合表不是非常多的情况,否则表数量过多,超过字符串的长度,不能进行完全清理.
2.利用游标清理所有表


sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤declare @trun_name varchar(50)
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤declare name_cursor cursor for
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤select 'truncate table ' + name from sysobjects where xtype='U' and status > 0
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤open name_cursor
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤fetch next from name_cursor into @trun_name
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤while @@FETCH_STATUS = 0
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤begin
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤  exec (@trun_name)
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤 print 'truncated table ' + @trun_name
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤 fetch next from name_cursor into @trun_name
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤end
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤close name_cursor
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤deallocate name_cursor
sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤

这是我自己构造的,可以做为存储过程调用, 能够一次清空所有表的数据,并且还可以进行有选择的清空表.
3.利用微软未公开的存储过程


sql 2000数据库的操作,清空后让表的id从1开始等其他。 - 糟老头 - 糟老頭的地盤exec sp_msforeachtable "truncate table ?"

该方法可以一次清空所有表,但不能加过滤条件.

-----------------------------------------------------------------------------

清空表sql语句

可以使用delete清空表
DELETE FROM t表名

也可以使用truncate命令

truncate table 表名


CREATE TABLE 表名 [表约束]
(列名1 数据类型 [缺省值1,列约束1]
(列名2 数据类型 [缺省值2,列约束2]

列名n 数据类型 [缺省值n,列约束n]
[TABLESPACE 表空间名称]
[STORAGE (存贮的子句)]
[ENABLE 约束名]
[DISABLE 约束名]


? 插入数据
INSERT INTO 表名[(列名1,…)]
VALUES(值1,值2,…,值n)
? 修改数据
UPDATE 表名SET 列名1=表达式1,列名2=表达式2,…
WHERE 条件;
? 删除数据
删除表中已有数据,不能删除不存在的数据。
语句句法:
DELETE FROM 表名 WHERE 条件;
? 表结构的修改
在已存在的表中增加新列,语句句法:
ALTER TABLE 表名 ADD(新列名 数据类型(长度));
    例如:
    ALTER TABLE STUDENT ADD (DEPARTMENT CHAR(8));
b.增加已有列的数据类型。
    例如:
    ALTER TABLE STUDENT MODIFY(NAME VARCHAR2(25));
 
? 表的删除
将已经存在的表删除,语句句法:
    DROP TABLE表名;
    例如:
    DROP TABLE EMP;
 
? 查询语句
SELECT命令的语法为:
SELECT [DISTINCT|ALL] {*|模式名.] {表名|视图名|
快照名] .*…| {表达式[列别名]…} } [, [模式名. ] {表名|
视图名|} .*…| 表达式[列别名] ]…
FROM [模式名.] {表名|视图名|快照名} [@数据库链名] [表别名]
[, [模式名.] {表名|视图名|快照名} [@数据库链名]
[表别名] ]…
[WHERE条件]
[START WITH条件 CONNECT BY 条件]
[GROUP BY表达式[,表达式] …[HAVING条件]
[UNION|UNION ALL |INTERSECT|MINUS]SELECT命令
[ORDER BY{表达式|位置} [ASC|DESC] [, {表达式|位置[ASC|DESC]}]…]

 

---------------------------------------------------------------------------------------------------------------

  评论这张
 
阅读(2414)| 评论(2)

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018