SQL Server 2005 某个表中,其中一列存储的值比较多, 第一次查询很慢,怎么解决?
数据库版本:SQLServer2005表结构:CREATETABLE[dbo].[Core_Flow_Approve_InstanceFlow]([Instance_ID...
数据库版本: SQL Server 2005
表结构:
CREATE TABLE [dbo].[Core_Flow_Approve_InstanceFlow]
(
[Instance_ID] [varchar] (32) COLLATE Chinese_PRC_CI_AS NOT NULL, --主键
[Tem_Detail] [varchar] (max) COLLATE Chinese_PRC_CI_AS NOT NULL,
[NodesAttrib] [varchar] (max) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
其中,基于程序设计的原因,Tem_Detail 列字段存储的值很大,存储的为字符信息40KB以上,
现在要执行查询语句
SELECT Tem_Detail
FROM Core_Flow_Approve_InstanceFlow
WHERE Instance_ID = '9117a14fc56546e1bcf104b55efa67a7'
AND Tem_Detail != ''
第一次执行的时候,非常慢,要等4-5分钟,由于相应时间太久,导致程序直接报错。
由于项目原因,无法快速修改Tem_Detail存储的值,请问如何提高第一次查询的速度?
怎么去优化数据库,提高效率? 展开
表结构:
CREATE TABLE [dbo].[Core_Flow_Approve_InstanceFlow]
(
[Instance_ID] [varchar] (32) COLLATE Chinese_PRC_CI_AS NOT NULL, --主键
[Tem_Detail] [varchar] (max) COLLATE Chinese_PRC_CI_AS NOT NULL,
[NodesAttrib] [varchar] (max) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]
其中,基于程序设计的原因,Tem_Detail 列字段存储的值很大,存储的为字符信息40KB以上,
现在要执行查询语句
SELECT Tem_Detail
FROM Core_Flow_Approve_InstanceFlow
WHERE Instance_ID = '9117a14fc56546e1bcf104b55efa67a7'
AND Tem_Detail != ''
第一次执行的时候,非常慢,要等4-5分钟,由于相应时间太久,导致程序直接报错。
由于项目原因,无法快速修改Tem_Detail存储的值,请问如何提高第一次查询的速度?
怎么去优化数据库,提高效率? 展开
4个回答
展开全部
查询语句可以优化一下
SELECT Tem_Detail
FROM Core_Flow_Approve_InstanceFlow
WHERE Tem_Detail != '' AND Instance_ID = '9117a14fc56546e1bcf104b55efa67a7'
SQL语句过滤条件是从右到左的,
有两个条件如果有一千条数据,第一条件要比较1000次(索引除外)。
第一条件滤过了900,第二条件比较就只比较100:总比较次数就是1100.
如果第一条件过滤100,第二条件比较900次,总次数就是1900了!
SELECT Tem_Detail
FROM Core_Flow_Approve_InstanceFlow
WHERE Tem_Detail != '' AND Instance_ID = '9117a14fc56546e1bcf104b55efa67a7'
SQL语句过滤条件是从右到左的,
有两个条件如果有一千条数据,第一条件要比较1000次(索引除外)。
第一条件滤过了900,第二条件比较就只比较100:总比较次数就是1100.
如果第一条件过滤100,第二条件比较900次,总次数就是1900了!
展开全部
第一次查询很慢
可以考虑用sql server 代理
里的作业,每天让系统定时执行一次
可以考虑用sql server 代理
里的作业,每天让系统定时执行一次
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
没辙...用存储过程行不
追问
查询的时候,用的就是存储过程
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2011-12-23
展开全部
把大的字段可以放在mongdoDB中,或者放在磁盘上,保存在文件里
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询