SQL高手篇:精典SQL FAQ收藏
<b>1. 行列转换--普通</b><br /> <br /> 假设有张学生成绩表(CJ)如下<br /> Name Subject Result<br /> 张三 语文 80<br /> 张三 数学 90<br /> 张三 物理 85<br /> 李四 语文 85<br /> 李四 数学 92<br /> 李四 物理 82<br /> <br /> 想变成<br /> 姓名 语文 数学 物理<br /> 张三 80 90 85<br /> 李四 85 92 82<br /> <br /> declare @sql varchar(4000)<br /> set @sql = 'select Name'<br /> select @sql = @sql + ',sum(case Subject when '''+Subject+''' then Result end) ['+Subject+']'<br /> from (select distinct Subject from CJ) as a<br /> select @sql = @sql+' from test group by name'<br /> exec(@sql)<br /> <br /> <b>2. 行列转换--合并</b><br /> <br /> 有表A,<br /> id pid<br /> 1 1<br /> 1 2<br /> 1 3<br /> 2 1<br /> 2 2<br /> 3 1<br /> 如何化成表B:<br /> id pid<br /> 1 1,2,3<br /> 2 1,2<br /> 3 1<br /> <br /> 创建一个合并的函数<br /> create function fmerg(@id int)<br /> returns varchar(8000)<br /> as<br /> begin<br /> declare @str varchar(8000)<br /> set @str=''<br /> select @str=@str+','+cast(pid as varchar) from 表A where id=@id<br /> set @str=right(@str,len(@str)-1)<br /> return(@str)<br /> End<br /> go<br /> <br /> --调用自定义函数得到结果<br /> select distinct id,dbo.fmerg(id) from 表A<br /> <br /> <b>3. 如何取得一个数据表的所有列名</b><br /> <br /> 方法如下:先从SYSTEMOBJECT系统表中取得数据表的SYSTEMID,然后再SYSCOLUMN表中取得该数据表的所有列名。<br /> SQL语句如下:<br /> declare @objid int,@objname char(40)<br /> set @objname = 'tablename'<br /> select @objid = id from sysobjects where id = object_id(@objname)<br /> select 'Column_name' = name from syscolumns where id = @objid order by colid<br /> <br /> 是不是太简单了? 呵呵 不过经常用阿.<br /> <br /> <b>4. 通过SQL语句来更改用户的密码</b><br /> <br /> 修改别人的,需要sysadmin role<br /> EXEC sp_password NULL, 'newpassword', 'User'<br /> <br /> 如果帐号为SA执行EXEC sp_password NULL, 'newpassword', sa<br /> <br /> <b>5. 怎么判断出一个表的哪些字段不允许为空?</b><br /> <br /> select COLUMN_NAME from INFORMATION_SCHEMA.COLUMNS where IS_NULLABLE='NO' and TABLE_NAME=tablename<br /> <br /> <b>6. 如何在数据库里找到含有相同字段的表?</b><br /> <br /> a. 查已知列名的情况<br /> SELECT b.name as TableName,a.name as columnname<br /> From syscolumns a INNER JOIN sysobjects b<br /> ON a.id=b.id<br /> AND b.type='U'<br /> AND a.name='你的字段名字'<br /> <br /> b. 未知列名查所有在不同表出现过的列名<br /> Select o.name As tablename,s1.name As columnname<br /> From syscolumns s1, sysobjects o<br /> Where s1.id = o.id<br /> And o.type = 'U'<br /> And Exists (<br /> Select 1 From syscolumns s2<br /> Where s1.name = s2.name<br /> And s1.id <> s2.id<br /> )<br /> <br /> <b>7. 查询第xxx行数据</b><br /> <br /> 假设id是主键:<br /> select *<br /> from (select top xxx * from yourtable) aa<br /> where not exists(select 1 from (select top xxx-1 * from yourtable) bb where aa.id=bb.id)<br /> <br /> 如果使用游标也是可以的<br /> fetch absolute from <br /> 行数为绝对行数<br /> <br /> <b>8. SQL Server日期计算</b><br /> <br /> a. 一个月的第一天<br /> SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)<br /> b. 本周的星期一<br /> SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)<br /> c. 一年的第一天<br /> SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)<br /> d. 季度的第一天<br /> SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)<br /> e. 上个月的最后一天<br /> SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))<br /> f. 去年的最后一天<br /> SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))<br /> g. 本月的最后一天<br /> SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))<br /> h. 本月的第一个星期一<br /> select DATEADD(wk, DATEDIFF(wk,0,<br /> dateadd(dd,6-datepart(day,getdate()),getdate())), 0)<br /> i. 本年的最后一天<br /> SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))。
页:
[1]