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

[转贴]精妙SQL语句收集

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

SQL语句先前写的时候,很容易把一些特殊的用法忘记,我特此整理了一下SQL语句操作。 {~fCqP.2  
8e!DDh  
;9 ,mV(w  
一、基础 !y-2#  
1、说明:创建数据库 c%@~%IGF  
CREATE DATABASE database-name ~9r!m5ws  
2、说明:删除数据库 DBJA}Cw  
drop database dbname drKjLo[y  
3、说明:备份sql server S tnv>  
--- 创建 备份数据的 device vo ;F;  
USE master .3<IOtD=  
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' oNB,.:  
--- 开始 备份 sD8 m<   
BACKUP DATABASE pubs TO testBack W Gw!Y1wq  
4、说明:创建新表 g'ZMV6b?K  
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..) & 8' (  
根据已有的表创建新表: {M r~%y4  
A:create table tab_new like tab_old (使用旧表创建新表) $i:||L^8p  
B:create table tab_new as select col1,col2... from tab_old definition only 030U7VT1  
5、说明:删除新表 6lmiMU&V  
drop table tabname Y/,$Y]%g  
6、说明:增加一个列 ml.;wB|  
Alter table tabname add column col type 'B (eMnLg  
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。 MJ*]fC3/  
7、说明:添加主键: Alter table tabname add primary key(col) hiRR+`L%  
说明:删除主键: Alter table tabname drop primary key(col) cZr G:\A  
8、说明:创建索引:create [unique] index idxname on tabname(col....) Vp $wHB&  
删除索引:drop index idxname ;DD>k bd  
注:索引是不可更改的,想更改必须删除重新建。 ("E!Jyc!  
9、说明:创建视图:create view viewname as select statement ~sU?"V  
删除视图:drop view viewname l>D-Aan  
10、说明:几个简单的基本的sql语句 qX{X4b$  
选择:select * from table1 where 范围 ZSPgci  
插入:insert into table1(field1,field2) values(value1,value2) W 9Vz[  
删除:delete from table1 where 范围 *el(+ib%  
更新:update table1 set field1=value1 where 范围 yYToiW *  
查找:select * from table1 where field1 like '%value1%' ---like的语法很精妙,查资料! /*AJr  
排序:select * from table1 order by field1,field2 [desc] nFe` <Al$N  
总数:select count as totalcount from table1 #_?TIY:h  
求和:select sum(field1) as sumvalue from table1 'sRg4?PT  
平均:select avg(field1) as avgvalue from table1 3X$Q,  
最大:select max(field1) as maxvalue from table1 |'c4er/;#  
最小:select min(field1) as minvalue from table1 ?Z Rkn+;  
e(~'pk"mZ  
I{42'9  
Y:%m;b$]  
11、说明:几个高级查询运算词 %e Sm&`  
O:;OR'N9  
,$h(fM8GC  
A: UNION 运算符 sK@Y!oF}\  
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。 T2DF'f3A  
B: EXCEPT 运算符 @%OPy|=,{  
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。 "mPSA Z  
C: INTERSECT 运算符 jVad)2D  
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。 4jX@m  
注:使用运算词的几个查询结果行必须是一致的。 5=Kq@[(4  
12、说明:使用外连接 ZT) !8  
A、left outer join: 4D^ M<Xn  
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。 uw Kh  
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 P>*Fj4 Z~  
B:right outer join: . [T'yc:=  
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。 4llD6&%  
C:full outer join: =oE_.ux\  
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。 \G$QNUU  
WI1T?.Gc   
:7p9t.R<$h  
二、提升 O87"[c`>  
1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用) { p1lae  
法一:select * into b from a where 1<>1 v:r D3=M-  
法二:select top 0 * into b from a 6exI_3A4jh  
2、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用) YBX)eWslK  
insert into b(a, b, c) select d,e,f from b; (U|)xA]y!  
3、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用) XC|*A$x,  
insert into b(a, b, c) select d,e,f from b in '具体数据库' where 条件 )v%l0_z{  
例子:..from b in '"&Server.MapPath(".")&"\data.mdb" &"' where.. z,pNb%*O  
4、说明:子查询(表名1:a 表名2:b) -#LjI.  
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) CO-Iar  
5、说明:显示文章、提交人和最后回复时间 /8xH$n&xoC  
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b N'I(P9@  
6、说明:外连接查询(表名1:a 表名2:b) izMYVI?0  
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c EjWgaV  
7、说明:在线视图查询(表名1:a ) tT;8r8@  
select * from (SELECT a,b,c FROM a) T where t.a > 1; gjW\ XY  
8、说明:between的用法,between限制查询数据范围时包括了边界值,not between不包括 ,*/Pg 52?  
select * from table1 where time between time1 and time2 ]SFWt/<  
select a,b,c, from table1 where a not between 数值1 and 数值2 pw@`}cM=  
9、说明:in 的使用方法 ]\A1mw-T  
select * from table1 where a [not] in ('值1','值2','值4','值6') w#*/y?"D  
10、说明:两张关联表,删除主表中已经在副表中没有的信息 m8'@UzB  
delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 ) bb|}'  
11、说明:四表联查问题: i<%m Iq1L  
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 ..... N 0+hejz  
12、说明:日程安排提前五分钟提醒 b -PSm=`  
SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5 A9 U5,mOz  
13、说明:一条sql 语句搞定数据库分页 k+FMZ, D|  
select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段 L e*`r2  
14、说明:前10条记录 p-.Ri^p   
select top 10 * form table1 where 范围 NX?}{'f  
15、说明:选择在每一组b值相同的数据中对应的a最大的记录的所有信息(类似这样的用法可以用于论坛每月排行榜,每月热销产品分析,按科目成绩排名,等等.) 5XDgs|8  
select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) 8tU>DJ}0  
16、说明:包括所有在 TableA 中但不在 TableB和TableC 中的行并消除所有重复行而派生出一个结果表 mge#YV::  
(select a from tableA ) except (select a from tableB) except (select a from tableC) n_v02vFAHT  
17、说明:随机取出10条数据 hM?`x(P  
select top 10 * from tablename order by newid() i8K_vo2Z)  
18、说明:随机选择记录 '|Qd0,Z  
select newid() _B)s=Snx  
19、说明:删除重复记录 2Kjrw;  
Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...) hjkLVL  
20、说明:列出数据库里所有的表名 ;;:">@5  
select name from sysobjects where type='U' |2O')3p"9  
21、说明:列出表里的所有的 ton1oq  
select name from syscolumns where id=object_id('TableName') S+r^B?a<oM  
22、说明:列示type、vender、pcs字段,以type字段排列,case可以方便地实现多重选择,类似select 中的case。 0!pJ5q ,A  
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 wfE^Sb3  
显示结果: 7%e1cI  
type vender pcs nE_Cuc>K\  
电脑 A 1 yq?]V7~  
电脑 A 1 kd yAl,  
光盘 B 2 Tr~sieL  
光盘 A 2 a0PE^U  
手机 B 3 ` M:DZNy,  
手机 C 3 42&v % ;R  
23、说明:初始化表table1 ML=eL*}l  
TRUNCATE TABLE table1 wTxbDT@H5  
24、说明:选择从10到15的记录 yO00I`5  
select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc "?35C !  
]Ko^G_Rm  
)IHG6}<  
Nb0Ik/:<  
三、技巧 O$^xkv5.  
1、1=1,1=2的使用,在SQL语句组合时用的较多 C8ZL*9U  
"where 1=1" 是表示选择全部  "where 1=2"全部不选, SAR= {/  
如: k0JW[04j  
if @strWhere !='' vB.l0!c\e_  
begin [@//#}5v  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where ' + @strWhere zVw:7-  
end !}_b|  
else EkjgNEXq  
begin z`4c 4h]I  
set @strSQL = 'select count(*) as Total from [' + @tblName + ']' RND9D\7  
end V^WU8x  
我们可以直接写成 Fk{J@Y  
set @strSQL = 'select count(*) as Total from [' + @tblName + '] where 1=1 安定 '+ @strWhere e4DMO*6  
2、收缩数据库 nob0T5G  
--重建索引 8f|98T"  
DBCC REINDEX j C)-`_  
DBCC INDEXDEFRAG 5MR,UgT  
--收缩数据和日志 Sm)u9  
DBCC SHRINKDB V7EQ4Om:It  
DBCC SHRINKFILE 5X#E@3g5  
3、压缩数据库 +y/55VLq  
dbcc shrinkdatabase(dbname) h$`#YNd'  
4、转移数据库给新用户以已存在用户权限 nBkh:5E5%  
exec sp_change_users_login 'update_one','newname','oldname' QOH<]~3J  
go Ke!'gohv  
5、检查备份集 X3',vey  
RESTORE VERIFYONLY from disk='E:\dvbbs.bak' dxK9:IX  
6、修复数据库 iPvuz7j=h  
ALTER DATABASE [dvbbs] SET SINGLE_USER (,B#t7ka  
GO Ird|C[la  
DBCC CHECKDB('dvbbs',repair_allow_data_loss) WITH TABLOCK 2s\BY%XY  
GO /,2rjJ#b  
ALTER DATABASE [dvbbs] SET MULTI_USER ;'0=T0\  
GO s9@Sd  
7、日志清除 .fp&MgiQ  
SET NOCOUNT ON Xh F _]  
DECLARE @LogicalFileName sysname, D<>@ %"%  
        @MaxMinutes INT, Ab2Q \+,  
        @NewSize INT I-kWS 4  
USE    tablename            -- 要操作的数据库名 5wv fF.v  
SELECT  @LogicalFileName = 'tablename_log',  -- 日志文件名 !X]8dyW  
@MaxMinutes = 10,              -- Limit on time allowed to wrap log. uH:YKH':/  
        @NewSize = 1                  -- 你想设定的日志文件的大小(M) V%*b@zv  
-- Setup / initialize :5b0np!  
DECLARE @OriginalSize int ~E)fpGJ  
SELECT @OriginalSize = size 9%tobo@J~n  
  FROM sysfiles F'FP0t!S  
  WHERE name = @LogicalFileName O6X"RsI}  
SELECT 'Original Size of ' + db_name() + ' LOG is ' + 2:SO_O4C  
        CONVERT(VARCHAR(30),@OriginalSize) + ' 8K pages or ' + v+xB7w  
        CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + 'MB' '#.#$8l  
  FROM sysfiles Ls}7VKl'   
  WHERE name = @LogicalFileName l$XPIC~H  
CREATE TABLE DummyTrans Rko M~`CT  
  (DummyColumn char (8000) not null) .UQE{.?  
DECLARE @Counter  INT, 2' ] KTHm  
        @StartTime DATETIME, <CZgQ\Mt  
        @TruncLog  VARCHAR(255) , jU5|2  
SELECT  @StartTime = GETDATE(), e2cP *J  
        @TruncLog = 'BACKUP LOG ' + db_name() + ' WITH TRUNCATE_ONLY' 6;iJ*2f5V  
DBCC SHRINKFILE (@LogicalFileName, @NewSize) `XKVr  
EXEC (@TruncLog) l1'6cLT`  
-- Wrap the log if necessary. 3I  $>uR  
WHILE    @MaxMinutes > DATEDIFF (mi, @StartTime, GETDATE()) -- time has not expired 9t$]X>}  
      AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName)  %%JMb=!%2  
      AND (@OriginalSize * 8 /1024) > @NewSize  AXPMnbUS  
  BEGIN -- Outer loop. ~Lz%.a;o  
    SELECT @Counter = 0 tU :EN;H  
    WHILE  ((@Counter < @OriginalSize / 16) AND (@Counter < 50000)) q%i-`S]}qL  
      BEGIN -- update =5x&8i  
        INSERT DummyTrans VALUES ('Fill Log')  Lja7   
        DELETE DummyTrans !RH.|}  
        SELECT @Counter = @Counter + 1 /.1. MssQM  
      END  !h`kX[:  
    EXEC (@TruncLog)  KzV 2MO-$  
  END  U*)m' ,  
