1,MERGE INTO 语句:

这个语法仅需要一次全表扫描就完成了全部工作,执行效率要高于INSERT+UPDATE,作用还是很强大的(简单的说就是它可以批量更新和插入处理一个数据集,如果存在就更新指定列,不存在就插入)

/****** MERGE INTO 语句运用实例 ******/
-- =============================================
-- Author: <Author,yuanchen,Name>
-- Create date: <Create Date,,>
-- Description: <Description,将数据批量新增或更新到[dbo].[Table]中,ID为主键自增>
-- =============================================
Create PROCEDURE [dbo].[AddOrUpdateTable]
@Roles UDT_Table READONLY,--用户自定义表类型(相当于一个传入的临时表)
@ReturnValue INT OUTPUT --返回值
AS
BEGIN
SET NOCOUNT ON;
BEGIN TRY
BEGIN TRANSACTION
MERGE INTO [dbo].[Table] AS TARGET --此处[dbo].[Table]是需要插入或更新数据的表
USING (SELECT * FROM @UDT_Table) AS SOURCE
ON TARGET.ID = SOURCE.ID --根据此处的列作为条件判断是新增还是更新(多个列作为条件用and连接)
WHEN MATCHED
THEN UPDATE
SET
TARGET.[A]=SOURCE.[B],
TARGET.[B]=SOURCE.[B],
TARGET.[UpdateTime]=getdate() --内置函数获取当前时间
WHEN NOT MATCHED
THEN INSERT
([A],[B],[CreateTime])
VALUES(SOURCE.[A],SOURCE.[B],getdate());
SET @ReturnValue = 1
COMMIT TRAN
END TRY
BEGIN CATCH
IF XACT_STATE() <> 0
BEGIN
ROLLBACK TRANSACTION;
--此处可以用Error_message()函数记录日志,千万不要在ROLLBACK TRANSACTION前面记录日志,会被回滚
SET @ReturnValue = -1
END;
END CATCH
END

2,WITH XXX AS  语句:

WITH AS短语,也叫做子查询部分(subquery factoring),可以让你做很多事情,定义一个SQL片断,该SQL片断会被整个SQL语句所用到。有的时候,是为了让SQL语句的可读性更高些,也有可能是在UNION ALL的不同部分,作为提供数据的部分。 
特别对于UNION ALL比较有用。因为UNION ALL的每个部分可能相同,但是如果每个部分都去执行一遍的话,则成本太高,所以可以使用WITH AS短语,则只要执行一遍即可。如果WITH AS短语所定义的表名被调用两次以上,则优化器会自动将WITH AS短语所获取的数据放入一个TEMP表里,如果只是被调用一次,则不会。而提示materialize则是强制将WITH AS短语里的数据放入一个全局临时表里。很多查询通过这种方法都可以提高速度。(更高效,可读性更好,复杂的子查询推荐使用)

With [Table1] As(
select * from [A] inner join [B] on [A].ID=B.[A_ID] --A表和B表连表查询
),[Table2] As(
select * from [C] inner join [Table1] T on [C].ID=T.[C_ID] --C表和A,B表的查询结果连表查询
)Select * From [Table2] --上面的查询结果等同于下面这段Sql
select * from [C] inner join (select * from [A] inner join [B] on [A].ID=B.[A_ID]) T on [C].ID=T.[C_ID]

3,游标的常规使用,游标可以遍历数据集对每条数据的指定列做处理,处理数据的能力也是相当强大的,但是滥用和使用不当可能对造成性能问题哦,而且处理复杂的多表多条数据时一般都要配合事务一起使用,不然一旦程序错误就会产生错误数据

/****** 游标的使用实例  ******/
-- =============================================
-- Author: <Author,yuanchen>
-- Create date: <Create Date,>
-- Description: <Description,>
-- =============================================
Create Proc [dbo].[Proc_CURSOR_USE]
AS
BEGIN
SET NOCOUNT ON; DECLARE @ID BIGINT --定义变量
DECLARE @A BIGINT
DECLARE @B NVARCHAR(100) Select * INTO #Table From [Table] --将查询结果放入临时表
--定义游标
DECLARE CURSOR_JOB01 CURSOR FOR
Select [ID],[A],[B] From #Table --此处可以不用临时表,直接写查询语句,但在实际的业务处理中我们需要的查询结果可能是通过复杂的查询语句得到的,直接写在此处,可读性较差
OPEN CURSOR_JOB01
FETCH CURSOR_JOB01 INTO @ID,@A,@B
BEGIN TRY
BEGIN TRANSACTION
WHILE (@@FETCH_STATUS=0)
BEGIN
--此处可以编写逻辑代码,即对游标遍历的当前数据做处理,例如:如果当前数据列A>0,那么就向[BaseLog]表记录一条日志
IF(@A>0)
Begin
Insert into BaseLog([CONTENT],[CreateTime],[Pro_Name]) values('ID为:'+CONVERT(varchar(10),@ID)++'的A列的值大于0',getdate(),'[Proc_CURSOR_USE]'); --记录错误日志
End
FETCH CURSOR_JOB01 INTO @ID,@A,@B
END
CLOSE CURSOR_JOB01
DEALLOCATE CURSOR_JOB01
COMMIT
END TRY
BEGIN CATCH
IF XACT_STATE() <> 0
BEGIN
ROLLBACK TRANSACTION;
Insert into BaseLog([CONTENT],[CreateTime],[Pro_Name]) values(Error_message(),getdate(),'[Proc_CURSOR_USE]'); --记录错误日志
IF CURSOR_STATUS('local','CURSOR_JOB01') <> -3
BEGIN
IF CURSOR_STATUS('local','CURSOR_JOB01') <> -1
BEGIN
CLOSE CURSOR_JOB01
DEALLOCATE CURSOR_JOB01
END
END
END;
END CATCH
DROP TABLE #Table --清除临时表
END

