MyException - 我的异常网
当前位置:我的异常网» Sql Server » 这两条SQL语句如何合并成一条提高效率

这两条SQL语句如何合并成一条提高效率

www.MyException.Cn  网友分享于:2013-04-07  浏览:39次
这两条SQL语句怎么合并成一条提高效率
我现在是这么实现的
===================================================
数据表分别有   公司表zs_khinfo   跟踪记录表zs_gzrec
zs_khinfo主要字段:id为主键,cname为公司名称,levels为公司类型
zs_gzrec主要字段:
nexttimegj   作用就是跟踪时间   类型:smalldatetime
fid   作用就是记录公司id   类型:int   可重复
addtime   作用就是记录添加时间   类型:smalldatetime
===================================================
先用一条SQL语句
------------------------
"select   a.id,a.cname   from   zs_khinfo   a,zs_gzrec   b   where   datediff(day,b.nexttimegj,getdate())=0   and   a.id=b.fid   and   a.levels <> 'O '   order   by   b.addtime   desc "
------------------------
------------------------
读出所有符合条件的公司表里的字段并要符合跟踪表里的跟踪时间有今天
"datediff(day,nexttimegj,getdate())=0 "   并按b.addtime来顺序

然后通过程序循环中
单独读出跟踪表的字段,按时间顺序,只读一条
------------------------
"select   visitrec,nexttimegj   from   [zs_gzrec]   where   fid= "&Rs(0)& "   order   by   addtime   desc "
------------------------
------------------------
这里的RS(0)就是上面对应公司表的ID
一个公司一般在跟踪表里有N个fid,我在这里用order   by   addtime   desc只取了最新的一条,并不一定就是跟踪时间为今天的那一条,这里排序的关键就是addtime,跟踪时间只是用来判定是否显示该公司信息的重要依据,就是该公司必须有一条符合 "datediff(day,nexttimegj,getdate())=0 ",真正显示出来的并非一定是这条信息,是这个公司的最新添加的信息.
***********************************************************************
这样写程序才正确,但是效率很低,打开要20多秒,可以参考这两个语句来综合一下
我也曾经综合过多次,语句如下,但是有问题:
select   c.id,c.cname,d.visitrec,d.nexttimegj,d.addtime  
from   zs_khinfo   c,zs_gzrec   d  
where   datediff(day,d.nexttimegj,getdate())=0   and   c.levels <> 'O '   and   c.id=d.fid
order   by   d.addtime   desc
得到的是符合datediff(day,d.nexttimegj,getdate())=0的那一条记录,而不是该条信息fid所对应公司的最新跟踪记录!
-------------------------------------------
请高手帮忙看一下!!

------解决方案--------------------
--把@t1 改成 zs_khinfo
--@t2 改成 zs_gzrec
select c.id,c.cname,c.levels,d.visitrec,d.nexttimegj,d.addtime
from zs_khinfo c
join zs_gzrec d on c.id=d.fid and c.levels=1
join (select fid ,max(addtime) addtime from zs_gzrec group by fid) e on c.id=e.fid and d.addtime=e.addtime
join (select distinct fid from zs_gzrec where datediff(day,nexttimegj,getdate())=0) f on c.id=f.fid order by c.id

文章评论

10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
为什么程序员都是夜猫子
为什么程序员都是夜猫子
10个调试和排错的小建议
10个调试和排错的小建议
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
代码女神横空出世
代码女神横空出世
程序员必看的十大电影
程序员必看的十大电影
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
中美印日四国程序员比较
中美印日四国程序员比较
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
程序员和编码员之间的区别
程序员和编码员之间的区别
漫画:程序员的工作
漫画:程序员的工作
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
 程序员的样子
程序员的样子
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
一个程序员的时间管理
一个程序员的时间管理
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
我是如何打败拖延症的
我是如何打败拖延症的
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
老程序员的下场
老程序员的下场
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
总结2014中国互联网十大段子
总结2014中国互联网十大段子
程序员都该阅读的书
程序员都该阅读的书
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
旅行,写作,编程
旅行,写作,编程
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
我的丈夫是个程序员
我的丈夫是个程序员
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
每天工作4小时的程序员
每天工作4小时的程序员
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
Java程序员必看电影
Java程序员必看电影
那些争议最大的编程观点
那些争议最大的编程观点
程序员应该关注的一些事儿
程序员应该关注的一些事儿
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有