精妙的Sql语句Word文档下载推荐.docx
- 文档编号:20687107
- 上传时间:2023-01-25
- 格式:DOCX
- 页数:10
- 大小:21.37KB
精妙的Sql语句Word文档下载推荐.docx
《精妙的Sql语句Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《精妙的Sql语句Word文档下载推荐.docx(10页珍藏版)》请在冰豆网上搜索。
FROMTABLE1,
(SELECTX.NUM,X.UPD_DATE,Y.UPD_DATEPREV_UPD_DATE
FROM(SELECTNUM,UPD_DATE,INBOUND_QTY,STOCK_ONHAND
FROMTABLE2
WHERETO_CHAR(UPD_DATE,'
YYYY/MM'
)=TO_CHAR(SYSDATE,'
))X,
(SELECTNUM,UPD_DATE,STOCK_ONHAND
)=
TO_CHAR(TO_DATE(TO_CHAR(SYSDATE,'
)||'
/01'
'
YYYY/MM/DD'
)-1,'
))Y,
WHEREX.NUM=Y.NUM(+)
ANDX.INBOUND_QTY+NVL(Y.STOCK_ONHAND,0)<
X.STOCK_ONHAND)B
WHEREA.NUM=B.NUM
select*fromstudentinfowherenotexists(select*fromstudentwherestudentinfo.id=student.id)and系名称='
"
&
strdepartmentname&
'
and专业名称='
strprofessionname&
orderby性别,生源地,高考总成绩
7.说明:
从数据库中去一年的各单位电话费统计(电话费定额贺电化肥清单两个表来源)
SELECTa.userper,a.tel,a.standfee,TO_CHAR(a.telfeedate,'
yyyy'
)AStelyear,
SUM(decode(TO_CHAR(a.telfeedate,'
mm'
),'
01'
a.factration))ASJAN,
02'
a.factration))ASFRI,
03'
a.factration))ASMAR,
04'
a.factration))ASAPR,
05'
a.factration))ASMAY,
06'
a.factration))ASJUE,
07'
a.factration))ASJUL,
08'
a.factration))ASAGU,
09'
a.factration))ASSEP,
10'
a.factration))ASOCT,
11'
a.factration))ASNOV,
12'
a.factration))ASDEC
FROM(SELECTa.userper,a.tel,a.standfee,b.telfeedate,b.factration
FROMTELFEESTANDa,TELFEEb
WHEREa.tel=b.telfax)a
GROUPBYa.userper,a.tel,a.standfee,TO_CHAR(a.telfeedate,'
)
8.说明:
四表联查问题:
select*fromaleftinnerjoinbona.a=b.brightinnerjoincona.a=c.cinnerjoindona.a=d.dwhere.....
9.说明:
得到表中最小的未使用的ID号
SELECT(CASEWHENEXISTS(SELECT*FROMHandlebWHEREb.HandleID=1)THENMIN(HandleID)+1ELSE1END)asHandleID
FROMHandle
WHERENOTHandleIDIN(SELECTa.HandleID-1FROMHandlea)
9.SQL语句技巧
9.1、一个SQL语句的问题:
行列转换
select*fromv_temp
上面的视图结果如下:
user_namerole_name
-------------------------
系统管理员管理员
feng管理员
feng一般用户
test一般用户
想把结果变成这样:
---------------------------
feng管理员,一般用户
test一般用户
===================
createtablea_test(namevarchar(20),role2varchar(20))
insertintoa_testvalues('
李'
管理員'
)
張'
一般用戶'
常'
createfunctionjoin_str(@contentvarchar(100))
returnsvarchar(2000)
as
begin
declare@strvarchar(2000)
set@str='
select@str=@str+'
+rtrim(role2)froma_testwhere[name]=@content
select@str=right(@str,len(@str)-1)
return@str
end
go
--调用:
select[name],dbo.join_str([name])role2froma_testgroupby[name]
--selectdistinctname,dbo.uf_test(name)froma_test
9.2、求助!
快速比较结构相同的两表
结构相同的两表,一表有记录3万条左右,一表有记录2万条左右,我怎样快速查找两表的不同记录?
============================
给你一个测试方法,从northwind中的orders表取数据。
select*inton1fromorders
select*inton2fromorders
select*fromn1
select*fromn2
--添加主键,然后修改n1中若干字段的若干条
altertablen1addconstraintpk_n1_idprimarykey(OrderID)
altertablen2addconstraintpk_n2_idprimarykey(OrderID)
selectOrderIDfrom(select*fromn1
union
select*fromn2)agroupbyOrderIDhavingcount(*)>
1
应该可以,而且将不同的记录的ID显示出来。
下面的适用于双方记录一样的情况,
select*fromn1whereorderidin
(selectOrderIDfrom(select*fromn1
至于双方互不存在的记录是比较好处理的
--删除n1,n2中若干条记录
deletefromn1whereorderIDin('
10728'
10730'
deletefromn2whereorderIDin('
11000'
11001'
--*************************************************************
--双方都有该记录却不完全相同
)union
--n2中存在但在n1中不存的在10728,10730
select*fromn1whereOrderIDnotin(selectOrderIDfromn2)
union
--n1中存在但在n2中不存的在11000,11001
select*fromn2whereOrderIDnotin(selectOrderIDfromn1)
9.3、四种方法取表里n到m条纪录:
1.
selecttopm*into临时表(或表变量)fromtablenameorderbycolumnname--将topm笔插入
setrowcountn
select*from表变量orderbycolumnnamedesc
2.
selecttopn*from
(selecttopm*fromtablenameorderbycolumnname)a
orderbycolumnnamedesc
3.如果tablename里没有其他identity列,那么:
selectidentity(int)id0,*into#tempfromtablename
取n到m条的语句为:
select*from#tempwhereid0>
=nandid0<
=m
如果你在执行selectidentity(int)id0,*into#tempfromtablename这条语句的时候报错,那是因为你的DB中间的selectinto/bulkcopy属性没有打开要先执行:
execsp_dboption你的DB名字,'
selectinto/bulkcopy'
true
4.如果表里有identity属性,那么简单:
select*fromtablenamewhereidentitycolbetweennandm
5.如何删除一个表中重复的记录?
createtablea_dist(idint,namevarchar(20))
insertintoa_distvalues(1,'
abc'
execup_distinct'
a_dist'
id'
select*froma_dist
createprocedureup_distinct(@t_namevarchar(30),@f_keyvarchar(30))
--f_key表示是分組字段﹐即主鍵字段
declare@maxinteger,@idvarchar(30),@sqlvarchar(7999),@typeinteger
select@sql='
declarecur_rowscursorforselect'
+@f_key+'
count(*)from'
+@t_name+'
groupby'
+@f_key+'
havingcount(*)>
1'
exec(@sql)
opencur_rows
fetchcur_rowsinto@id,@max
while@@fetch_status=0
begin
select@max=@max-1
setrowcount@max
select@type=xtypefromsyscolumnswhereid=object_id(@t_name)andname=@f_key
if@type=56
deletefrom'
+@t_name+'
where'
+@f_key+'
='
+@id
if@type=167
+'
+@id+'
end
closecur_rows
deallocatecur_rows
setrowcount0
select*fromsystypes
select*fromsyscolumnswhereid=object_id('
9.4.查询数据的最大排序问题(只能用一条语句写)
CREATETABLEhard(quchar(11),cochar(11),jenumeric(3,0))
insertintohardvalues('
A'
1'
3)
2'
4)
4'
2)
6'
9)
B'
5)
3'
6)
C'
7)
要求查询出来的结果如下:
qucoje
---------------------------
A69
A24
B36
B25
C67
C34
就是要按qu分组,每组中取je最大的前2位!
!
而且只能用一句sql语句!
select*fromhardawherejein(selecttop2jefromhardbwherea.qu=b.quorderbyje)
9.5.求删除重复记录的sql语句?
怎样把具有相同字段的纪录删除,只留下一条。
例如,表test里有id,name字段
如果有name相同的记录只留下一条,其余的删除。
name的内容不定,相同的记录数不定。
有没有这样的sql语句?
==============================
A:
一个完整的解决方案:
将重复的记录记入temp1表:
select[标志字段id],count(*)intotemp1from[表名]
groupby[标志字段id]
havingcount(*)>
1
2、将不重复的记录记入temp1表:
inserttemp1
select[标志字段id],count(*)from[表名]
havingcount(*)=1
3、作一个包含所有不重复记录的表:
select*intotemp2from[表名]
where标志字段idin(select标志字段idfromtemp1)
4、删除重复表:
delete[表名]
5、恢复表:
insert[表名]
select*fromtemp2
6、删除临时表:
droptabletemp1
droptabletemp2
================================
B:
10.1.行列转换--普通
假设有张学生成绩表(CJ)如下
NameSubjectResult
张三语文80
张三数学90
张三物理85
李四语文85
李四数学92
李四物理82
想变成
姓名语文数学物理
张三809085
李四859282
declare@sqlvarchar(4000)
set@sql='
selectName'
select@sql=@sql+'
sum(caseSubjectwhen'
+Subject+'
thenResultend)['
]'
from(selectdistinctSubjectfromCJ)asa
select@sql=@sql+'
fromtestgroupbyname'
exec(@sql)
10.2.行列转换--合并
有表A,
idpid
11
12
13
21
22
31
如何化成表B:
11,2,3
21,2
创建一个合并的函数
createfunctionfmerg(@i
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 精妙 Sql 语句