易截截图软件、单文件、免安装、纯绿色、仅160KB

请教一个SQL查询的写法 - MS-SQL Server / 基础类

类似下面的代码执行时间非常长,请问要怎样写才是正确的写法?


select * from a where a.字段1+a.字段2 not in (select b.字段1+b.字段2 from b) 

(实际上的应用情况是更多字段,更多的子查询,但症结就是慢在多字段的IN上面,其余的都非常快,唯一是用到
a.字段1+a.字段2 not in 的句时,就极慢!

向各位高手求助!



换not exists 试试


引用
SQL code
select * from a inner join b
on a.字段1+a.字段2 =b.字段1+b.字段2
where b.字段1 is null

这种写法看不懂?能这样写?

引用
换not exists 试试


字段个数并不是一样的,请问如何写。

SQL code:
select * from a inner join b
on checksum(a.字段1,....)=checksum(b.字段1,....)
where b.字段1 is null


引用

引用 2 楼 chuifengde 的回复:
SQL code
select * from a inner join b
on a.字段1+a.字段2 =b.字段1+b.字段2
where b.字段1 is null

这种写法看不懂?能这样写?


2楼和5楼都误把LEFT JOIN写成了INNER JOIN。

引用
SQL code
select * from a inner join b
on checksum(a.字段1,....)=checksum(b.字段1,....)
where b.字段1 is null


什么代码啊,这样写怎么行?
{{----


相关问答:

sql小小的疑问 - .NET技术 / C#

可能因为工作的原因 接触数据库这块比较少,之前都是做程序这块,数据库这块都有专门的人来做 分工都很明细 所以对数据库这一块完全不了解。前段时间 去面试了几家公司 几乎都是在数据库这块挂掉的 连个简单的SQ ......

请教SQL语句查询问题? - MS-SQL Server / 基础类

我想查询出每天数据的最大的一个值。表的格式如下
表名: hisdata
字段 编号 值 状态 时间  
  Id value state dattime  
  101 32.3 0 ......

SQL语句问题 - MS-SQL Server / 疑难问题

请教高手:
 以下是数据库中的三条记录,英文为字段名称  
  id planname TaskBeginTime Status
329 2010年03 ......

关于SQL语句OR的问题 - Oracle / 高级技术

通过NAME字段条件查询一个数据表,假设我有100个姓名,有以下两个方法,
方法1:
把100个Name 组成一个SQL语句,比如 Select * from tmp_table where Name='张三' or Name ='李四' Or ...Or Name='第一百个姓名'
......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号