社区应用 最新帖子 精华区 社区服务 会员列表 统计排行 社区论坛任务 迷你宠物
  • 4344阅读
  • 0回复

[转贴]精妙SQL语句收集

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

SQL语句先前写的时候,很容易把一些特殊的用法忘记,我特此整理了一下SQL语句操作。 j5tA!o  
voCQ_~*)9  
~g)gXPjke  
一、基础 'kPShZS$b  
1、说明:创建数据库 ?/NxZ\  
CREATE DATABASE database-name '%kk&&3'  
2、说明:删除数据库 RBiDU}j  
drop database dbname GtbI w  
3、说明:备份sql server s&z+j%;+o  
--- 创建 备份数据的 device A"p7N?|%  
USE master s4t>/.;x  
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' :rwF5  
--- 开始 备份 oT.g@kf=H  
BACKUP DATABASE pubs TO testBack k_$w+Q  
4、说明:创建新表 "<NQ2Vr]5  
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..) 5G= 2=E  
根据已有的表创建新表: KI#),~n S  
A:create table tab_new like tab_old (使用旧表创建新表) Q+gQ"l,95  
B:create table tab_new as select col1,col2... from tab_old definition only `AQv\@wp  
5、说明:删除新表 eZT923tD  
drop table tabname +ImPNwrY  
6、说明:增加一个列 u9QvcD^'z  
Alter table tabname add column col type umK~K!i  
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。 uQ. m[y  
7、说明:添加主键: Alter table tabname add primary key(col) 7zT]\AnO  
说明:删除主键: Alter table tabname drop primary key(col) %6HDLG6@^}  
8、说明:创建索引:create [unique] index idxname on tabname(col....) DTPYCG&%  
删除索引:drop index idxname L<*wzl2Go  
注:索引是不可更改的,想更改必须删除重新建。 or>5a9pj  
9、说明:创建视图:create view viewname as select statement *tO7A$LDT  
删除视图:drop view viewname nO2-fW:9]  
10、说明:几个简单的基本的sql语句 o|(-0mWBQA  
选择:select * from table1 where 范围 C%0|o/Wi  
插入:insert into table1(field1,field2) values(value1,value2) <e)3 j6F!  
删除:delete from table1 where 范围 &p`RKD  
更新:update table1 set field1=value1 where 范围 5 J61PuH   
查找:select * from table1 where field1 like '%value1%' ---like的语法很精妙,查资料! Sr/"'w;  
排序:select * from table1 order by field1,field2 [desc] QVm3(;&'  
总数:select count as totalcount from table1 {088j?[hzk  
求和:select sum(field1) as sumvalue from table1 m^%[  
平均:select avg(field1) as avgvalue from table1 0k0 y'1SL  
最大:select max(field1) as maxvalue from table1 G)M9to  
最小:select min(field1) as minvalue from table1 MW6d-  
S2h?Q $e3  
aB+Ux< -  
PJsiT4<  
11、说明:几个高级查询运算词 },e f(  
D~G24k6b3  
?,O{,2}  
A: UNION 运算符 7xz|u\?_2  
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。 6m|j " m  
B: EXCEPT 运算符 la[xbv   
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。 <9B\('  
C: INTERSECT 运算符 hj4Kv  
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。 u+~Ta  
注:使用运算词的几个查询结果行必须是一致的。 f^Lw3|rq4  
12、说明:使用外连接 -P^ 6b(  
A、left outer join: nPD5/xW  
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。 rB~x]5TH  
SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c 6$lj$8\  
B:right outer join: 4&2aJ_ 2 y  
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。 &+u) +<&;(  
C:full outer join: F\ yxXOI  
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。 M8oI8\6[  
H~^am  
2xN1=ug  
二、提升 BC=U6>`/  
1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用) p'fU}B1  
法一:select * into b from a where 1<>1 DP6M4  
法二:select top 0 * into b from a 8A~5@  
2、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用) b7^VWX%  
insert into b(a, b, c) select d,e,f from b; Y.$ '<1  
3、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用) FY|.eY_7 {  
insert into b(a, b, c) select d,e,f from b in '具体数据库' where 条件 y'(l]F1]  
例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where.. h/j+ b.|  
4、说明:子查询(表名1:a 表名2:b) DJ2EV^D+P  
select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3) iP6$;Y{ZA  
5、说明:显示文章、提交人和最后回复时间 ?kqo~twJ  
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b ,W;\6"Iwx'  
6、说明:外连接查询(表名1:a 表名2:b) {L$]NQdz  
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c Kz:g9  
7、说明:在线视图查询(表名1:a ) 6hv4D`d;o  
select * from (SELECT a,b,c FROM a) T where t.a > 1; Z?kLAhy!  
8、说明:between的用法,between限制查询数据范围时包括了边界值,not between不包括 SQ9s  
select * from table1 where time between time1 and time2 ( 6|S42  
select a,b,c, from table1 where a not between 数值1 and 数值2 ~pWbD~aeg  
9、说明:in 的使用方法 {+_ pyL  
select * from table1 where a [not] in ('值1','值2','值4','值6') ^Qt4}V=  
10、说明:两张关联表,删除主表中已经在副表中没有的信息 AL74q[>  
delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 ) *,A?lX,9A  
11、说明:四表联查问题: EbZRU65J}O  
select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where ..... Sp3?I2 o  
12、说明:日程安排提前五分钟提醒 Av:5v3%  
SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5 {{7%z4l  
13、说明:一条sql 语句搞定数据库分页 %]S~PKx  
select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段 2It$ bz  
14、说明:前10条记录 _h", ,"p#o  
select top 10 * form table1 where 范围 g} 7FR({b  
15、说明:选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.) sDL@e33Yb  
select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) 9tvLj5~  
16、说明:包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表 [XK Ke  
(select a from tableA ) except (select a from tableB) except (select a from tableC) :biM}L  
17、说明:随机取出10条数据 5-3`@ (/  
select top 10 * from tablename order by newid() ^tc2?T  
18、说明:随机选择记录 5}@6euT5$  
select newid() ;+t~$5  
19、说明:删除重复记录 ~$-Nl  
Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...) Fsv:SL+5  
20、说明:列出数据库里所有的表名 c+|,q m  
select name from sysobjects where type='U' Hg\+:}k&9  
21、说明:列出表里的所有的 ]V \qX+K  
select name from syscolumns where id=object_id('TableName') E$"( :%'v  
22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。 l=G=J(G  
select type,sum(case vender when 'A' then pcs else 0 end),sum(case vender when 'C' then pcs else 0 end),sum(case vender when 'B' then pcs else 0 end) FROM tablename group by type UE33e(Q<  
显示结果: ;gfY_MXnF  
type vender pcs /^v?Q9=Y  
电脑 A 1 #-?pY"N,  
电脑 A 1 )xYv$6=  
光盘 B 2 m22M[L(q  
光盘 A 2 28J ; 9  
手机 B 3 4)./d2/E  
手机 C 3 bI/d(Q%#<  
23、说明:初始化表table1 H7bdL 8/  
TRUNCATE TABLE table1 iTJSW  
24、说明:选择从10到15的记录 t>p!qKrE'J  
select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc g"gh2#!D  
 Cg[]y1Ne  
~= qJSb  
m2{3j[  
三、技巧 i j&_>   
1、1=1,1=2的使用,在SQL语句组合时用的较多 @|kBc.(]  
"where 1=1" 是表示选择全部  "where 1=2"全部不选, $Ay j4|_-  
如: \lwYDPY:  
if @strWhere !='' 9|#YKO\\i  
begin ug*#rpb  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where ' + @strWhere T 7`9[  
end ov>Rvy  
else wN1%;~?7  
begin gRA}sF  
set @strSQL = 'select count(*) as Total from [' + @tblName + ']' 72@lDY4cE  
end Z |wM  
我们可以直接写成 SJ$N]<d  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere (GB2("p`  
2、收缩数据库 9fp@d  
--重建索引 <>\s#Jf/  
DBCC REINDEX PF5;2  
DBCC INDEXDEFRAG Ba==Ri8$  
--收缩数据和日志  Gh;Ju[6  
DBCC SHRINKDB C;7?TZ&xw  
DBCC SHRINKFILE z'N_9=  
3、压缩数据库 ~^jdiy5  
dbcc shrinkdatabase(dbname) .1R:YNx{/  
4、转移数据库给新用户以已存在用户权限 _q*4+x  
exec sp_change_users_login 'update_one','newname','oldname' rrBu6\D  
go :l<)p;\  
5、检查备份集 r_/=iYYJ  
RESTORE VERIFYONLY from disk='E:\dvbbs.bak' _hT-5)1r  
6、修复数据库 -+fbK/  
ALTER DATABASE [dvbbs] SET SINGLE_USER .XD7};g  
GO d3Dw[4  
DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK ~xI1@^ r  
GO M =Pn8<h~  
ALTER DATABASE [dvbbs] SET MULTI_USER \z"0lAv"  
GO :.KN;+tP  
7、日志清除 0 ?kaXD  
SET NOCOUNT ON wc z|Zy  
DECLARE @LogicalFileName sysname, pm$ZKM  
        @MaxMinutes INT, pE.f}  
        @NewSize INT :C6  
USE    tablename            -- 要操作的数据库名 6b1f ?0  
SELECT  @LogicalFileName = 'tablename_log',  -- 日志文件名 BZAeg">3  
@MaxMinutes = 10,              -- Limit on time allowed to wrap log. 6f1%5&si  
        @NewSize = 1                  -- 你想设定的日志文件的大小(M) *=UxX ] 0y  
-- Setup / initialize ~<b/%l>h1  
DECLARE @OriginalSize int O 1T JJ8  
SELECT @OriginalSize = size f+>l-6M+p  
  FROM sysfiles "JI FF_  
  WHERE name = @LogicalFileName 5)X;q-  
SELECT 'Original Size of ' + db_name() + ' LOG is ' + aRFLh  
        CONVERT(VARCHAR(30),@OriginalSize) + ' 8K pages or ' +  !]]QbB  
        CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB' S |SN3)  
  FROM sysfiles C? pi8Xg  
  WHERE name = @LogicalFileName +-_71rJc.  
CREATE TABLE DummyTrans J[E_n;d1  
  (DummyColumn char (8000) not null) {z)&=v@  
DECLARE @Counter  INT, {ctEjgiE  
        @StartTime DATETIME, /7WN,a  
        @TruncLog  VARCHAR(255) cBICG",TA  
SELECT  @StartTime = GETDATE(), H:9Z.|{Gv  
        @TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY' 56 6vjE  
DBCC SHRINKFILE (@LogicalFileName, @NewSize) JNhHQvi\  
EXEC (@TruncLog) HU[a b  
-- Wrap the log if necessary. 0Y rdu,c  
WHILE    @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time has not expired RiHOX&-7  
      AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName)  4dy2m!  
      AND (@OriginalSize * 8 /1024) > @NewSize  a^yBtb~,P  
  BEGIN -- Outer loop. lZT9 SDtS  
    SELECT @Counter = 0 Xk#"rM< Y  
    WHILE  ((@Counter < @OriginalSize / 16) AND (@Counter < 50000)) @\-i3EhR  
      BEGIN -- update J6x#c`Y  
        INSERT DummyTrans VALUES ('Fill Log')  (!F Uu  
        DELETE DummyTrans f tBbO8e  
        SELECT @Counter = @Counter + 1 =gI;%M\'  
      END  8`bQ,E+2  
    EXEC (@TruncLog)  >:W7f2%8`  
  END  a[TR_ uR  
SELECT 'Final Size of ' + db_name() + ' LOG is ' + IT,d(UV_  
        CONVERT(VARCHAR(30),size) + ' 8K pages or ' + uK6_HvHuy  
        CONVERT(VARCHAR(30),(size*8/1024)) + 'MB' 3f'dBn5  
  FROM sysfiles 3L2@C%  
  WHERE name = @LogicalFileName .Q'/e>0  
DROP TABLE DummyTrans q^{Z"ifL  
SET NOCOUNT OFF k2>gnk0  
8、说明:更改某个表 zqEMR>px  
exec sp_changeobjectowner 'tablename','dbo' Uh.XL=wY  
9、存储更改全部表 e">$[IhXtV  
CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch M%=V vE.I  
@OldOwner as NVARCHAR(128), ejq2]^O4c  
@NewOwner as NVARCHAR(128) J?/.|Y]e  
AS O6rrv,+_L  
DECLARE @Name  as NVARCHAR(128) u<8 f ;C_  
DECLARE @Owner  as NVARCHAR(128) {"<6'2T3  
DECLARE @OwnerName  as NVARCHAR(128) ml7nt 0{  
DECLARE curObject CURSOR FOR B35zmFX|}N  
select 'Name'  = name, 9G8n'jWyY  
  'Owner'  = user_name(uid) _4E . P  
from sysobjects W}+f}/&l  
where user_name(uid)=@OldOwner =GO/r; 4  
order by name )c9]}:W&  
OPEN  curObject 5 `:+NwXS2  
FETCH NEXT FROM curObject INTO @Name, @Owner u15-|i{y7  
WHILE(@@FETCH_STATUS=0) F 8*e  
BEGIN    Eyw)f>  
if @Owner=@OldOwner **\BP,]}  
begin i!zh9,i>M  
  set @OwnerName = @OldOwner + '.' + rtrim(@Name) L||_Jsu  
  exec sp_changeobjectowner @OwnerName, @NewOwner ZLA&<]Ad"$  
end 6;/>asf  
-- select @name,@NewOwner,@OldOwner c*nH=  
FETCH NEXT FROM curObject INTO @Name, @Owner + -e8MvP  
END }gw `,i  
close curObject 1$,t:/'-4  
deallocate curObject gI^);J rTE  
GO r,p6J7/lfS  
10、SQL SERVER中直接循环写入数据 nquKeH  
declare @i int 1VW;[ ocQ  
set @i=1 AF{k^^|H  
while @i<30 K`.wj8zGY  
begin }qUNXE@  
  insert into test (userid) values(@i) 6 bL+q`3>  
  set @i=@i+1 ; n2|pC^  
end YT;b$>1v  
小记存储过程中经常用到的本周,本月,本年函数 Mwdh]I,#  
Dateadd(wk,datediff(wk,0,getdate()),-1) .K![<e Z  
Dateadd(wk,datediff(wk,0,getdate()),6) /'|'3J]HP  
Dateadd(mm,datediff(mm,0,getdate()),0) \'( @{  
Dateadd(ms,-3,dateadd(mm,datediff(m,0,getdate())+1,0)) )"7hyW5  
Dateadd(yy,datediff(yy,0,getdate()),0) JL~QE-pvD  
Dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0)) b`Wn98s  
上面的SQL代码只是一个时间段 ?sl 7C gl  
Dateadd(wk,datediff(wk,0,getdate()),-1) x}TDb0V  
Dateadd(wk,datediff(wk,0,getdate()),6) jE)&`yZ5  
就是表示本周时间段. fn|l9k~<O  
下面的SQL的条件部分,就是查询时间段在本周范围内的: '8~cf  
Where Time BETWEEN Dateadd(wk,datediff(wk,0,getdate()),-1) AND Dateadd(wk,datediff(wk,0,getdate()),6) O[RmQ8ll  
而在存储过程中 _]E ~ci}  
select @begintime = Dateadd(wk,datediff(wk,0,getdate()),-1) # k+Gg w  
select @endtime = Dateadd(wk,datediff(wk,0,getdate()),6) VQHJ O I  
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

描述
快速回复

您目前还是游客,请 登录注册
如果您提交过一次失败了,可以用”恢复数据”来恢复帖子内容
认证码:
验证问题:
10+5=?,请输入中文答案:十五