SELECT 'Final Size of ' + db_name() + ' LOG is ' + Ba'LRz  
        CONVERT(VARCHAR(30),size) + ' 8K pages or ' + Bd~1P/  
        CONVERT(VARCHAR(30),(size*8/1024)) + 'MB' T.m mmT  
  FROM sysfiles k[kju%i4  
  WHERE name = @LogicalFileName ._PzYE|m2  
DROP TABLE DummyTrans ~}"]&%Q{J  
SET NOCOUNT OFF ?LK 2g  
8、说明:更改某个表 y[?-@7i  
exec sp_changeobjectowner 'tablename','dbo' Ul+Mo&y-  
9、存储更改全部表 6"f}O<M 5H  
CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch F?-R$<Cn2~  
@OldOwner as NVARCHAR(128), aZ|=(]  
@NewOwner as NVARCHAR(128) 5ZY<JA3  
AS oCS2E =O&  
DECLARE @Name  as NVARCHAR(128) nNt1C  
DECLARE @Owner  as NVARCHAR(128) _O"mfXl6  
DECLARE @OwnerName  as NVARCHAR(128) ep/Y^&$M  
DECLARE curObject CURSOR FOR 5jxQW ;  
select 'Name'  = name, 04U")-\O  
  'Owner'  = user_name(uid) N<(.%<!  
from sysobjects N!2Rl  
where user_name(uid)=@OldOwner U#&7p)4(  
order by name Ch \&GzQ  
OPEN  curObject F4L;BjnJ  
FETCH NEXT FROM curObject INTO @Name, @Owner \Ae9\Jp8M  
WHILE(@@FETCH_STATUS=0) YXo|~p;=Y  
BEGIN    6CbxuzYer  
if @Owner=@OldOwner pmWr]G3,*  
begin -E"GX  
  set @OwnerName = @OldOwner + '.' + rtrim(@Name) /X'(3'a  
  exec sp_changeobjectowner @OwnerName, @NewOwner [`RX*OH2  
end \QE)m<GUe  
-- select @name,@NewOwner,@OldOwner u8GMUN  
FETCH NEXT FROM curObject INTO @Name, @Owner kOo~%kcQ'  
END `;l.MZL!  
close curObject @&|l^ 1  
deallocate curObject ~@.%m"<.  
GO 3&&9_`r&_  
10、SQL SERVER中直接循环写入数据 d;mx<i=/  
declare @i int )lk&z8;.=  
set @i=1 0 &_UH}10  
while @i<30 Vv1|51B  
begin Y5ZZ3Ati  
  insert into test (userid) values(@i) M-V&X&?j  
  set @i=@i+1 z7GTaX$d  
end 9d[5{" 2j  
小记存储过程中经常用到的本周,本月,本年函数 D,qu-k[jMI  
Dateadd(wk,datediff(wk,0,getdate()),-1) V'*~L\;pU  
Dateadd(wk,datediff(wk,0,getdate()),6) !`41q=r  
Dateadd(mm,datediff(mm,0,getdate()),0) u VyGk~  
Dateadd(ms,-3,dateadd(mm,datediff(m,0,getdate())+1,0)) 2owEw*5jl/  
Dateadd(yy,datediff(yy,0,getdate()),0) W6H,6v  
Dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0)) 10!wqyj&  
上面的SQL代码只是一个时间段 ,<BbpIQ2o  
Dateadd(wk,datediff(wk,0,getdate()),-1) *}k;L74|  
Dateadd(wk,datediff(wk,0,getdate()),6) ^sN (  
就是表示本周时间段. U8qtwA9t  
下面的SQL的条件部分,就是查询时间段在本周范围内的: LI2&&Mw  
Where Time BETWEEN Dateadd(wk,datediff(wk,0,getdate()),-1) AND Dateadd(wk,datediff(wk,0,getdate()),6) ivDGZI9  
而在存储过程中 t58e(dgi  
select @begintime = Dateadd(wk,datediff(wk,0,getdate()),-1) ]I3!fEAWR  
select @endtime = Dateadd(wk,datediff(wk,0,getdate()),6) J:&[ 59  
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水

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

描述
快速回复

您目前还是游客,请 登录注册
温馨提示:欢迎交流讨论,请勿纯表情、纯引用!
认证码:
验证问题:
3+5=?,请输入中文答案:八 正确答案:八