数据库提高查询效率

kang_zhi_xiong13456 2010-05-26 11:48:40

ALTER PROCEDURE FindeAllOrderCompanyNO
@companyNO varchar(50),
@supplierNO varchar(50),
@settlement int,
@endDateTime datetime,
@sign bit,
@ticketingTime datetime
AS

declare @sql varchar(max)
SET NOCOUNT ON;
set @sql =' select * from vw_tickDetail_tickorders_tickAirLines where CompanyNO in (select CompanyNO from TicketOrders GROUP by CompanyNO) and GetTicketTime<'''+cast(@endDateTime as varchar(20))+''' and GetTicketTime>='''+cast(@ticketingTime as varchar(20))+''' and GetTicketSign='''+cast(@sign as varchar(20))+''' '
if @companyNO is not null and @companyNO!=''
set @sql +=' and CompanyNO ='''+@companyNO+''''
if @supplierNO is not null and @supplierNO!=''
set @sql +=' and tickDetailSupplierNO='''+@supplierNO+''''
if @settlement !='' and @settlement >-1
set @sql +=' and SettlementStatus='+@settlement+''

print @sql
exec (@sql)
RETURN

各位大侠,,怎么修改才能使这个存储过程 提高查询效率
...全文
82 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
huangmin3956 2010-05-26
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 foren_whb 的回复:]
这个已经很高效了,
再要提高就只好对表添加索引了
或者用视图也可以
[/Quote]
LZ还想咋样
winner2050 2010-05-26
  • 打赏
  • 举报
回复
CompanyNO in (select CompanyNO from TicketOrders GROUP by CompanyNO)
================================
所有关联的表的 CompanyNO 字段都要建立索引。
select CompanyNO from TicketOrders GROUP by CompanyNO 单独出来
把结果拼接字符串
改为CompanyNO in (拼接的字符串) 这样就能利用到索引,性能提升数十倍。

where 、Group by 、order by 的字段都要建立索引,一般由后往前,具体自己把握。
fanlose2 2010-05-26
  • 打赏
  • 举报
回复
每天回帖即可获得10分可用分! 很饿,占位---,回来分析。
mzjmicrosoft 2010-05-26
  • 打赏
  • 举报
回复
视图不好

只要表结构没问题

这个就行吧
丰云 2010-05-26
  • 打赏
  • 举报
回复
这个已经很高效了,
再要提高就只好对表添加索引了
或者用视图也可以
  • 打赏
  • 举报
回复
怎么没人回答吗
  • 打赏
  • 举报
回复
怎么没人回答吗

62,025

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