社区
MS-SQL Server
帖子详情
存储过程用多了会不会加重CPU负担,如何平衡?
zgdhj95
2003-06-09 02:00:01
正在开发一个教务系统,数据库大量用到了存储过程,可是业主的预算较低,只能购买一个CPU的服务器,到时候并发处理量很大的时候,CPU会不会吃不消?系统是C/S与B/S相结合的架构,C/S有几十个客户端,B/S有一个WEB服务器,另外还有一个中间层服务器(只是给WEB用的,C/S结构不用这个中间层。)
各位大虾给点意见,不用存储过程的话很多事情又很难做,真是麻烦.......
...全文
211
14
打赏
收藏
存储过程用多了会不会加重CPU负担,如何平衡?
正在开发一个教务系统,数据库大量用到了存储过程,可是业主的预算较低,只能购买一个CPU的服务器,到时候并发处理量很大的时候,CPU会不会吃不消?系统是C/S与B/S相结合的架构,C/S有几十个客户端,B/S有一个WEB服务器,另外还有一个中间层服务器(只是给WEB用的,C/S结构不用这个中间层。) 各位大虾给点意见,不用存储过程的话很多事情又很难做,真是麻烦.......
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
14 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
emayongxiang
2003-06-11
打赏
举报
回复
存储过程不会增加系统的负担。
要提高系统的性能,应尽量减少c/s的客户端数目。
c/s的客户端数目的数目一旦超过50,对系统的资源就会造成极大地浪费。
尽量采用b/s结构,减少同数据库的连接。
benxie
2003-06-11
打赏
举报
回复
学习ING
存储过程是一组已被编辑在一起的执行某种功能的S Q L语句。它们可以用来向用户返回
数据并且可以获得对应用逻辑的统一执行。如下所述,使用存储过程大有益处:
• 人们可以把用于完成相同任务的S Q L语句和逻辑在一个地方进行设计、编码、测试。然
后,需要用到该功能的应用程序都可以执行该存储过程。
• 存储过程可以节省因执行大块S Q L脚本而增大的网络通信量,从而提高服务器效率。这
样,所有的客户机只需要执行这个单独的存储过程就行了。
• 存储过程能使你的用户不必去了解有关表结构的每件事。他们只需要知道去执行一个存
储过程来得到明确的结果。
你可以用存储过程来做大量的事情。在第2 1学时“ SQL Server编程”中,你将学会怎样
使用存储过程。
zgdhj95
2003-06-10
打赏
举报
回复
TO CrazyFor(蚂蚁)
这么说来,是可以放心的使用存储过程了 :)
19191919
2003-06-10
打赏
举报
回复
哪本书的内容?可否告知书名?
zjy6631
2003-06-10
打赏
举报
回复
不会,会的可能性很小,并可以减少网络流量,提高应用程序性能。
当然,存储过程必须要认真设计,并考虑到性能。
CrazyFor
2003-06-10
打赏
举报
回复
储过程概述
12.1.1 存储过程的概念
存储过程Stored Procedure 是一组为了完成特定功能的SQL 语句集经编译后存
储在数据库中用户通过指定存储过程的名字并给出参数如果该存储过程带有参数来
执行它
在SQL Server 的系列版本中存储过程分为两类系统提供的存储过程和用户自定义
存储过程系统过程主要存储在master 数据库中并以sp_为前缀并且系统存储过程主
要是从系统表中获取信息从而为系统管理员管理SQL Server 提供支持通过系统存储
过程MS SQL Server 中的许多管理性或信息性的活动如了解数据库对象数据库信息
都可以被顺利有效地完成尽管这些系统存储过程被放在master 数据库中但是仍可以
在其它数据库中对其进行调用在调用时不必在存储过程名前加上数据库名而且当创建
一个新数据库时一些系统存储过程会在新数据库中被自动创建用户自定义存储过程是
由用户创建并能完成某一特定功能如查询用户所需数据信息的存储过程在本章中所
涉及到的存储过程主要是指用户自定义存储过程
12.1.2 存储过程的优点
当利用MS SQL Server 创建一个应用程序时Transaction-SQL 是一种主要的编程语
言若运用Transaction-SQL 来进行编程有两种方法其一是在本地存储Transaction-
SQL 程序并创建应用程序向SQL Server 发送命令来对结果进行处理其二是可以把
部分用Transaction-SQL 编写的程序作为存储过程存储在SQL Server 中并创建应用程序
来调用存储过程对数据结果进行处理存储过程能够通过接收参数向调用者返回结果集
结果集的格式由调用者确定返回状态值给调用者指明调用是成功或是失败包括针对
数据库的操作语句并且可以在一个存储过程中调用另一存储过程
我们通常更偏爱于使用第二种方法即在SQL Server 中使用存储过程而不是在客户
计算机上调用Transaction-SQL 编写的一段程序原因在于存储过程具有以下优点
1 存储过程允许标准组件式编程
存储过程在被创建以后可以在程序中被多次调用而不必重新编写该存储过程的SQL
语句而且数据库专业人员可随时对存储过程进行修改但对应用程序源代码毫无影响因
为应用程序源代码只包含存储过程的调用语句从而极大地提高了程序的可移植性
2 存储过程能够实现较快的执行速度
如果某一操作包含大量的Transaction-SQL 代码或分别被多次执行那么存储过程要
比批处理的执行速度快很多因为存储过程是预编译的在首次运行一个存储过程时查
询优化器对其进行分析优化并给出最终被存在系统表中的执行计划而批处理的Transaction-
SQL 语句在每次运行时都要进行编译和优化因此速度相对要慢一些
3 存储过程能够减少网络流量
对于同一个针对数据数据库对象的操作如查询修改如果这一操作所涉及到的
Transaction-SQL 语句被组织成一存储过程那么当在客户计算机上调用该存储过程时
网络中传送的只是该调用语句否则将是多条SQL 语句从而大大增加了网络流量降
低网络负载
4 存储过程可被作为一种安全机制来充分利用
系统管理员通过对执行某一存储过程的权限进行限制从而能够实现对相应的数据访
问权限的限制避免非授权用户对数据的访问保证数据的安全我们将在14 章SQL
Server 的用户和安全性管理中对存储过程的这一应用作更为清晰的介绍
wycg_cnh20
2003-06-10
打赏
举报
回复
不会增加cpu的负担
leimin
2003-06-10
打赏
举报
回复
当然,MS提供SP和XP,在加上MSSQLSERVER2000的UDF就是位了要减轻SERVER端的运行效率和安全问题.
zhangzy
2003-06-09
打赏
举报
回复
不会增加cpu的负担,存储过程在服务器中是编译过在执行的时候省去对sql语言的解析过程。因此存储过程的执行速度快、网络带宽占用低。但应避免将一些毫不相干的语句放在同一个存储过程中。
caiyunxia
2003-06-09
打赏
举报
回复
不管用过程/或前台处理,
都会使用服务器资源,但会比前台处理少用资源,用存储过程效果好些
tangwenbin
2003-06-09
打赏
举报
回复
up一下
我也想知道怎么测试
zgdhj95
2003-06-09
打赏
举报
回复
tj_dns(愉快的登山者)
这个测试不大好做啊.
愉快的登山者
2003-06-09
打赏
举报
回复
因为存储过程是在数据库服务器上执行的,用多了会加重CPU负担。
但可能减少了通讯负担。
最好做一个测试环境,按实际的用户量模拟一下,若问题严重,将结果通知客户,说服其添加CPU和内存。
若访问速度还可以,也跟客户说明,让其有机会时,添加CPU和内存。
Happiness
2003-06-09
打赏
举报
回复
存储过程不会增加负担(包括CPU负担、内存负担、磁盘负担、网络负担)
会减少磁盘负担、网络负担
如果确实负担不了,只能考虑升级和优化了
注:没有优化的存储过程也许会增加负担
该不该用
存储过程
?什么情况下使用
存储过程
?
转自:https://www.cnblogs.com/gxbk629/p/4505844.html 本篇文章讨论并不是:不要使用
存储过程
,因为有些事情还是要
存储过程
来完成,不可能不用。而是关于:"业务逻辑是不是要封装在
存储过程
中实现,这样子php、java等就是调用
存储过程
"。 业务逻辑,通俗说就是:比如要取数据的操作,取出
会
员编号为x的数据,原来我们一般是封装成函数,或者直接编写...
ES6 的解构赋值前每次都创建一个对象吗?
会
加重
GC 的
负担
吗?
本文来源于知乎上的一个提问。为了程序的易读性,我们
会
使用 ES6 的解构赋值:function f({a,b}){}f({a:1,b:2});这个例子的函数调用中,
会
真的...
java 储存过程_java
存储过程
一、java的六种存储地址及解释1) 寄存器(register):这是最快的存储区,因为它位于不同于其他存储区的地方——处理器内部。但是寄存器的数量极其有限,所以寄存器由编译器根据需求进行分配。你不能直接控制,也不能在程序中感觉到寄存器存在的任何迹象。2) 堆栈(stack):位于通用RAM中,但通过它的“堆栈指针”可以从处理器哪里获得支持。堆栈指针若向下移动,则分配新的内存;若向上移动,则释放那...
深入浅出:
CPU
,GPU,内存的优化
营养非常丰富的一篇文章,原文:http://www.cnblogs.com/murongxiaopifu/p/4284988.html 阅读目录 前言:看看优化需要从哪里着手
CPU
的方面的优化:GPU的优化内存的优化更新,使用Unity Profiler工具检测内存 前言: 刚开始写这篇文章的时候选了一个很土的题目。。。《Unity3D优化全解析
该不该用
存储过程
转:减少
存储过程
封装业务逻辑-web开发与传统软件开发的思维模式不同 本篇文章讨论并不是:不要使用
存储过程
,因为有些事情还是要
存储过程
来完成,不可能不用。而是关于:"业务逻辑是不是要封装在
存储过程
中实现,这样子php、java等就是调用
存储过程
"。 业务逻辑,通俗说就是:比如要取数据的操作,取出
会
员编号为x的数据,原来我们一般是封装成函数,或者直接编写sql语句查询。现在是交给数据库
MS-SQL Server
34,591
社区成员
254,589
社区内容
发帖
与我相关
我的任务
MS-SQL Server
MS-SQL Server相关内容讨论专区
复制链接
扫一扫
分享
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章