Ø  T-SQL 编程是大多数程序员都会接触的,也是数据库编程必须掌握的技术。下面,是本人在工作或学习中积累的一些心得和技巧。主要包含以下内容:

1.   waitfor延时执行

2.   NOT 关键字的使用

3.   向变量赋值的 SELECT 语句,总是按照顺序赋值

4.   SET 与 SELECT 赋值的区别

5.   获取变量的数据类型

6.   一条 SQL 语句将一个字段的数据转为字符串

7.   根据起始和结束字符串,提取子字符串

8.   查询某数据库的所有存储过程中,是否包含指定的字符串

1.   waitfor延时执行,类似于定时器、休眠等

1)   延迟执行

WAITFOR DELAY 不在50~60之间

3.   向变量赋值的 SELECT 语句,总是按照顺序赋值

DECLARE

4.   SET 与 SELECT 赋值的区别

1)   SET 只能赋值一个变量,而 SELECT 可以赋值多个变量。

1.   SQL:

DECLARE @SetId int, @SelectId int, @SelectName varchar(20);

SET @SetId = (SELECT Id FROM (SELECT 1 AS Id, 'zhangsan' AS Name) AS T);

SELECT @SelectId = Id, @SelectName = Name FROM (SELECT 1 AS Id, 'zhangsan' AS Name) AS T;

SELECT @SetId AS SetId, @SelectId AS SelectId, @SelectName AS SelectName;

2.   结果:

2)   当返回多个值时,SET 不支持并且会报错;而 SELECT 不会,将赋值为最后一个值。

1.   SQL:

DECLARE @SetId int, @SelectId int, @SelectName varchar(20);

--SET @SetId = (SELECT Id FROM (SELECT 1 AS Id, 'zhangsan' AS Name UNION SELECT 2 AS Id, 'lisi' AS Name) AS T);

SELECT @SelectId = Id, @SelectName = Name FROM (SELECT 1 AS Id, 'zhangsan' AS Name UNION SELECT 2 AS Id, 'lisi' AS Name) AS T;

SELECT @SetId AS SetId, @SelectId AS SelectId, @SelectName AS SelectName;

2.   结果:

3)   没有记录返回时,SET 赋值为 NULL,而 SELECT 则保持原来的值。

1.   SQL:

DECLARE @SetId int = 10, @SelectId int = 10, @SelectName varchar(20) = 'original value';

SET @SetId = (SELECT Id FROM (SELECT 1 AS Id, 'zhangsan' AS Name) AS T WHERE 1 <> 1);

SELECT @SelectId = Id, @SelectName = Name FROM (SELECT 1 AS Id, 'zhangsan' AS Name) AS T WHERE 1 <> 1;

SELECT @SetId AS SetId, @SelectId AS SelectId, @SelectName AS SelectName;

2.   结果:

5.   获取变量的数据类型

SELECT Sql_Variant_Property(20, 'BaseType') AS Column1, Sql_Variant_Property(0.1, 'BaseType') AS Column2,Sql_Variant_Property(20 / 0.1, 'BaseType') AS Column3;

6.   SQL 语句将一个字段的数据转为字符串

DECLARE @Table1 TABLE(Name varchar(20));

INSERT INTO @Table1 VALUES('a'),('b'),('c'),('d'),('e');

DECLARE @Result varchar(max);

SELECT @Result = (SELECT CAST(Name AS varchar(20)) + ',' FROM @Table1 FOR XML PATH('')), @Result = SUBSTRING(@Result, 1, LEN(@Result) - 1);

SELECT @Result AS 字符串;

7.   根据起始和结束字符串,提取子字符串,代码如下:

1)   首先,创建一张临时表并写入数据

IF(OBJECT_ID('tempdb.dbo.#Table1', 'U') IS NOT NULL)

DROP TABLE #Table1;

CREATE TABLE #Table1(Id int, Value varchar(8000));

