主页 > 知识库 > 在SQLServer 2005中编写存储过程

在SQLServer 2005中编写存储过程

热门标签:网站排名优化 地方门户网站 服务外包 AI电销 呼叫中心市场需求 百度竞价排名 铁路电话系统 Linux服务器
然而,在SQL Server 2005中,我们可以用.NET家族的语言——主要是VB.NET和C#来编写存储过程(以及方法、触发器和其它组件)。让我们来熟悉一下关于编写存储过程新方法的5个常见问题。它们是非常值得我们探讨的。
  1、为什么我们必须使用CLR模式来编写存储过程呢?
  主要原因是速度。SQL CLR在很多方式下都运行较快:比如字符串处理,它比T-SQL运行快很多,并且对于错误的处理能力也更加强大。同时,由于CLR所提供的来执行这些事务的框架都更为完善,因此任何需要与数据库之外资源进行事务交互的存储过程——比如,文件系统或者Web服务——CLR SP都是表现最好的。
  2、CLR最适合编写哪些类型的存储过程?
  一般来说,在数据上执行繁重计算而不是仅仅是查询数据的SP最适合用CLR。如果一个CLR SP只是封装一个复杂的SELECT语句,那么我们将无法看到显著的性能增益,因为每次运行SP时,都必须验证CLR中的SQL语句。事实上,它比仅将SELECT语句作为T-SQL SP处理表现还要差。
  一个经典的好方法是:如果需要执行的SQL的行数很多,那么可以将SQL封装在一个常规的SP上。如果想要在一个大的数据集上运行CLR风格的处理,那么我们可以在CLR SP内部调用一个常规的SP来获取这个大的数据集。这样,常规的SP会被预编译,性能也会更好,同时数据转换性能也会有所提高。
  注意:这种情况是假定我们需要在数据层上进行复杂的数据处理,而不是在显示层上。事实上我们在编写代码之前就需要考虑这些问题。
  3、是否应该把现有的存储过程转换为CLR模式?
  简单而言,“要有好处才去做”。在这种情况下,可以为指定的存储过程创建一个同等的CLR实现的版本,然后使用实际数据对两种SP进行测试。除非我们可以确定新的存储过程:(a)按照预计的方式运行,(b)对性能有实际的提升,否则应该继续使用老的存储过程。其实CLR跟其它的存储过程一样,没什么奇特的。
  4、在没有开发IDE的情况下,可以创建CLR(Common Language Runtime)存储过程吗?
  当然,我们可以通过C#编译手动实现这类开发。然而,使用Visual Studio或者类似的IDE可以更简单,特别是当我们在整个企业范围内转换或实现大量SP时。
  5、转换有多难?
  很明显,我们必须具备其中一种支持语言的知识,如VB.NET或者C#。事实上,SQL命令是“封装”在CLR代码中的,因此,只要我们知道如何使用它,那么在CLR重新实现现有的T-SQL是不难的。比较有难度的是如何使用这种语言来优化我们正在做的工作,这个问题就不是几个要点就可以归纳的。
您可能感兴趣的文章:
  • SqlServer 2000、2005分页存储过程整理
  • sqlserver存储过程语法详解
  • SqlServer获取存储过程返回值的实例
  • sqlserver 各种判断是否存在(表名、函数、存储过程等)
  • sqlserver 存储过程带事务 拼接id 返回值
  • sqlserver 存储过程动态参数调用实现代码
  • sqlserver 存储过程分页(按多条件排序)
  • sqlserver 存储过程分页代码
  • sqlserver 常用存储过程集锦
  • sqlserver 通用分页存储过程
  • SQLServer 2005 列所有存储过程的语句
  • 分页 SQLServer存储过程
  • sql存储过程几个简单例子

标签:铜川 湘潭 兰州 崇左 湖南 仙桃 黄山 衡水

巨人网络通讯声明:本文标题《在SQLServer 2005中编写存储过程》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266