常用的SQL数据库语句总结

来源:网络 责任编辑:栏目编辑 发表时间:2013-07-01 14:51 点击:

 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 END ) as State
  FROM tablename 

8单引号的处理

在包含单引号时应该使用两个单引号转义

dbo.sp_executesql @statement = N select indexID,Sex=( case when Sex=0 then 男 else 女 end )
  from tablename

9使用游标
 declare @temp table(TaskID int ,NodeId int)--声明临时表
 insert into @temp select A.TaskID ,A.NodeId from tableA A,tableB B
 where A.TaskID=B.TaskID--//--给声明的临时表中插入记录 
 DECLARE tnames_cursor CURSOR LOCAL FORWARD_ONLY READ_ONLY--声明游标
 FOR select TaskID,NodeId from @temp;--游标需要用到的列
 open tnames_cursor--打开游标
 DECLARE @TaskID int,@NodeId int;--声明变量
 FETCH NEXT FROM tnames_cursor INTO @TaskID,@NodeId--移动游标给变量赋值,应该与游标需要用到的列一一对应 ,顺序类型应该一致
 WHILE (@@FETCH_STATUS = 0)--循环
 BEGIN
  BEGIN  
  exec TaskType @TaskID,@NodeId--调用存储过程  
  END
  FETCH NEXT FROM tnames_cursor INTO @TaskID,@NodeId ,@TaskRunCYCType--移动游标 给变量赋值 应该与游标需要用到的列一一对应 ,顺序类型应该一致
 END
  CLOSE tnames_cursor--关闭游标
  DEALLOCATE tnames_cursor--释放

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      用户名: 验证码:点击我更换图片
      最新评论 更多>>

      推荐热点

      • sql常见面试题
      • SQL SERVER 2005性能之跟踪
      • SQL编程(一)
      • LINUX上RMAN自动备份脚本
      • sql server面试题
      • 如何将多个SQL查询统计结果一次显示出来
      • 浅谈SQL Server中的事务日志(三)----在简单恢复模式下日志的角色
      • SQL小技巧系列 --- 行转列合并
      • sql server 列转行
      网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
      Copyright © 2008-2015 计算机技术学习交流网. 版权所有

      豫ICP备11007008号-1