`
sakakokiya
  • 浏览: 507311 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

存储过程和sql语句的优缺点

阅读更多
答:
存储过程的优缺点:
优点:
1.由于应用程序随着时间推移会不断更改,增删功能,T-SQL过程代码会变得更复杂,StoredProcedure为封装此代码提供了一个替换位置。
2.执行计划(存储过程在首次运行时将被编译,这将产生一个执行计划-- 实际上是 Microsoft SQL Server为在存储过程中获取由 T-SQL 指定的结果而必须采取的步骤的记录。)缓存改善性能。
……..但sql server新版本,执行计划已针对所有 T-SQL 批处理进行了缓存,而不管它们是否在存储过程中,所以没比较优势了。
3.存储过程可以用于降低网络流量,存储过程代码直接存储于数据库中,所以不会产生大量T-sql语句的代码流量。
4.使用存储过程使您能够增强对执行计划的重复使用,由此可以通过使用远程过程调用 (RPC) 处理服务器上的存储过程而提高性能。RPC 封装参数和调用服务器端过程的方式使引擎能够轻松地找到匹配的执行计划,并只需插入更新的参数值。
5.可维护性高,更新存储过程通常比更改、测试以及重新部署程序集需要较少的时间和精力。
6.代码精简一致,一个存储过程可以用于应用程序代码的不同位置。
7.更好的版本控制,通过使用 Microsoft Visual SourceSafe 或某个其他源代码控制工具,您可以轻松地恢复到或引用旧版本的存储过程。
8.增强安全性:
a、通过向用户授予对存储过程(而不是基于表)的访问权限,它们可以提供对特定数据的访问;
b、提高代码安全,防止 SQL注入(但未彻底解决,例如,将数据操作语言--DML,附加到输入参数);
c、SqlParameter 类指定存储过程参数的数据类型,作为深层次防御性策略的一部分,可以验证用户提供的值类型(但也不是万无一失,还是应该传递至数据库前得到附加验证)。
缺点:
1.如果更改范围大到需要对输入存储过程的参数进行更改,或者要更改由其返回的数据,则您仍需要更新程序集中的代码以添加参数、更新 GetValue() 调用,等等,这时候估计比较繁琐了。
2.可移植性差
由于存储过程将应用程序绑定到 SQL Server,因此使用存储过程封装业务逻辑将限制应用程序的可移植性。如果应用程序的可移植性在您的环境中非常重要,则将业务逻辑封装在不特定于 RDBMS 的中间层中可能是一个更佳的选择。
Sql语句灵活,可移植性强,查询速度比存储过程慢些
分享到:
评论

相关推荐

    学生管理系统(三种方法控制台实现:ArrayList、SQL语句、存储过程)

    在这个项目中,我们将探讨如何使用三种不同的方法在控制台上实现这样的系统:ArrayList、SQL语句和存储过程。每种方法都有其特点和适用场景,理解它们有助于提升对数据管理和程序设计的理解。 1. **ArrayList实现**...

    存储过程的优点

    1. **预编译与优化**:存储过程在创建时就已经经过了预编译和优化的过程,这意味着执行存储过程时可以直接利用这些优化结果,而不必每次都重新编译SQL语句。 2. **内存驻留**:存储过程首次执行后会被缓存在内存中...

    SQLServer实用SQL语句大全

    《SQLServer实用SQL语句大全》是一本涵盖了SQL Server数据库管理与开发的全面指南,旨在帮助用户深入理解和熟练运用SQL语言。此书共分为15个章节,每一章都精心设计,理论结合实践,旨在让读者能够从基础到高级逐步...

    mysql存储过程教程

    MySQL存储过程是数据库管理系统中的一种重要功能,它允许开发者预编译一系列SQL语句并封装成一个可重复使用的单元,从而提高数据处理的效率和代码的复用性。本教程将深入探讨MySQL存储过程的创建、调用以及相关概念...

    DB2 SQL存储过程基础

    * 安全性: DB2 认为 SQL 存储过程是“安全”的,因为全是 SQL,正因如此 SQL 存储过程能直接在 DB引擎上运行,并且有很好的运行效率和应用范围 存储过程的参数模式: * IN:传入数据到存储过程 * OUT:存储过程...

    DB2 sql 存储过程基础.doc

    DB2 SQL 存储过程基础是指在 DB2 数据库管理系统中使用 SQL 语言来创建和管理存储过程的技术。存储过程是一种特殊的数据库对象,允许开发者在服务器端编写和执行复杂的业务逻辑。 routine 概念 在 DB2 中,...

    Sql Sever存储过程简要教程

    存储过程是数据库管理系统中的一个重要组成部分,它是一种预编译的SQL语句集合,由一系列的流控制和SQL语句组成,用于执行特定任务。存储过程在Sql Server中扮演着关键角色,它可以增强数据库的功能,提高性能,保证...

    sql语句性能调整原则

    9. **适当使用子查询和连接操作**:子查询和连接操作都有各自的优缺点,需要根据具体情况进行选择。有时候,子查询可以通过连接操作优化,反之亦然。 10. **监控和调整数据库统计信息**:定期更新数据库统计信息,...

    mysql存储过程、触发器.pdf

    2. 可增强 SQL 语句的功能和灵活性:存储过程可以包含复杂的逻辑和计算,超过了单个 SQL 语句的能力。 3. 可减少网络流量:存储过程可以将多个 SQL 语句封装在一起,减少了网络流量和数据库服务器的负载。 4. 高性能...

    INFORMIX存储过程手册

    管理员或开发者可以通过`DBSCHEMA`工具或SQL查询来检索存储过程的代码,具体方法包括使用`dbschema`命令指定数据库名和过程名,或者通过SQL联接`sysprocedures`和`sysprocbody`表,筛选出特定过程的代码。...

    SQL2005存储过程解密

    SQL2005存储过程是微软SQL Server 2005数据库管理系统中的一种高级编程机制,它允许数据库管理员和开发者编写一系列复杂的SQL语句、控制流语句和系统功能,以实现数据处理、业务逻辑和数据操作的封装。在数据库应用...

    null关系型数据库及SQL语句,SQLSERVER数据库设计.doc

    关系型数据库可以存储大量的数据,并且可以使用SQL语句来查询、插入、更新和删除数据。 2. SQL语句的基础知识 SQL(Structured Query Language)是关系型数据库管理系统使用的标准语言。SQL语句可以用来创建、修改...

    SQL Server存储过程

    SQL Server存储过程是数据库管理系统中一组预编译的SQL语句集合,它们被封装在一起,以便于多次重复执行,提高数据库应用的效率和安全性。存储过程可以包含输入、输出甚至输入输出参数,允许根据不同的参数值执行...

    PL/SQL存储过程编程

    Pro*C/C++允许开发者在C语言程序中嵌入SQL语句,使得程序能够直接操作Oracle数据库。这种方式结合了C语言的强大功能和Oracle数据库的高效数据处理能力。 2. **ODBC (Open Database Connectivity)**: ODBC提供了一种...

    ORACLE数据库SQL语句编写优化总结.rar

    在Oracle数据库中,SQL语句的编写和优化是数据库管理员和开发人员的重要技能。这份"ORACLE数据库SQL语句编写优化总结"文档很可能是对如何提高SQL查询性能、减少资源消耗以及提升系统整体效率的详细阐述。以下是根据...

    SQL语句删除重复记录

    SQL语句删除重复记录 在数据库管理中,删除重复记录是一个非常重要的操作。重复记录可能来自于数据导入、系统错误或者其他原因。今天,我们将探讨如何使用 SQL 语句删除重复记录。下面将介绍四种不同的方法来删除...

    java sql 数据库 面试 面试试题

    - 存储过程和函数的区别是什么? - 如何在Java中调用SQL存储过程? 6. **预编译语句与批处理** - 为什么使用PreparedStatement比Statement更好? - 什么是批处理?何时应该使用批处理? 7. **连接池管理** - ...

    Oracle sql语句优化规则汇总

    ### Oracle SQL语句优化规则详解 ...综上所述,Oracle SQL语句优化是一个多方面的过程,涉及优化器的选择、访问策略的制定和SQL语句的高效管理。通过精心设计和持续调优,可以显著提升Oracle数据库的性能和响应速度。

    MySQL存储过程

    3. **执行速度快:** 预编译的特性让存储过程在执行时比动态SQL语句更快,特别是在处理大量事务时表现更佳。 4. **减少网络流量:** 调用存储过程只需发送一个简单的命令,而非整个SQL语句,这有助于减轻网络负载。 ...

    精通MySQL存储过程和函数

    ##### 2.1 存储过程的优缺点 **优点:** 1. **执行效率高:** 存储过程在服务器内部执行,减少了网络传输的开销,提高了执行效率。 2. **代码重用性:** 可以多次调用相同的存储过程,避免重复编写相同的逻辑代码。 3...

Global site tag (gtag.js) - Google Analytics