INSERT INTO #Table1 VALUES(1, '<id>1</id><name>爱变成</name><address>湖北</address>');

2)   检索位于起始字符与结束字符之间的字符串

DECLARE @start varchar(200) = '<name>', @end varchar(200) = '</name>';

SELECT SUBSTRING(Value, CHARINDEX(@start, Value) + LEN(@start), CHARINDEX(@end, Value) - (CHARINDEX(@start, Value) + LEN(@start))) AS Name, * FROM #Table1;

3)   执行结果

8.   查询某数据库的所有存储过程中,是否包含指定的字符串

--1. 申明变量

IF(OBJECT_ID('tempdb.dbo.#Temp_Proc', 'U') IS NOT NULL)

DROP TABLE #Temp_Proc;

GO

CREATE TABLE #Temp_Proc(ProcName varchar(100), SqlText text);

DECLARE @Temp1 TABLE(SqlText text);

DECLARE @ProcName varchar(100);

DECLARE cursor_proc CURSOR FOR SELECT name FROM sys.procedures;

--2. 使用游标遍历所有存储过程

OPEN cursor_proc;

FETCH NEXT FROM cursor_proc INTO @ProcName;

WHILE(@@FETCH_STATUS = 0)

BEGIN

--先写入表变量

DELETE @Temp1;  --注意:这里最好不要 DECLARE @Temp1 TABLE(SqlText text); 这样效率极低,原因不详!

INSERT INTO @Temp1 EXEC sp_helptext @ProcName;

--再写入临时表

INSERT INTO #Temp_Proc

SELECT @ProcName, SqlText FROM @Temp1;

FETCH NEXT FROM cursor_proc INTO @ProcName;

END

CLOSE cursor_proc;

DEALLOCATE cursor_proc;

--3. 查询临时表

DECLARE @PName varchar(100) = '', @PText varchar(200) = '%QueryText%';

SELECT * FROM #Temp_Proc WHERE 1=1

AND (LEN(@PName) = 0 OR ProcName = @PName)

AND SqlText LIKE @PText;

T-SQL 编程技巧的更多相关文章

  1. SQL 编程技巧

    Ø  简介 本文主要介绍编写 SQL 时的一些编程技巧,方便有时候忘了便于查看,主要包含以下内容: 1.   SQL 语句中使用 +=.-=.*=./= 运算符 2.   值为 NULL 的列或局部变 ...

  2. SQL Server 数据库编程技巧

    Ø  简介 本文主要介绍 SQL Server 数据库在平常的开发中,可能会涉及到的编程技巧,主要包含以下内容: 1.   解决 SQL Server 不支持 127.0.0.1 登录 2.   查询 ...

  3. SQL开发技巧(二)

    本系列文章旨在收集在开发过程中遇到的一些常用的SQL语句,然后整理归档,本系列文章基于SQLServer系列,且版本为SQLServer2005及以上-- 文章系列目录 SQL开发技巧(一) SQL开 ...

  4. EF – 2.EF数据查询基础(上)查询数据的实用编程技巧

    目录 5.4.1 查询符合条件的单条记录 EF使用SingleOrDefault()和Find()两个方法查询符合条件的单条记录. 5.4.2 Entity Framework中的内部数据缓存 DbS ...

  5. 自从学了SQL编程,哪里不会点哪里!!!

    在学习SQL编程前,先给大家分享几个段子吧,咱先乐呵乐呵! <桃花庵--程序员版> 写字楼里写字间,写字间中程序员:程序人员写程序,又将程序换酒钱: 酒醒只在屏前坐,酒醉还来屏下眠:酒醉酒 ...

  6. SQL开发技巧(二) 【转】感觉他写的很好

    本文转自: http://www.cnblogs.com/marvin/p/DevelopSQLSkill_2.html 本系列文章旨在收集在开发过程中遇到的一些常用的SQL语句,然后整理归档,本系列 ...

  7. EF – 2.EF数据查询基础(上)查询数据的实用编程技巧

    目录 5.4.1 查询符合条件的单条记录 EF使用SingleOrDefault()和Find()两个方法查询符合条件的单条记录. 5.4.2 Entity Framework中的内部数据缓存 DbS ...

  8. Delphi 与SQL编程

    Delphi 与SQL编程 SQL语言作为关系数据库管理系统中的一种通用的结构查询语言, 已经被众多的数据库管理系统所采用,如Oracle.Sybase.Informix等数据库管理系统,它们都支持S ...

  9. js异步编程技巧一

    异步回调是js的一大特性,理解好用好这个特性可以写出很高质量的代码.分享一些实际用的一些异步编程技巧. 1.我们有些应用环境是需要等待两个http请求或IO操作返回后进行后续逻辑的处理.而这种情况使用 ...

  10. sqL编程篇(三) 游标与存储过程

    sql编程2 游标与存储过程 sql编程中的游标的使用:提供的一种对查询的结果集进行逐行处理的一种方式不用游标的处理解决方式:逐行修改工资update salar set 工资=‘新工资’ where ...

