sqlserver存储过程优化
这个方法我一般不告诉别人,这是微软最新的BUG,当你代码全部都打好以后,先全选,然后删除所有代码(这之前不能复制,复制了就不起作用了),然后按ctrl+z撤销操作,这个时候你的代码还是在你的窗口里;然后现在关闭SSMS,这时SSMS会提示你要不要保存,选择不保存,然后完全关闭SSMS再重新打开你的SSMS,这个时候再按一次撤销,SQLSERVER会自动对齐你刚刚敲的代码。
这个方法尤其是在你懒得对齐自己代码的时候非常有效,不管你敲了多久的代码,都可以自动缩进得非常漂亮,但是如果是乱打的字就没办法了,它会认为那是字符串,不会有任何改变。
Ⅱ SqlServer存储过程
create
procere
prCreateSubPlan
as
begin
declare
@id
int,
@intCycle
int,
@planName
varchar(100),
@createTime
smalldatetime,
@cycleTime
int
select
@id
=
min(t_cplan_id)
from
t_cplan
while
(@id
is
not
null)
begin
select
@planName=t_plan_name,
@createTime
=
createTime,
@cycleTime
=
cycleTime
from
t_cplan
where
t_cplan_id=@id
select
@intCycle=
0
while
(@intCycle<@cycleTime)
begin
--
表t_plan
列t_plan_id是IDENTITY
列
insert
t_plan
(t_plan_name,
t_cplan_id,
createTime)
values
(@planName,
@id,
dateadd(day,
@intCycle,
@createTime))
select
@intCycle
=
@intCycle
+
1
end
select
@id
=
min(t_cplan_id)
from
t_cplan
where
t_cplan_id>@id
end
end
go
Ⅲ sqlserver的存储过程 求高手优化,
首先,goto+if 的组合其实实现的就是while的用法,可以去掉goto语句把Beg:if改成while即可
然后你写了两组关于max与min的查询赋值,我看了下,结构完全一致,完全可以合并为一组
Ⅳ SqlServer中构建存储过程进行复杂业务处理时,需要从哪些方面进行优化,提高效率
所有有联结的所有表有具有索引
尽量减少存储过程参数
简化条件表达式与逻辑判断
与存储过程里的局部变量
我个人比较喜欢从维护做为出发点,尤其你要搞复杂业务处理
实在性能客户受不了才会去优化性能
个人意见,别丢鸡蛋
Ⅳ 优化级联删除的存储过程SqlServer
这个感觉上, 加一个 DELETE CASCADE 方式 的外键约束, 就什么事情都解决了呀。
--创建测试主表.ID是主键.
CREATETABLEtest_main(
idINTNOTNULL,
valueVARCHAR(10),
PRIMARYKEY(id)
);
--创建测试子表.
CREATETABLEtest_sub(
idINTNOTNULL,
main_idINT,
valueVARCHAR(10),
PRIMARYKEY(id)
);
--插入测试主表数据.
INSERTINTOtest_main(id,value)VALUES(1,'ONE');
INSERTINTOtest_main(id,value)VALUES(2,'TWO');
--插入测试子表数据.
INSERTINTOtest_sub(id,main_id,value)VALUES(1,1,'ONEONE');
INSERTINTOtest_sub(id,main_id,value)VALUES(2,2,'TWOTWO');
1>--创建外键(使用ONDELETECASCADE选项,删除主表的时候,同时删除子表)
2>ALTERTABLEtest_sub
3>ADDCONSTRAINTmain_id_cons
4>FOREIGNKEY(main_id)REFERENCEStest_mainONDELETECASCADE;
5>
6>--测试删除主表数据.将成功地执行.
7>DELETE
8>TEST_MAIN
9>WHERE
10>ID=1;
11>
12>--测试检索子表,应该只有一条main_id=2的数据.
13>SELECT
14>*
15>FROM
16>test_sub;
17>
18>go
(1行受影响)
idmain_idvalue
--------------------------------
22TWOTWO
(1行受影响)
Ⅵ 如何做SqlServer 数据查询优化!
一、建立索引
二、建立存储过程
三、只查询您所需要的数据,不要把所有数据都查询出来,防止数据冗余。
四、对于大量及海量数据一般还要建立分区
Ⅶ SQLserver如何做数据优化
2000条都查不出来,你要检查数据库到你电脑的网络是不是通畅,同时只查一下ID这样的值,看是否会好点,如果查ID值没有什么问题,证明表太大,网络不是很快,大量数据传过来时间有点久。
对于sql server表的优化,当数据量越来越大时,最好对常用的字段建索引。查询时尽量将需要查询的列出来,而不要使用*这样将所有的都查出来。如果可能,将语句写入存储过程,也能提高执行速度。
但是,网络速度不高,再怎么搞,查大量数据,都差不多!
Ⅷ 怎样进行sql数据库的优化
1、数据库空间是个概述,在sqlserver里,使用语句 exec sp_spaceused 'TableName' 这个语句来查。
Ⅸ sqlserver存储过程怎么调试
SQL Server存储过程相信大家都接触过,下面就教您如何实现SQL Server存储过程的单步调试,希望可以让您对SQL Server存储过程有更深的认识。
1)调试
在SQL Server的SQL Query Analyzer(查询分析器)中,打开Object Brower(F8),在左边的列表中选择一数据库,展开Stored Proceres,然后选择要调试的存储过程(或任意一个存储过程),按右键,点击“Debug”,则弹出Debug Procere对话框,显示该存储过程的参数(可在Proceres列表中选择其他要调试的存储过程),为参数输入初始值,点击“Execute”按钮,进入Debug窗口;可使用上面一排按钮或其对应的快捷键对该存储过程进行“执行”“设断点”“取消断点”“单步跟踪”等操作;窗口下方是参数列表,第一个是自定义参数变量列表,在Debug的过程中显示全局变量和局部变量的值的变化,可对参数列表中该存储过程的参数初值进行修改,再重新调试;第二个列表是系统变量,可自行增加,如添加“@@Error”“@@RowCount”,观看其值的变化,其值不能手工修改。第三个列表是CallStack,暂时不知道怎么用。在参数列表中,不能直接把User_Name()、GetDate()等函数直接放到参数列表中跟踪,要把它们赋值予自定义变量进行查看。
大家可连接Pivot的SQL Server进行尝试,使用本机DB系统如果不行,则需要用Administrator登录本机,然后在企业管理器中,在本机的SQL Server Registration上点击右键,点“属性”,选择“Security”,选择“This account”,输入Administrator和密码,确定之。
2)SQL Server存储过程单步调试
具体步骤如下:
1、将服务器【身份验证】属性设置成【混合模式】(window与sql身份验证)
2、在【控制面板】中打开【服务】将【MSSQLSERVER】服务打开【属性】,选择【登录】页面,将登录身份设置成服务器本地帐号和该帐号密码,如administrator,密码123;
3、重新启动sqlserver服务,此时的服务指的是【SQL服务管理器】中的SQL SERVER服务;
假设【帐号】设置为administrator
此时达到的效果是:服务器本地帐号administrator与客户端上的administrator(并且该帐号的密码要与服务器密码相同)可以通过【查询分析器】进行调试;
如果想让【其他帐号】也能够调试,那么还需要如下设置:
1、在【服务器】上运行dcomcnfg.exe;
2、在【默认安全机制】中【默认访问权限】右边点击【编辑默认值】选择允许调试的帐号类型,如users用户类型,sample帐号有包含users组;
3、重新启动sqlserver服务;
3、在客户端上创建与服务帐号密码一样的用户,如sample;
做到这步就可以通过查询分析器的调试功能进行单步调试了