几个很好用SQL语法(SqlServer)的更多相关文章

  1. SQLite中不支持的sql语法

    今天很自然的在写Sql语句的时候用了Top,一开始没发现问题,因为我从数据库读出的值正好是0,而我习惯变量定义的时候也都赋值0,可是到我不要0的时候我就发现问题了.后来才知道,可爱的小sqlite竟然 ...

  2. SQL语法汇总

    以下默认为mySQL与SQLsever都能使用SQLsever不能使用的另外标出来了 显示数据库SHOW DATABASES;进入其中一个数据库USE students;显示进入数据库中的所有表SHO ...

  3. java核心技术第二篇之数据库SQL语法

    #查询products表记录SELECT * FROM products WHERE price > 2000;-- 单行注释/* 多行注释*/#创建数据库CREATE DATABASE hei ...

  4. [转]MySQL 最基本的SQL语法/语句

    MySQL 最基本的SQL语法/语句,使用mysql的朋友可以参考下.   DDL-数据定义语言(Create,Alter,Drop,DECLARE) DML-数据操纵语言(Select,Delete ...

  5. ORACLE分页查询SQL语法——最高效的分页

    --1:无ORDER BY排序的写法.(效率最高)--(经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然!) SELECT * FROM (SELECT  ...

  6. [Android新手区] SQLite 操作详解--SQL语法

    该文章完全摘自转自:北大青鸟[Android新手区] SQLite 操作详解--SQL语法  :http://home.bdqn.cn/thread-49363-1-1.html SQLite库可以解 ...

  7. SQLite的 SQL语法总结

    SQLite库可以解析大部分标准SQL语言.但它也省去了一些特性并且加入了一些自己的新特性.这篇文档就是试图描述那些SQLite支持/不支持的SQL语法的.查看关键字列表. 如下语法表格中,纯文本用蓝 ...

  8. Hadoop Hive sql语法详解

    Hadoop Hive sql语法详解 Hive 是基于Hadoop 构建的一套数据仓库分析系统,它提供了丰富的SQL查询方式来分析存储在Hadoop 分布式文件系统中的数据,可以将结构 化的数据文件 ...

  9. 【SQL】Oracle的PL/SQL语法及其拓展数据类型总结

    PL/SQL语法 PL/SQL程序由三部分组成,声明部分.执行部分.异常处理部分. 模板: DECLARE /*变量声明*/ BEGIN /*程序主体*/ EXCEPTION /*异常处理部分*/ E ...

随机推荐

  1. C语言初学

    输出控制符 输出控制符 含义 %d int 整型数 %ld long int %c char 一个字符 %f float 浮点数,整数/整数=整数,整数/小数=小数 %lf double %x %X ...

  2. C语言中的条件编译

    通常情况,我们想让程序选择性地执行,多会使用分支语句,比如if-else 或者switch-case 等.但有些时候,可能在程序的运行过程中,某个分支根本不会执行. 比如我们要写一个跨平台项目,要求项 ...

  3. 开发小技巧1——Logger

    开发小技巧1——Logger 在项目中加入静态Logger类,用于捕获并记录程序的进度.错误信息:   public static class Logger { public static void ...

  4. MCS锁和CLH锁

    CLH锁:自旋锁,在上一个节点上等待,先上代码: public class CLHLock { /** * 保证原子性操作 * */ private AtomicReference<Node&g ...

  5. Android源码博客目录

    每次都找不到,干脆每个部分都开个目录,方便找 0. 杂项 一些Android的博客,没事翻翻 1. 构建相关 linux和Android的Makefile和android.mk android 目录下 ...

  6. Jquery 筛选选择器

    筛选选择器(方法) 既然是方法 那就应该对象调用   obj.metch(); $(“.dd”).children("ul"),show();           //找到.dd下 ...

  7. 谷歌眼镜能给Apple Watch带来啥前车之鉴?

    当下,你想不听到Apple Watch的消息都难.这款智能手表在三月初发布时,有关它的新闻报道铺天盖地.记者们在博客上对发布会的每个阶段进行了实况报道,苹果粉丝们通过博客. 推特和YouTube视频对 ...

  8. css3 transition(转换)笔记

    之前transition也用过,大都是ctrl+c,然后ctrl+v,没有了解太详细,这次对transition的应用源自侧边抽屉展开收起的动画效果需要. W3C标准中对css3的transition ...

  9. 招新系统(jsp+servlet,实现简略前端网页注册登录+后台增删改查,分学生和管理员,Java语言,mysql数据库连接,tomcat服务器)

    生活不只是眼前的苟且,还有诗和远方. 架构说明: 要求是采用MVC模式,所以分了下面的几个包,但是由于是第一次写,可能分的也不是很清楚: 这个是后台部分的架构: 这个是前端的的展示: (那个StuLo ...

  10. 922-按奇偶校验排序数组II

    给定一组A 非负整数,A中的一半整数是奇数,而整数的一半是偶数. 对数组进行排序,以便每当A[i]奇数时,i都是奇数; 无论何时A[i]均匀,i均匀. 您可以返回满足此条件的任何答案数组. 例1: 输 ...