常用的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 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--释放游标
10 合并更新和插入
在开发中大部分情况下,插入和更新传递的参数基本上是一样,那为什么不合并呢
create proc [dbo].[Save_TableName]
(
@field1 varchar(50),
@field2???? varchar(200) ,
@ID int,
@insertOrUpdate --小于0插入 大于0更新
)
as
begin
?? if(@insertOrUpdate<0)
?begin
???? INSERT INTO?? TableName (field1,field2,ID )
????? values ( @field1? ,@field2,@ID);???
?end
else
???? begin
???? UPDATE TableName? SET field1= @field1, field2 = @field2????