大量数据查询时的效率问题!
表1: T1
num(int) c1(nvarchar) c2(nvarchar)
1 数据1 数据2
2 数据3 数据4
其中num在T1中是主键
表2: T2
num(int) cc(nvarchar) vv(nvarchar)
1 数据5 数据6
1 数据7 数据8
2 数据9 数据10
2 数据11 数据12
在对于两个表做如下查询的时候
查询1:
select * from T1
where (c1 like '%查找%') or (c2 like '%查找%')
or num in (select num from T2 where vv like '%查找%')
查询2:
select * from T1 where (c1 like '%查找%') or (c2 like '%查找%')
select * from T1
where num in (select num from T2 where vv like '%查找%')
查询1:直接生成的DataTable
查询2:生成的两个DataTable经过合并去掉重复的记录生成的DataTable,那个效率高一点
大部分的朋友认为查询1比较快,但是在100万条数据的查询时在查询分析器中需要6秒,存储过程中要3秒,要是可以的话能不能有改进的方法使查询速度再提高一点!
还有一点很奇怪,同样的数据库我在查询分析器中分别执行查询2的两个语句时都是用了1秒。这是为什么?难道查询2的效率反而高吗?