随机推荐

  1. docker-compose.yml(4)

    实例3:version: '3'services: mysql: image: mysql network_mode: "host" environment: - MYSQL_RO ...

  2. jmeter4.0测试dubbo接口遇到的问题:An error occurred: org.springframework.scheduling.quartz.CronTriggerBean has interface org.quartz.CronTrigger as super class

    半年前,用jmeter4.0测试dubbo接口的时候,遇到这样一个问题 An error occurred: org.springframework.scheduling.quartz.CronTri ...

  3. bzoj4337树的同构

    树是一种很常见的数据结构. 我们把N个点,N-1条边的连通无向图称为树. 若将某个点作为根,从根开始遍历,则其它的点都有一个前驱,这个树就成为有根树. 对于两个树T1和T2,如果能够把树T1的所有点重 ...

  4. BZOJ2801/洛谷P3544 [POI2012]BEZ-Minimalist Security(题目性质发掘+图的遍历+解不等式组)

    题面戳这 化下题面给的式子: \(z_u+z_v=p_u+p_v-b_{u,v}\) 发现\(p_u+p_v-b_{u,v}\)是确定的,所以只要确定了一个点\(i\)的权值\(x_i\),和它在同一 ...

  5. 利用LVS+Keepalived搭建Mysql双主复制高可用负载均衡环境

    应用背景: MySQL复制(主主,主从...)能在保证数据的备份的同时也能够做读写分离分摊系统压力,但是发生单点故障时,需要手动 切换到另外一台主机.LVS和Keppalived可以设定一个VIP来实 ...

  6. hdu3038How Many Answers Are Wrong(带权并查集)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3038 题解转载自:https://www.cnblogs.com/liyinggang/p/53270 ...

  7. 如何在jsp中引入bootstrap

    如何在jsp中引入bootstrap包: 1.首先在http://getbootstrap.com/上下载Bootstrap的最新版. 您会看到两个按钮: Download Bootstrap:下载 ...

  8. 用lemon测交互题

    题目类型:传统. 答案比较类型:逐行比较类型(忽略多余空格和制表符). 配置:交互. 编译器参数: -o %s %s.* ..\..\data\%s\judge.cpp -Wl,--stack= ju ...

  9. IE jQuery ajax 请求缓存问题

    我最近在IE下测试开发我们的系统,经常出现改过的jsp页面,刷新IE后也不能显示,这就是IE的缓存问题,查了一下百度,说是IE9在ajax进行请求时,如果两次请求url相同,则不会请求服务器,而是从缓 ...

  10. tensorflow中tf.ConfigProto()用法解释

    在看C3D代码的时候,看见有一段代码是 config = tf.ConfigProto()#主要是配置tf.Session的运行方式,GPU还是CPU,在这里选择的是GPU的运行方式 config.g ...