SQL In的替换
前2天在搞SQL的的时候,发现其中有很多in的操作,诸如:id in(1,2,3)或id in(select id from table……),这个对SQL来说并不是最好的选择,执行效率是偏低的[它执行的是全表遍历],同事问那用什么来替代In Or Not In呢?其实方法还是有的,比方用EXISTS替代IN、用NOT EXISTS替代NOT IN。在这里我另外一种方式来实现替代In.下面先来看下测试的数据结构
id stuid stuname birthdat areaorganid
1 4538 张文 1977-06-30 00:00:00.000 36
2 4538 张文 1977-06-30 00:00:00.000 36
3 5324 王清超 1971-10-13 00:00:00.000 36
4 5324 王清超 1971-10-13 00:00:00.000 36
5 5969 卫石林 1982-03-25 00:00:00.000 36
6 5969 卫石林 1982-03-25 00:00:00.000 36
7 5865 林雪健 1981-06-25 00:00:00.000 36
1 4538 张文 1977-06-30 00:00:00.000 36
2 4538 张文 1977-06-30 00:00:00.000 36
3 5324 王清超 1971-10-13 00:00:00.000 36
4 5324 王清超 1971-10-13 00:00:00.000 36
5 5969 卫石林 1982-03-25 00:00:00.000 36
6 5969 卫石林 1982-03-25 00:00:00.000 36
7 5865 林雪健 1981-06-25 00:00:00.000 36
SELECT * FROM dbo.AAAA WHERE id IN(SELECT id FROM dbo.AAAA WHERE stuname='张文')
上面的SQL是我们最常见到的查询方式,咋一看没什么问题,可实际上当数据量偏大的时候响应时间是比较久的,而且会使索引无法发挥作用。那怎么来改造一下呢?我们直接来看代码:
SET STATISTICS PROFILE ON
SELECT * FROM (SELECT id FROM dbo.AAAA WHERE stuname='张文')a INNER JOIN
AAAA b ON a.id=b.id
是不是很眼熟呢,这种形式的查询也是我们最常见到的,换这种方式后查询的执行效率会得到恨到的提升,不信大家可以自己动手试一试。
可以有的童鞋会问了,那id in(1,2,3)这种形式的怎么来弄啊,没有办法像上面一样来操作啊,别急,我给出我比较常用的方式。当然还有别的方式,欢迎大家补充。
一般in(1,2,3)这样的形式多半是拼接而来的SQL,字符串嘛,我们转换一下,我个人习惯的是用CTE来搞定,不熟悉CTE的百度哈,很多。下面上具体的代码:
;WITH mycte AS
(
SELECT col=1 UNION ALL
SELECT 2 UNION ALL
SELECT 3
)
SELECT * FROM dbo.AAAA a,mycte b WHERE a.id=b.col
小技巧,直接将in括号里面的【,】替换成UNION ALL SELECT即可,是不是很方便。
SQL In的替换的更多相关文章
- SQL*Plus中替换变量与定义变量
替换变量 SQL*Plus中的替换变量又叫替代变量,它一般用来临时存储相关数据:在SQL语句之间传递值.一般使用&或&&前缀来指定替换变量. 关于使用替换变量,一般是利用其创建 ...
- sql数据库批量替换dedecms内容关键字
之前写了一篇dedecms后台批量替换文章中的关键词,这边我们介绍一下用sql数据库批量替换dedecms内容关键字,当然要求你对数据库比较熟悉,修改前请自行做好备份. 1.更改文章中的内容 upda ...
- sql server 字符串替换函数REPLACE
sql server 字符串替换函数REPLACE函数的使用 <pre name="code" class="sql">--参数1:需要替换字符的母 ...
- 使用SQL命令批量替换WordPress站点中图片的URL链接地址
本文由荒原之梦原创,原文链接:http://zhaokaifeng.com/?p=689 前言: 本文记录了使用SQL命令批量替换URL的方法以及除了替换URL之外,网站更换图片URL地址所必须的其他 ...
- SQL 批量字符串替换
--在SQL SERVER中批量替换字符串的方法 update table[表名] set Fields[字段名]=replace(Fields[字段名],'被替换原内容','要替换成的内容') up ...
- [转]在SQL中用正则表达式替换html标签
本文转自:http://blog.csdn.net/dhttaso/article/details/6045380 由于数据库的一个表字段中多包含html标签,现在需要修改数据库的字段把html标签都 ...
- 在SQL中用正则表达式替换html标签
由于数据库的一个表字段中多包含html标签,现在需要修改数据库的字段把html标签都替换掉.当然我可以通过写一个程序去修改,那毕竟有点麻烦.直接在查询分析器中执行,但是MS SQL Server并没有 ...
- 在SQL 语句批量替换数据库字符串的方法
update table[表名] set Fields[字段名]=replace(Fields[字段名],'被替换原内容','要替换成的内容')update ProgInfo set JoinTime ...
- 在SQL中用正则表达式替换html标签(2)
由于数据库的一个表字段中多包含html标签,现在需要修改数据库的字段把html标签都替换掉.当然我可以通过写一个程序去修改,那毕竟有点麻烦.直接在查询分析器中执行,但是MS SQL Server并没有 ...
随机推荐
- 一个用UpdateLayeredWindow实现窗体半透明的delphi的代码
http://www.pudn.com/downloads171/sourcecode/windows/detail791686.html unit Unit1; interface uses ...
- POJ-3204-Ikki's Story I - Road Reconstruction(最大流)
题意: 给一个有向图 求给那些边增加容量能增加总的流量,求边的条数 分析: 一开始求的是割边,结果wa了,那是因为有些割边增加了容量,但总的容量也不会增加 只有满流的边并且从源点汇点都有一条可扩展的路 ...
- spj题
S(SNO,SNAME,SCITY) ,P(PNO,PNAME,COLOR,WEIGHT) ,J(JNO,JNAME,JCITY),其中S表示供应商,它的各属性依次为供应商号,供应商名,供应商所在城市 ...
- Vagrant 集群的部署
使用Vagrant部署集群 一.运行多个虚拟机 我们通过配置Vagrantfile配置两个虚拟机--web服务器和数据库服务器. Vagrant::configure("2") d ...
- LeetCode (85): Maximal Rectangle [含84题分析]
链接: https://leetcode.com/problems/maximal-rectangle/ [描述] Given a 2D binary matrix filled with '0's ...
- LA 3263 欧拉定理
题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_ ...
- 在javaweb中通过servlet类和普通类读取资源文件
javaweb有两种方式读取资源文件 在Servlet中读取,可以使用servletContext,servletContext可以拿到web所有的资源文件,然后随便读,但是这种方法不常用,尽量少在S ...
- STRUCTS 2 LABLE
{LJ?Dragon}[标题]structs2标签的作用 {LJ?Dragon}[Diary]2017年,愉快的开始:离别不一定总伤感,虽然只是安慰着自己......... 问与答 问题 在Strut ...
- 缓存的概念(反向代理、CDN)
缓存在我们的日常开发中随处可见,理解缓存的概念,本质就是就近处理,比如很多热点数据,访问量很多,我们需要使用,就可以把它 缓存起来,然后下次访问就不用再去数据库的去查询了,而是直接使用缓存,现在说说大 ...
- 程序启动原理和UIApplication
iOS开发UI篇—程序启动原理和UIApplication 一.UIApplication 1.简单介绍 (1)UIApplication对象是应用程序的象征,一个UIApplication对象就 ...