ehxz 发表于 2006-12-18 22:42:02

SQL高手篇:精典SQL FAQ收藏

  <b>1&#46; 行列转换--普通</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&#46; 行列转换--合并</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&#46;fmerg(id) from 表A<br />  <br />  <b>3&#46; 如何取得一个数据表的所有列名</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 />  是不是太简单了? 呵呵 不过经常用阿&#46;<br />  <br />  <b>4&#46; 通过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&#46; 怎么判断出一个表的哪些字段不允许为空?</b><br />  <br />  select COLUMN_NAME from INFORMATION_SCHEMA&#46;COLUMNS where IS_NULLABLE='NO' and TABLE_NAME=tablename<br />  <br />  <b>6&#46; 如何在数据库里找到含有相同字段的表?</b><br />  <br />  a&#46; 查已知列名的情况<br />  SELECT b&#46;name as TableName,a&#46;name as columnname<br />  From syscolumns  a INNER JOIN  sysobjects b<br />  ON a&#46;id=b&#46;id<br />  AND b&#46;type='U'<br />  AND a&#46;name='你的字段名字'<br />  <br />  b&#46; 未知列名查所有在不同表出现过的列名<br />  Select o&#46;name As tablename,s1&#46;name As columnname<br />  From syscolumns s1, sysobjects o<br />  Where s1&#46;id = o&#46;id<br />  And o&#46;type = 'U'<br />  And Exists (<br />  Select 1 From syscolumns s2<br />  Where s1&#46;name = s2&#46;name<br />  And s1&#46;id <> s2&#46;id<br />  )<br />  <br />  <b>7&#46; 查询第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&#46;id=bb&#46;id)<br />  <br />  如果使用游标也是可以的<br />  fetch absolute  from <br />  行数为绝对行数<br />  <br />  <b>8&#46; SQL Server日期计算</b><br />  <br />  a&#46; 一个月的第一天<br />  SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)<br />  b&#46; 本周的星期一<br />  SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)<br />  c&#46; 一年的第一天<br />  SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)<br />  d&#46; 季度的第一天<br />  SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)<br />  e&#46; 上个月的最后一天<br />  SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))<br />  f&#46; 去年的最后一天<br />  SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))<br />  g&#46; 本月的最后一天<br />  SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))<br />  h&#46; 本月的第一个星期一<br />  select DATEADD(wk, DATEDIFF(wk,0,<br />  dateadd(dd,6-datepart(day,getdate()),getdate())), 0)<br />  i&#46; 本年的最后一天<br />  SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))。
页: [1]
查看完整版本: SQL高手篇:精典SQL FAQ收藏