讨论:关于SQL数据库的事务处理。

oo渣渣oo 2008-06-25 12:09:37
单位开发一个数据处理量较大的项目,使用VB.NET2003+SQL2000。
现在正在设计当中,到时大概会有100台左右的电脑同时使用一个数据库。
由于肯定要用到事务处理,想跟高手们讨论一下:

在存储过程中使用BEGIN TRAN...ROLLBACK TRAN...COMMIT TRAN这样的事务处理好,
还是在代码中使用BeginTransaction...Rollback...Commit这样的事务处理好?

请高手分析一下,各自的优缺点。谢谢!
...全文
170 22 打赏 收藏 转发到动态 举报
写回复
用AI写文章
22 条回复
切换为时间正序
请发表友善的回复…
发表回复
Tracy5453 2008-07-10
  • 打赏
  • 举报
回复
我们项目全是放在代码里,维护方便
oo渣渣oo 2008-07-10
  • 打赏
  • 举报
回复
再顶,还有人要说什么吗?没有就结贴了
oo渣渣oo 2008-07-10
  • 打赏
  • 举报
回复
[Quote=引用 21 楼 Tracy5453 的回复:]
问领导,领导让用什么就用什么, 呵呵
[/Quote]

不好意思……俺就是领导……俺自己领导自己……俺也不晓得该用什么好!哈哈哈
Tracy5453 2008-07-10
  • 打赏
  • 举报
回复
问领导,领导让用什么就用什么, 呵呵
烈火焚身 2008-07-10
  • 打赏
  • 举报
回复
up
gsmsdn 2008-06-26
  • 打赏
  • 举报
回复
存储过程好
  • 打赏
  • 举报
回复
个人觉得:
使用BEGIN TRAN...ROLLBACK TRAN...COMMIT TRAN这样的事务处理好
xiaoqhuang 2008-06-25
  • 打赏
  • 举报
回复
感觉code里事务锁比较独占或排它, 事务内操作不当很容易time out.
如果代码复用度不高,尽量放SP里.
神之泪花 2008-06-25
  • 打赏
  • 举报
回复
我们的项目一般都是放在代码里处理的.

如果是考虑效率的话,这个你应该找本SQL的书看看.
51Crack 2008-06-25
  • 打赏
  • 举报
回复
俺是放在程序中的,因为执行过程中可能执行多个存储过程!
xuzicn 2008-06-25
  • 打赏
  • 举报
回复
效率上的差距不太清楚。想来差距应该不大

光从程序上来说。写存储过程很明显是个痛苦的过程,因为调试等等很困难,阅读起来也不够清晰。代码里的transaction明显就很清楚明白,从开发者的角度来说,我觉得放弃存储过程是可以的
足球中国 2008-06-25
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 whoami333 的回复:]
数据库的东西还是数据库来处理好了。
[/Quote]
放在数据库中有灵活性。程序升级的改动比较少。
amandag 2008-06-25
  • 打赏
  • 举报
回复
这个肯定是能用存储过程就用存储过程,除非有些逻辑必须要和程序交互
myjce 2008-06-25
  • 打赏
  • 举报
回复
当然在存储过程好啦
CathySun118 2008-06-25
  • 打赏
  • 举报
回复
当然在存储过程好。
horizonlin 2008-06-25
  • 打赏
  • 举报
回复
6楼说得对,记得看过一本书,在存储过程中的代码是编译好的,比每次写再编译要好一点,但在代码安全性方面,存储过程又没有程序代码安全,方便性上说也是存储过程要有优势,有时改变算法不用更新客户端
guilin_gavin 2008-06-25
  • 打赏
  • 举报
回复
个人觉得,如果要是偏向于数据的操作的话,使用存储过程可能效率会好一些,但是如果要是其中掺杂有大量的业务逻辑的话,建议还是不要放到存储过程中,使用代码可能会更清晰一些,可能有人会说,放到存储过程中,还保证了业务逻辑的隐秘性,但是如果想想如果其中出现问题,调试数据库的存储过程可是一个噩梦,所以说,如果是偏简单或偏数据操作性强的流程,使用数据库存储过程可能会好一些,反之,可以考虑在代码中实现,差别应该不是很明显。
yanlongwuhui 2008-06-25
  • 打赏
  • 举报
回复
基本还是在代码中处理,部分比较特殊的处理是使用存储过程的
whoami333 2008-06-25
  • 打赏
  • 举报
回复
数据库的东西还是数据库来处理好了。
ejoe313 2008-06-25
  • 打赏
  • 举报
回复
这个要根据你的系统来配合使用,不是说用哪个不用哪个;

