SQL收藏(更新中)

    技术2022-05-11  115

     1.SQL   Server同名表的判断:         IF   EXISTS(Select   *   From   sysobjects   where   ID=Object_ID(N'tablename')   AND   xType='U')         print   'exists'     else           print   'not   exists'SQL   Server:

    或IF   object_id('tableName')   is   not   null   and   OBJECTPROPERTY(object_id('tableName'),N'IsUserTable')   =   1         print   'exists'     else           print   'not   exists'

    2. 行列转换--普通

    假设有张学生成绩表(CJ)如下Name Subject Result张三 语文 80张三 数学 90张三 物理 85李四 语文 85李四 数学 92李四 物理 82

    想变成 姓名 语文 数学 物理张三 80 90 85李四 85 92 82

    declare @sql varchar(4000)set @sql = 'select Name'select @sql = @sql + ',sum(case Subject when '''+Subject+''' then Result end) ['+Subject+']'from (select distinct Subject from CJ) as aselect @sql = @sql+' from test group by name'exec(@sql)

    3 行列转换--合并

    有表A,id pid1 11 21 32 12 23 1如何化成表B:id pid 1 1,2,3 2 1,2 3 1

    创建一个合并的函数create function fmerg(@id int)returns varchar(8000)asbegindeclare @str varchar(8000)set @str=''select @str=@str+','+cast(pid as varchar) from 表A where id=@id set @str=right(@str,len(@str)-1)return(@str)Endgo

    --调用自定义函数得到结果select distinct id,dbo.fmerg(id) from 表A

    4. 如何取得一个数据表的所有列名

    方法如下:先从SYSTEMOBJECT系统表中取得数据表的SYSTEMID,然后再SYSCOLUMN表中取得该数据表的所有列名。SQL语句如下:declare @objid int,@objname char(40)set @objname = 'tablename'select @objid = id from sysobjects where id = object_id(@objname)select 'Column_name' = name from syscolumns where id = @objid order by colid

    是不是太简单了? 呵呵 不过经常用阿.

    5. 通过SQL语句来更改用户的密码

    修改别人的,需要sysadmin role EXEC sp_password NULL, 'newpassword', 'User'

    如果帐号为SA执行EXEC sp_password NULL, 'newpassword', sa

    6. 怎么判断出一个表的哪些字段不允许为空?

    select COLUMN_NAME from INFORMATION_SCHEMA.COLUMNS where IS_NULLABLE='NO' and TABLE_NAME=tablename

    7. 如何在数据库里找到含有相同字段的表?a. 查已知列名的情况SELECT b.name as TableName,a.name as columnname From syscolumns a INNER JOIN sysobjects b ON a.id=b.id AND b.type='U' AND a.name='你的字段名字'

    b. 未知列名查所有在不同表出现过的列名Select o.name As tablename,s1.name As columnname From syscolumns s1, sysobjects o Where s1.id = o.id  And o.type = 'U'  And Exists (  Select 1 From syscolumns s2  Where s1.name = s2.name  And s1.id <> s2.id  )

    8. 查询第xxx行数据

    假设id是主键: select * from (select top xxx * from yourtable) aa where not exists(select 1 from (select top xxx-1 * from yourtable) bb where aa.id=bb.id) 如果使用游标也是可以的 fetch absolute [number] from [cursor_name] 行数为绝对行数

    9. SQL Server日期计算a. 一个月的第一天SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0) b. 本周的星期一SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0) c. 一年的第一天SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0) d. 季度的第一天SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0) e. 上个月的最后一天 SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)) f. 去年的最后一天SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)) g. 本月的最后一天SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0)) h. 本月的第一个星期一select DATEADD(wk, DATEDIFF(wk,0,  dateadd(dd,6-datepart(day,getdate()),getdate())  ), 0) i. 本年的最后一天SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))。

    10.SQL SERVER的statistics I/O状态打开

    SET STATISTICS IO  on | off 

    select * from titles

    11 动态查询语句使用单引号处理

    select   @strSQL   =   'select   *   from   table   where   col1   =   ' ' ' '   and   col2   =   ' ' ' ' '    


    最新回复(0)