常用的SQL数据库语句总结.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
常用的SQL数据库语句总结

常用的SQL数据库语句总结 正 文: 1、as 的用处?? ? as可以对表和列取别名 ? 在开发过程中经常遇到开始给某一个的字段去field1的名称,但后来有感觉field1字段指定不确切,于是又把此字段改成了field2,由于开始认为field1是常量,于是到处使用字符串field1,而且程序中又含有大量对field1的处理,? 此时就可以使用as 例如原来的 select field1 from tableA,改为select? field2 as? field1 from tableA 代码基本就可以不动了。 2、自增长的字段的插入 开发中经常遇到某个字段类型为IDENTITY,也就是自增长类型,但由于特殊需要,又要插入数据 需要临时去掉,可以使用如下语句set IDENTITY_INSERT? tablename on ,在处理完成后在使用如下语句恢复 set IDENTITY_INSERT? tablename? off 3、分组取每组的前N个数据 开发中还会遇到需要对某一组数据先分组,然后取每组的前n条记录的情况 不妨试试如下代码 /* 按CurrentNodeLevel列分组,每组按NodeID排序,取出每个组中的前3个元素 */ declare @temp table (NodeID int, CurrentNodeLevel int ,rowNumber int)--定义临时表 insert into @temp? select NodeID,CurrentNodeLevel,ROW_NUMBER() ?????????????????????? OVER (?? partition?? by CurrentNodeLevel ?????????????????????????????? order by NodeID ) as rowNumber from SchoolTerminalStruct---给临时表中插入数据 select * from @temp where rowNumber=3--从临时表中取数据 4、生成随机数 主意此方法只能写成存储过程,不能写成函数 -----返回Max ,Min之间的随机数? 不能写成函数 create proc [dbo].[getRAND] ( @Max int,--最大值 @Min int--,--最小值 ) AS BEGIN???? ?? DECLARE @result int ????? SELECT @result=RAND()*(@Max-@Min)+@Min?? END 5、把满足一定条件的数据用逗号分隔 这可能也是一个很常用的语句了,经常出现在一对多的关系中对外展示,要求把子表中的数据取出来用逗号或者其他符号分隔开 /* 把满足 t2.NodeID=t1.NodeID的tableA 的字段NodeName 以逗号分隔开合并为一个字段输出 */ select *,stuff((select , + t1.NodeName from tableA t1,tableB t2 ??????????????? where?? t2.NodeID=t1.NodeID ??????????????? for xml path()) , 1 , 1 , )? as text from tableA 6、在数据库中处理异常 通过个参数附加output标志来输出参数,通过TRY,CATCH捕捉异常 CREATE PROCEDURE [dbo].[sp_UpdateFunctionTree]? ??? @nodename int, ??? @Result int output---2,操作失败;0操作成功 AS BEGIN???????????? ? begin ??? BEGIN TRY ???? UPDATE FunctionTree SET NodeName=@nodename ????? set @Result=0 --操作成功 ???? END TRY BEGIN CATCH ???? set @Result=-2 --操作失败 END CATCH ? end????? END 7、查询中的条件判断 经常遇到在某些条件下应该查询这个字段,在另外一些条件下需要其他字段的情况,可以通过unoin来完成,但也可以通过CASE WHEN 完成 /* 在State=0 时返回field1 ,在State=1时返回 field2 ,其他时返回field3 */ ??? SELECT (CASE WHEN?? State=0 THEN field1 WHEN?? State=1 THEN field2 ??? ELSE field3

文档评论(0)

gangshou + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档