正文

SQL最最重要的详细资料!!2006-04-26 14:35:00

【评论】 【打印】 【字体: 】 本文链接:http://blog.pfan.cn/tankboy/13199.html

分享到:

精典的SQL语句,推荐收藏在网上经常转,常常看到有些人为了求得某些SQL语句而焦头烂额,现在我特别把自己收藏的一些比较精典的SQL拿出来和大家分享一下1. 行列转换--普通假设有张学生成绩表(CJ)如下Name    Subject     Result张三    语文        80张三    数学        90张三    物理        85李四    语文        85李四    数学        92李四    物理        82想变成    姓名   语文   数学   物理张三   80     90     85李四   85     92     82declare @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 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 表A3. 如何取得一个数据表的所有列名方法如下:先从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的作者 对ASP、.NET、JSP、SQL情有独钟的情圣王子,精通一门语言是要流血的  -_-  我编程三日 两耳不闻人声 只有硬盘在歌唱  -_- 俺的人生目标:(:|睡觉睡到自然醒|数钱数到手抽筋:)   作者:zmjls专家分:2990  会员信息 发短消息   所属BLOG 发表时间:2005-11-22 9:30:00    [回复]  [引用]  第 1 楼   转贴:SQL SERVER 与EXCEL的数据转换1、在SQL SERVER里查询Excel数据:-- ======================================================SELECT * FROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:\book1.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...[Sheet1$]下面是个查询的示例,它通过用于 Jet 的 OLE DB 提供程序查询 Excel 电子表格。SELECT * FROM OpenDataSource ( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:\Finance\account.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions-------------------------------------------------------------------------------------------------2、将Excel的数据导入SQL server :-- ======================================================SELECT * into newtableFROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:\book1.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...[Sheet1$]实例:SELECT * into newtableFROM OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:\Finance\account.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions-------------------------------------------------------------------------------------------------3、将SQL SERVER中查询到的数据导成一个Excel文件-- ======================================================T-SQL代码:EXEC master..xp_cmdshell 'bcp 库名.dbo.表名out c:\Temp.xls -c -q -S"servername" -U"sa" -P""'参数:S 是SQL服务器名;U是用户;P是密码说明:还可以导出文本文件等多种格式实例:EXEC master..xp_cmdshell 'bcp saletesttmp.dbo.CusAccount out c:\temp1.xls -c -q -S"pmserver" -U"sa" -P"sa"'EXEC master..xp_cmdshell 'bcp "SELECT au_fname, au_lname FROM pubs..authors ORDER BY au_lname" queryout C:\ authors.xls -c -Sservername -Usa -Ppassword'在VB6中应用ADO导出EXCEL文件代码: Dim cn As New ADODB.Connectioncn.open "Driver={SQL Server};Server=WEBSVR;DataBase=WebMis;UID=sa;WD=123;"cn.execute "master..xp_cmdshell 'bcp "SELECT col1, col2 FROM 库名.dbo.表名" queryout E:\DT.xls -c -Sservername -Usa -Ppassword'"-------------------------------------------------------------------------------------------------4、在SQL SERVER里往Excel插入数据:-- ======================================================insert into OpenDataSource( 'Microsoft.Jet.OLEDB.4.0','Data Source="c:\Temp.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...table1 (A1,A2,A3) values (1,2,3)T-SQL代码:INSERT INTO OPENDATASOURCE('Microsoft.JET.OLEDB.4.0', 'Extended Properties=Excel 8.0;Data source=C:\training\inventur.xls')...[Filiale1$] (bestand, produkt) VALUES (20, 'Test')

阅读(1600) | 评论(0)


版权声明:编程爱好者网站为此博客服务提供商,如本文牵涉到版权问题,编程爱好者网站不承担相关责任,如有版权问题请直接与本文作者联系解决。谢谢!

评论

暂无评论
您需要登录后才能评论,请 登录 或者 注册