daixinet

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

    SQL Server的一些操作:

1、判断一个表是否存在:

if exists(select * from sysobjects where id=OBJECT_ID(N'[' + @tableName + ']') and OBJECTPROPERTY(id,N'IsUserTable') = 1)

相对于这个数据库来说,OBJECT_ID根据表名得到ID,N表示显示的将非Unicode字符转化为Unicode字符,来自SQL-92 标准中的 National(Unicode)数据类型。OBJECTPROPERTY:返回当前数据库中对象的有关信息。1表“真”。

 

2、int转为Char

@char = cast(@int as varchar)

 

3、使用游标

--定义游标
declare MyCursor Cursor for
select CompanyId from dbo.Company where CompanyID in (7,29,16)
--打开游标
open MyCursor
--循环游标
declare @index int
fetch next from MyCursor into @index
while @@FETCH_STATUS=0
begin
exec('drop table dbo.C' + @index + '_DisplayPattern')
fetch next from MyCursor into @index
end
--关闭游标
close MyCursor
--释放资源
deallocate MyCursor

 

4、选择前几条,并且把相同的留下

select TOP 4 with ties * 
from dbo.T_Person
order by FAge

 

5、SQL的控制符列表

--ms sql里的控制字符列表:
--Tab   char(9)
--换行  char(10)
--回车  char(13)
--单引号 char(39)
--双引号 char(34)

 

6、得到一个表的行数

set @sqls='select @a=COUNT(*) from [DemoSite_0213_OldCSV].[dbo].[C' + @company + '_Proposal]'
exec sp_executesql @sqls,N'@a int output',@oldNumber output

 

posted on 2012-02-16 12:01  daixinet.com  阅读(319)  评论(0编辑  收藏  举报