速度上来说,存储过程中会高一些
加载更多回复(2)
SQL Server 2005微软官方权威参考手册     是Inside Microsoft SQL Server 2005系列书中的第一本,SQL Server类的顶尖之作   全球公认SQL Server 2005经典著作,囊括大量鲜为人知的技术内幕,大师智慧、专家经验尽览无余。       本系列图书中文版得到了微软总部SQL Server组专家的高度重视,同时也得到了微软中国上海SQL Server全球技术支持中心的高度关注。        本书详细介绍了T-SQL的内部构造,包含了非常全面的编程参考。数据库开发人员和DBA可以通过书中的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的问题。本书涵盖了T-SQL程序设计的方方面面,如基于集合的编程技术、日期和时间相关的XML和CLR数据类型的使用、临时对象、T-SQL和CLR用户自定义函数、存储过程、触发器、事务和新的错误处理结构、应用并发模型支持并发用户、使用Service Broker来控制数据库应用程序中的异步处理等。   内容简介 本书是Inside Microsoft SQL Server 2005系列四本著作中的一本。它详细介绍了T-SQL的内部构造,包含了非常全面的编程参考。它提供了使用Transact-SQL(T-SQL)的专家级指导,T-SQL是用于SQL Server的最常见的也是功能最强大的编程语言。该书由Itzik Ben-Gan权威执笔,重点关注语言特性以及它们如何被SQL Server引擎解释和处理。   通过本书,你将深入了解T-SQL的高级用法,包括触发器、用户自定义函数、异常处理等。该书解释并比较了SQL Server 2000和SQL Server 2005在数据库开发相关问题上的解决方案,深入讨论SQL Server 2005中新增的T-SQL编程特性,包含了大量的代码示例、表示例和逻辑难题以帮助数据库开发人员和管理员理解复杂的逻辑并掌握T-SQL。   本书适合于专业数据库开发者、BI开发者、DBA和以SQL Server作为后台数据库的一般应用程序开发者,读者可以通过书中的最佳实践、高级技巧和代码示例来掌握这门复杂的编程语言,以切合实际的方案来解决复杂的实际问题。 作者简介 Itzik Ben-Gan是Solid Quality Learning的导师和创始人。从1999年开始,他一直是Microsoft SQL Server MVP(最有价值专家),并在全世界已经开展过无数次T-SQL查询、T-SQL优化和编程方面的培训。Itzik是Microsoft SQL Server方面几本著作的作者。他在SQL ServerMagazine和MSDN上发表了许多文章和白皮书。Itzik被邀请在许多会议上做报告,包括TechEd、DevWeek、世界各地的各种SQL用户组、PASS、SQL server Magazine Connections和Solid Quality Learning的会议。 从1992年开始,Itzik就一直致力于涉及各种数据库和计算机系统相关技术的多个课题。除了帮助顾客处理紧迫的要求、修复问题、优化数据库、教学和担任顾问以外,他还帮助开发人员和数据库管理员转变关系/基于集合的理念,改善他们编写代码的性能和可维护性。Itzik擅长T-SQL查询、查询优化、编程和内部原理,此外他还精通其他的数据库领域。1999年,Itzik创立以色列SQL Server和OLAP用户组,一直管理至今。 目录 序 前言 致谢 引言 第1章 数据类型相关的问题,XML和CLR UDT 1.1 DATETIME数据类型 DATETIME的存储格式 时间处理   Datetime相关的查询问题  1.2 与字符相关的问题   模式匹配   区分大小写(Case-Sensitive)的筛选器  1.3 大型对象(Large Object,LOB)   MAX 说明符   BULK行集提供程序  1.4 隐式转换(Implicit Conversion)   标量表达式   筛选表达式  1.5 基于CLR的用户定义类型   UDT理论简介   开发UDT  1.6 XML数据类型   关系数据库中的XML支持   什么时候应该使用XML代替关系表现形式?   数据库中的XML序列化对象   使用开放架构(Open Schema)的XML   作为存储过程参数的XML数据类型   Xquery修改语句  1.7 结论 第2章 临时表和表变量  2.1 临时表   局部临时表   全局临时表  2.2 表变量   限制条件   tempdb   范围和可见性   事务上下文   统计信息  2.3 tempdb相关的注意事项  2.4 表表达式  2.5 比较临时对象  2.6 综合练习——关系分区(Relational Division)  2.7 结论 第3章 游标  3.1 使用游标  3.2 游标开销  3.3 单独处理每一行  3.4 按顺序访问   自定义聚合   连续聚合   最大并发会话   匹配问题  3.5 结论 第4章 动态SQL 第5章 视图 第6章 用户定义函数 第7章 存储过程 第8章 触发器 第9章 事务 第10章 错误处理 第11章 Service Broker 附录A CLR程序指南 A.1 创建CLRUtilities数据库: SQL Server A.2 部署:Visual Studio A.3 部署和测试:Visual Studio 和 SQL Server 索引 中英文术语对照表

16,556

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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