视图查询慢,如何优化

花样小星 2011-10-19 10:22:50
以下语句是我建立的一个视图,其中关联了4个表的数据。distinct后是18000多行数据。但是查询出来需要10以上的时间
请问我可以用什么办法来加快查询速度?

貌似这种视图不能建立索引。报错:无法对视图 'v_detail' 创建 索引。它没有唯一聚集索引。

因为视图是为了方便多个表联表查询是而设的,所以视图也是多个表中的字段由各个表中的关联关系二创建的一种虚拟表。
它不存在与实际的数据库存储空间中。因此不能创建索引

SELECT DISTINCT
A.invname, A.invpinpai, A.invspec, REPLACE(A.invtype, ',', ' ') AS invtype, B.measname, A.pk_invcl, A.pk_corp, A.pk_invbasdoc, F.fullname,
E.cbuyer
FROM dbo.nw_inv AS A INNER JOIN
dbo.v_nw_measdoc AS B ON A.pk_measdoc = B.pk_measdoc INNER JOIN
dbo.v_nw_ic_onhandnum AS C ON C.cinvbasid = A.pk_invbasdoc AND C.pk_corp = A.pk_corp INNER JOIN
dbo.v_nw_stordoc AS D ON D.pk_stordoc = C.cwarehouseid AND C.pk_corp = D.pk_corp LEFT OUTER JOIN
dbo.v_nw_inv_position AS E ON E.pk_invbasdoc = A.pk_invbasdoc LEFT OUTER JOIN
dbo.sys_user AS F ON F.Nc_UserID = E.cemployeeid
...全文
570 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
fanzhouqi 2011-10-19
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 me_meihuo 的回复:]

引用 2 楼 fredrickhu 的回复:
可以建立唯一聚集索引。

加完索引数据查询会变快吗?还有别的方法吗?
[/Quote]在视图上面建索引 正规一点。
其他方法也有,需要改数据库结构,对于一个已经是生产环境的系统来说事不可能的事情
花样小星 2011-10-19
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 fredrickhu 的回复:]
可以建立唯一聚集索引。
[/Quote]
加完索引数据查询会变快吗?还有别的方法吗?
--小F-- 2011-10-19
  • 打赏
  • 举报
回复
可以建立唯一聚集索引。
--小F-- 2011-10-19
  • 打赏
  • 举报
回复
---索引视图

索引视图是具体化的视图

--创建索引视图
create view 视图名 with schemabinding
as
select 语句
go

---创建索引视图需要注意的几点
1. 创建索引视图的时候需要指定表所属的架构
--错误写法
create view v_f with schemabinding
as
select
a.a,a.b,b.a,b.b
from
a join b
on
a.id=b.id
go

---正确写法:
create view v_f with schemabinding
as
select
a.a,a.b,b.a,b.b
from
dbo.a join dbo.b
on
a.id=b.id
go


2.在创建索引视图的select语句时,不使用*,必须指定具体的列名
--错误写法
create view v_f with schemabinding
as
select
*
from
dbo.a join dbo.b
on
a.id=b.id
go

---正确写法
create view v_f with schemabinding
as
select
a.a,a.b,b.a,b.b
from
dbo.a join dbo.b
on
a.id=b.id
go

3.在创建索引视图的select 语句中,不能存在重复的列名,这个不举例了

4. 只能为索引视图创建唯一聚集索引
--正确的写法
create unique clustered index ix_uniquetb on v_tb
go

--错误的写法
create clustered index ix_uniquetb on v_tb
go

34,591

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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