sql 中set和select区别

基于SQL中SET与SELECT赋值的区别详解

2012年09月06日 ? 综合 ? 共 912字 ? 字号    ? 评论关闭

最近的项目写的SQL比较多,经常会用到对变量赋值,而我使用SET和SELECT都会达到效果。
那就有些迷惑,这两者有什么区别呢?什么时候哪该哪个呢?
经过网上的查询,及个人练习,总结两者有以下几点主要区别:
假定有设定变量:

复制代码 代码如下:

DECLARE @VAR1 VARCHAR(1) 
DECLARE @VAR2 VARCHAR(2)

1、SELECT可以在一条语句里对多个变量同时赋值,而SET只能一次对一个变量赋值,如下:

复制代码 代码如下:

SELECT @VAR1=‘Y‘,@VAR2=‘N‘
-- 而SET要达到同样的效果,需要:
SET @VAR1=‘Y‘
SET @VAR2=‘N‘
/*
说到这个,SQL内置的变量:@@ERROR 和 @@ROWCOUNT必须要在一句SQL语句中捕获。如果用set分两句来获取它们,将获取不完整,这时就应该用select来获取值。
*/

2、表达式返回多个值时,用SET将会出错,而SELECT将取最后一个值,如下:

复制代码 代码如下:

----以下假定Permission表有多个IsRight记录 
SELECT @VAR1 = IsRight FROM Permission --将取最后一个值

SET @VAR1 = IsRight FROM Permission --将报错

3、表达式无返回值时,用SET将置变量值为NULL,用SELECT交保持变量值,如下:

复制代码 代码如下:

----以下假定Permission记录为空 
SET @VAR1 = ‘初始值‘

SELECT @VAR1 = IsRight FROM Permission --此时@VAR1为‘初始值‘

SET @VAR1 = (SELECT IsRight FROM Permission) --此时@VAR1为NULL

4、使用标量子查询时,如果无返回值,SET和SELECT一样,都将置为NULL,如下:

复制代码 代码如下:

----以下假定Permission记录为空 
SET @VAR1 = ‘初始值‘

SELECT @VAR1 =(SELECT IsRight FROM Permission ) --此时@VAR1为NULL

SET @VAR1 = ( SELECT IsRight FROM Permission) --此时@VAR1为NULL

时间: 2024-11-25 06:30:02

sql 中set和select区别的相关文章

sql 中convert和cast区别

SQL中的cast和convert的用法和区别 更多 2014/1/13 来源:SQL学习浏览量:14125 学习标签: cast convert sql 本文导读:SQL中的cast 和convert都是用来将一种数据类型的表达式转换为另一种数据类型的表达式.CAST 和 CONVERT 提供相似的功能,只是语法不同.在时间转化中一般用到convert,因为它比cast多加了一个style,可以转化成不同时间的格式. 一.语法: 1.使用 CAST CAST ( expression AS d

SQL中空值与NULL区别

很多人都有过这样的问题吧   在SQL中填充空值与NULL有什么区别 现在我以一个实例给大家分享一下自己的想法  恳请大家给予批评也指正 谢谢 创建一个监时表 CREATE TABLE #temp ( name VARCHAR(50) ) 填充三条资料 如下: INSERT INTO #tempVALUES ( NULL )INSERT INTO #tempVALUES ( 'Tom' )INSERT INTO #tempVALUES ( '' ) 使用如下语法查询 SELECT COUNT(n

SQL中JOIN和UNION区别及用法

转载:http://chengheng1984.blog.163.com/blog/static/17947412201012215738844/ JOIN用于按照ON条件联接两个表,主要有四种: INNER JOIN:内部联接两个表中的记录,仅当至少有一个同属于两表的行符合联接条件时,内联接才返回行.我理解的是只要记录不符合ON条件,就不会显示在结果集内. LEFT JOIN / LEFT OUTER JOIN:外部联接两个表中的记录,并包含左表中的全部记录.如果左表的某记录在右表中没有匹配记

SQL中Len与DataLength区别

SQL中求字符串长度问题 一.LEN(Param) 求字符串的长度 DataLength(param) 求字符串所占的字节长度 二.LEN不返回文本之后的空格长度 而DataLenth则不同 三.针对NText.text.image这样的数据类型 求长度DataLenth非常有用. 因为:1.这些数据类型对应的内容是可变的 .DataLength计算所占内存的字节数 2.以上三种数据类型Len是无法计算的. 以上内容仅供学习使用,若有不同意见 ,及时指出,一起学习

mybatis中为sql中传值#{}和${}的区别

在mybatis中,配置文件中sql的值,用#{}表示,例如: <select id="getTeacher" resultType="Teacher"> SELECT t_id id, t_name name FROM teacher WHERE t_id=#{id} </select> #{id}最终发送的sql为:select t_id id,t_name name from teacher where t_id=1 如果传入的是字符串

英文操作系统中中文乱码(SQL中 NVARCHAR 和 VARCHAR区别)

  varchar在SQL Server中是采用单字节来存储数据的,nvarchar是使用Unico来存储数据的.中文字符存储到SQL Server中会保存为两个字节(一般采用Unico编码),英文字符保存到数据库中,如果字段的类型为varchar,则只会占用一个字节,而如果字段 的类型为nvarchar,则会占用两个字节. 正常情况下,我们使用varchar也可以存储中文字符,但是如果遇到操作系统是英文操 作系统并且对中文字体的支持不全面时, 在SQL Server存储中文字符为varchar

Mybatis中Mapper.xml文件sql中动态获取----&gt;#{}和${}区别

1. #{} 获取参数的内容,支持索引获取,param1获取指定位置参数,并且sql使用?占位符 2. ${} 纯字符串拼接,不使用?,默认找${内容}内容的get/set方法,如果写数字,就是一个数字 原文地址:https://www.cnblogs.com/yikuan-919/p/9691702.html

pl/sql中return和exit区别

经测试: 1.exit只能用于循环中,并且退出循环往下执行: 2.return可用于循环或非循环,并且退出整个程序模块不往下执行. declare i number :=1; j number :=1; begin loop if i>3 then exit; --return; end if; j:=1; begin loop if j>2 then exit; --return; end if; dbms_output.put_line('i=' || i || ',j=' || j);

SQL中INEXISTS和IN 的区别和联系

SET NOCOUNT ON , SET NOCOUNT OFF当 SET NOCOUNT 为 ON 时,不返回计数(表示受 Transact-SQL 语句影响的行数).当 SET NOCOUNT 为 OFF 时,返回计数.如果存储过程中包含的一些语句并不返回许多实际的数据, 则该设置由于大量减少了网络流量,因此可显著提高性能. SQL 中 IN 和 EXISTS 用法的区别: NOT IN SELECT DISTINCT MD001 FROM BOMMD WHERE MD001 NOT IN