Sql 注意点

本文介绍使用SQL中的SELECT语句替代SET命令的优势,包括一次赋值多个变量,以及如何实现特定排序。同时提供了一个错误案例说明正确使用方法,避免全表扫描带来的性能问题。

1. Set、Select赋值

使用SELECT语句来替代SET命令的主要优点是:可以在一个操作内同时给多个变量赋值。执行下面的SELECT语句,通过SELECT语句赋值的变量就可以用于任何操作了。
 
declare @num1 int, @num2 int,@result1 int,@result2 int
select @num1= 144,@num2 = 121
select @result1 = sqrt(@num1),@result2 = sqrt(@num2)
select @result1,@result2
 
用一个select 语句给多个变量赋值一般比用多个SET命令的效率要高。将一个甚至多个值选进参数的限制是,对变量的赋值不能和数据检索操作同时进行。这就是上面的例子使用SELECT语句来填充变量,而用另外一个SELECT语句来检索变量中数据的原因。例如,下面的脚本就不能工作:
 
declare @RestockName varchar(50)
select ProductId,@RestockName=Name+':'+ProductNumber FROMProduction.Product
 
 这个脚本会产生如下错误:消息141,级别15,状态1,第2 行
2.  特定排序的写法
--1. 将MessageType表数据以后面的id(59、107、62、18、66、65)排序
select
* from MessageType where class_id=31 order by charindex(ltrim(id),'59,107,62,18,66,65') --2. 将管理员、张三排最前面,其他按id排序
select * from tb_users order by case when username like '%管理员%' then 0 when username like '%张三%' then 1 else 2 end,id

3.  top 100 percent 用法

  select top 30 * from data where title='&title1&' order by id desc
  原意是选出符合“where 条件”的记录集里的“前30条”

  但是,对于该SQL语句,由于语句里同时存在where和top语句,并且where条件列不是合适的索引,程序执行的是全表扫描,首先是查找符 合where条件的记录, 而这里的top限制形同虚设。如果全表是百万级别以上的数据表,那么就这么一个简单的判断,就有可能拖垮数据库。

  所以需要先把符合“where条件”的记录,用一个子查询筛选出来,再在筛选结果集里选top30。

  因为SQL规则规定,如果子查询里,有order ...,就必须有TOP,所以就用SELECT TOP 100 PERCENT来限定,top 100 percent是为了保证筛选出所有符合条件的数据条目。否则,报错:消息 1033,级别 15,状态 1,第 5 行除非同时指定了 TOP,否则 ORDER BY 子句在视图、内嵌函数、派生表和子查询中无效。默认情况下,如果子查询,函数,视图中尝试去使用order by,如下则报该错误:

create view dbo.VUsers
as
    select id,username from tb_users order by id
go

因为,针对一个表的select其实并不是返回一个表,而是一个游标。解决办法:

select top 100 percent id,username from tb_users order by id,username desc

引用:http://www.cnblogs.com/ziyeyimeng/articles/2099188.html

转载于:https://www.cnblogs.com/SunXiaoLin/p/3434003.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值