精典SQL FAQ保藏
发布时间:2018-08-21 11:12:11 所属栏目:电商 来源:站长网
导读:在网上常常转,经常看到有些工钱了求得某些SQL语句而焦头烂额,此刻我出格把本身保藏的一些较量精典的SQL拿出来和各人分享一下 1. 队列转换--平凡 假设有张门生后果表(CJ)如下Name Subject Result张三 语文 80张三 数学 90张三 物理 85李四 语文 85李四 数学
在网上常常转,经常看到有些工钱了求得某些SQL语句而焦头烂额,此刻我出格把本身保藏的一些较量精典的SQL拿出来和各人分享一下 1. 队列转换--平凡 假设有张门生后果表(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) 2. 队列转换--归并 有表A, id pid 1 1 1 2 1 3 2 1 2 2 3 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=@idset @str=right(@str,len(@str)-1)return(@str)Endgo --挪用自界说函数获得功效select distinct id,dbo.fmerg(id) from 表A 3. 怎样取得一个数据表的全部列名 要领如下:先从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 是不是太简朴了? 呵呵 不外常常用阿. 4. 通过SQL语句来变动用户的暗码 修改别人的,必要sysadmin role EXEC sp_password NULL, 'newpassword', 'User' 假如帐号为SA执行EXEC sp_password NULL, 'newpassword', sa 5. 怎么判定出一个表的哪些字段不应承为空? select COLUMN_NAME from INFORMATION_SCHEMA.COLUMNS where IS_NULLABLE='NO' and TABLE_NAME=tablename 6. 如安在数据库里找到含有沟通字段的表?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 ) 7. 查询第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] 行数为绝对行数 8. 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))。 感激那些网上提供相干SQL的作者 (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |