SQL_存储过程学习总结
oracle存储过程学习经典语法实例调用

O r a c l e存储过程学习目录Oracle存储过程基础知识商业规则和业务逻辑可以通过程序存储在Oracle中,这个程序就是存储过程。
存储过程是SQL, PL/SQL, Java 语句的组合,它使你能将执行商业规则的代码从你的应用程序中移动到数据库。
这样的结果就是,代码存储一次但是能够被多个程序使用。
要创建一个过程对象 procedural object ,必须有 CREATE PROCEDURE 系统权限。
如果这个过程对象需要被其他的用户schema 使用,那么你必须有 CREATE ANY PROCEDURE 权限。
执行procedure 的时候,可能需要excute权限。
或者EXCUTE ANY PROCEDURE 权限。
如果单独赋予权限,如下例所示:grant execute on MY_PROCEDURE to Jelly调用一个存储过程的例子:execute MY_PROCEDURE 'ONE PARAMETER' ;存储过程 PROCEDURE 和函数 FUNCTION 的区别。
function有返回值,并且可以直接在Query中引用function和或者使用function的返回值。
本质上没有区别,都是 PL/SQL 程序,都可以有返回值。
最根本的区别是:存储过程是命令, 而函数是表达式的一部分。
比如:select max NAME FROM但是不能 exec max NAME 如果此时max是函数。
PACKAGE是function,procedure,variables 和sql 语句的组合。
package允许多个procedure使用同一个变量和游标。
创建 procedure的语法:Sql 代码:可以使用 create or replace procedure 语句, 这个语句的用处在于,你之前赋予的excute 权限都将被保留。
IN, OUT, IN OUT用来修饰参数。
oracle 存储过程ifelse语句的用法

Oracle 是目前全球应用非常广泛的数据库管理系统之一,它支持使用PL/SQL 语言编写存储过程以及触发器等数据库对象。
在编写存储过程时,经常会用到条件判断语句,而 if-else 语句是最常见的一种条件判断语句。
本文将介绍在 Oracle 存储过程中如何使用 if-else 语句,并给出一些实际的示例来帮助读者更好地理解。
一、基本语法在 PL/SQL 中,if-else 语句的基本语法如下所示:```sqlIF condition THENstatement1;ELSIF condition THENstatement2;ELSEstatement3;END IF;```其中,condition 是一个条件表达式,如果它的值为真(True),则执行 statement1;否则继续判断下一个条件表达式,如果符合条件,则执行 statement2;如果上述条件都不满足,则执行 statement3。
二、示例说明接下来,我们通过一个实际的示例来说明 if-else 语句的用法。
假设我们需要编写一个存储过程,根据员工的工资水平给予不同的奖金。
在这个示例中,我们使用 if-else 语句来实现这一逻辑。
```sqlCREATE OR REPLACE PROCEDURE calculate_bonus (emp_id IN NUMBER) ASsalary NUMBER;bonus NUMBER;BEGIN-- 获取员工的工资水平SELECT salary INTO salaryFROM employeesWHERE employee_id = emp_id;-- 根据工资水平计算奖金IF salary > xxx THENbonus := salary * 0.2;ELSIF salary > 5000 THENbonus := salary * 0.1;ELSEbonus := salary * 0.05;END IF;-- 将奖金插入到奖金表中INSERT INTO bonus_table (employee_id, bonus_amount)VALUES (emp_id, bonus);END;/```在这个示例中,我们定义了一个名为 calculate_bonus 的存储过程,它接收一个员工的 ID 作为输入参数。
达梦数据库 存储过程语法

达梦数据库存储过程语法下载温馨提示:该文档是我店铺精心编制而成,希望大家下载以后,能够帮助大家解决实际的问题。
文档下载后可定制随意修改,请根据实际需要进行相应的调整和使用,谢谢!并且,本店铺为大家提供各种各样类型的实用资料,如教育随笔、日记赏析、句子摘抄、古诗大全、经典美文、话题作文、工作总结、词语解析、文案摘录、其他资料等等,如想了解不同资料格式和写法,敬请关注!Download tips: This document is carefully compiled by the editor. I hope that after you download them, they can help yousolve practical problems. The document can be customized and modified after downloading, please adjust and use it according to actual needs, thank you!In addition, our shop provides you with various types of practical materials, such as educational essays, diary appreciation, sentence excerpts, ancient poems, classic articles, topic composition, work summary, word parsing, copy excerpts,other materials and so on, want to know different data formats and writing methods, please pay attention!达梦数据库是一种关系型数据库管理系统,它具有高性能、高可靠性和高安全性的特点,广泛应用于企业信息化建设中。
SQL Server 2005数据库原理及应用教程第8章 存储过程和触发器

2.相关注意事项 ①不能将 CREATE PROCEDURE语句与其他 SQL 语句组合 PROCEDURE语句与其他 到单个批处理中。 ②创建存储过程的权限默认属于数据库所有者,该所有者可将 此权限授予其他用户。 ③存储过程是数据库对象,名称必须遵守标识符规则。 ④只能在当前数据库中创建存储过程。 ⑤一个存储过程的最大尺寸为128M。 ⑤一个存储过程的最大尺寸为128M。 ⑥可以在存储过程内引用临时表。 ⑦如果执行的存储过程调用另一个存储过程,则被调的存储过 程可以访问由第一个存储过程创建的包括临时表在内的所有 对象。 ⑧存储过程中参数的最大数量为2100。 ⑧存储过程中参数的最大数量为2100。 ⑨不要以sp_为前缀创建任何存储过程。 ⑨不要以sp_为前缀创建任何存储过程。
1.语法格式 创建存储过程的语法格式: CREATE PROC[EDURE] procedure_name[;number] [{@parameterdata_type} [VARYING][=default][OUTPUT] ][,...n] WITH AS sql_statement [ ...n ] ①procedure_name:用于指定要创建的存储过程的名称。 procedure_name:用于指定要创建的存储过程的名称。 ②number:该参数是可选的整数,它用来对同名的存储过程分组,以便用 number:该参数是可选的整数,它用来对同名的存储过程分组,以便用 一条 DROP PROCEDURE 语句即可将同组的过程一起除去。 ③@parameter:过程中的参数,在 CREATE PROCEDURE 语句中可以 @parameter:过程中的参数,在 声明一个或多个参数。 ④data_type:用于指定参数的数据类型。 data_type:用于指定参数的数据类型。 ⑤VARYING:用于指定作为输出OUTPUT参数支持的结果集。 VARYING:用于指定作为输出OUTPUT参数支持的结果集。 ⑥DEFAULT:用于指定参数的默认值。 DEFAULT:用于指定参数的默认值。 ⑦OUTPUT:表明该参数是一个返回参数。 OUTPUT:表明该参数是一个返回参数。 ⑧AS:用于指定该存储过程要执行的操作。 AS:用于指定该存储过程要执行的操作。 ⑨sql_statement:是存储过程中要包含的任意数目和类型的 Transactsql_statement:是存储过程中要包含的任意数目和类型的 TransactSQL 语句。
关于SQL文优化问题总结

关于SQL文优化问题总结【摘要】实际系统中遇到性能问题是非常常见的,性能优化有许多方面,其中包括硬件方面,软件方面,包括服务器端,客户端等等。
本文重点基于oracle分析了影响sql文性能的原因,然后列举了几点性能优化的对策,希望给开发人员在编码时提供帮助,给sql的性能问题调查者提供一个方向。
【关键词】oracle;性能问题;sql文优化一、问题提出之前有个项目,其中的批处理定期调用一个存储过程,在测试环境中运行没有问题,但是正式运行出现了错误,执行存储过程时出现了错误:提示是表空间不足。
为了解决这个问题,笔者对sql 文的性能优化进行了学习和研究。
二、问题调查与解决由于该存储过程内容比较多,大概有3000多行,也不能判断那部分出了问题,首先在可能出现问题的地方追加了log信息。
由于测试环境中该问题不能再现,所以代码更新到了实际环境中进行运行,通过log发现是在执行某个sql文时出的错误,这个sql文涉及到了10多个表,而其中表中的数据量比较大。
执行时用到的临时表空间高达40g,后来通过调查对sql的进行了调整,只是修改了where条件中其中两个条件的顺序,这个问题就解决了。
三、sql文性能原因分析(1)在大记录集上进行高成本操作,如使用了引起排序的谓词等。
(2)过多的i/o操作(含物理i/o与逻辑i/o),最典型的就是未建立恰当的索引,导致对查询表进行全表扫描。
减少访问数据库的次数,就能实际上减少oracle的工作量。
(3)处理了太多的无用记录,如在多表连接时过滤条件位置不当导致中间结果集包含了太多的无用记录。
(4)未充分利用数据库提供的功能,如查询的并行化处理等。
四、sql文性能优化总结(1)建立恰当的索引。
对经常进行排序和连接操作的字段建立索引。
(2)避免使用”*”,sql文中引用”*”,使用起来的确非常方便,但是效率非常低,主要是oracle在解析的过程中,会将”*”一次转化成所有的列名,这个工作是通过查询数据字典完成的。
sql server 经典 学习 总结

前言:最近看了看自己的这个简单的文章感觉不错,有机会一定将这个文档更新,分享给所有人们,祝大家学有所成。
本人最近研究mysql,有机会和大家分享mysql笔记^_^文档书写时间:2009年Sql server基础1 Transact-SQL 语言SQL 语言是一种介于关系代数与关系演算之间的语言其功能包括查询操纵定义和控制4 个方面是一个通用的功能极强的关系数据库语言SQL 语言的组成:数据定义语言DDL Data Definition Languagecreate table 创建一个数据库表drop table 从数据库中删除表alter table 修改数据库表结构create view 创建一个视图drop view 从数据库中删除视图create index 为数据库表创建一个索引drop index 从数据库中删除索引create procedure 创建一个存储过程drop procedure 从数据库中删除存储过程...数据操纵语言DML Data Manipulation Languageselect 从数据库表中检索数据行和列insert 向数据库表添加新数据行delete 从数据库表中删除数据行update 更新数据库表中的数据数据控制语言DCL Data Control Languagegrant 授予用户访问权限deny 拒绝用户访问revoke 解除用户访问权限2 条件表达式和逻辑运算符SQL Server提供的算术运算符运算符功能+ 完成两个数值型数据的相加操作/两个字符型数据的字符串串联操作- 完成两个数值型数据的相减操作* 完成两个数值型数据的相乘操作/ 完成两个数值型数据的相除操作% 完成两个数值型数据的模运算SQL Server提供的逻辑运算符运算符功能AND 二元运算,当参与运算的子表达式全部返回TRUE时,整个表达式的最终结果为TRUEOR 二元运算,当参与运算的子表达式中有一个返回为TRUE时,整个表达式返回TRUENOT 对参与运行的表达式结果取反IN 如果操作数与表达式列表中的任何一项匹配,则返回TRUE BETWEEN 如果操作数位于某一指定范围,则返回TRUEEXISTS 如果表达式的执行结果不为空,则返回TRUEANY 对OR操作符的扩展,将二元运算推广为多元运算ALL 对AND运算符的扩展,将二元运算推广为多元运算SOME 如果在一系列比较中,有某些子表达式的值为TRUE,那么整个表达式返回TRUELIKE 如果操作数与一种模式相匹配,那么就为 TRUE比较运算符运算符功能!= 不等于,等同于<>!< 不小于,等同于>=!> 不大于,等同于<=注:通配符:'_' % []3 T-SQL基础操作:Insert:语法:insert into table_name(col_name1...) values (value1...)通过insert select语句将现有表中的数据添加到新表中例如:Insert into tongxulu (姓名,地址,电子邮件)Select SName,SAddress,SEmailFrom student通过select into 语句将现有的表中的数据添加到新表中Select student.SName,student.SAddressInto tongxueluFrom student通过union关键字合并数据进行插入Union:用于将两个不同的数据或查询结果组合成新的结果集例如:Insert student(sname,sgread)Select '张三',1 unionSelect '李四',2 unionSelect '王五',3Update:语法:update <表名> set <列名=更新值> [where <更新条件>]Delete:语法:delete from <表名> [where <删除条件>]Truncate table:语法:Truncate table <表名>数据查询1 使用select查询语法:select <列名>From <表名>[where <条件查询>][order by <排序的列名> [desc 或 asc]]A 查询数据和列B 条件查询C 使用别名D 查询空行(is null)E 查询中使用常量F 查询使用的行数(top num)2 查询排序:使用。
sqlserver 格式化存储过程语句
一、概述SQL Server是一种流行的关系型数据库管理系统,它提供了存储过程这样的功能来增强数据库的灵活性和性能。
在实际的开发工作中,编写规范、易读的存储过程语句是非常重要的,这不仅可以提高代码的可维护性和可读性,还可以减少潜在的错误和提高执行效率。
本文将介绍如何对SQL Server中的存储过程语句进行格式化,以便开发人员能够更好地理解和管理代码。
二、SQL Server存储过程语句格式化的重要性1.可读性:规范的存储过程语句可以使代码更易读,从而减少了学习成本,并且能够提高新团队成员对代码的快速理解,减少理解的难度。
2.可维护性:格式化过的存储过程语句可以减少代码中的冗余或者重复的代码,实现代码重构,降低了代码维护的难度。
3.执行效率:规范的存储过程语句可以减少数据库服务器的负担,提升执行效率。
三、存储过程语句格式化的常用方法SQL Server中存储过程语句格式化的常用方法有很多,比如使用工具、手动排版等。
1.使用第三方工具第三方工具可以自动对存储过程语句进行格式化,比如SQL Server Management Studio (SSMS)、Redgate SQL Prompt等。
这些工具通常提供了多种格式化选项,可以根据个人或项目组的编码规范进行设置,通过简单的点击或快捷键即可完成格式化。
2.手动排版手动排版是一种传统的方法,可以通过缩进、换行、注释等方式加强代码的可读性。
在手动排版时,需要遵循一定的排版规范,比如保持一致的缩进、合理的换行等,以便代码的结构更加清晰。
四、使用SSMS格式化存储过程语句的步骤1.打开SQL Server Management Studio (SSMS),连接到相应的数据库服务器。
2.在对象资源管理器中展开数据库,找到存储过程所在的文件夹。
右键单击存储过程,选择“脚本存储过程为” - “新查询编辑器窗口”。
3.在新的查询编辑器窗口中,找到工具栏上的“查询”选项。
达梦创建存储过程实例-概述说明以及解释
达梦创建存储过程实例-概述说明以及解释1.引言1.1 概述在信息化和数据化的时代背景下,数据库管理系统(DBMS)成为了管理和存储大量数据的重要工具。
达梦数据库是一种高性能、高安全性的关系型数据库管理系统,它提供了一系列强大的功能和工具,用于管理和操作数据库。
存储过程是数据库中一组预定义的SQL语句集合,可以被保存并以后被重复调用。
存储过程使得数据库的开发工作更加灵活和高效,可以通过简单的调用实现复杂的业务逻辑。
达梦数据库也支持创建存储过程,并且为开发人员提供了完善的存储过程开发和管理工具。
本文将以达梦数据库为例,介绍如何创建和使用存储过程。
首先,我们将对存储过程的概念和特点进行简要介绍。
然后,我们将详细讲解如何在达梦数据库中创建存储过程,并通过实例演示不同场景下存储过程的应用。
最后,我们将总结本文的主要内容,并展望存储过程在数据库开发中的未来发展趋势。
通过学习本文,读者将能够深入了解达梦数据库存储过程的基本原理和使用方法,提升数据库开发效率和程序性能,并为今后的数据库应用开发奠定扎实的基础。
1.2 文章结构文章结构部分的内容可以按照以下方式编写:2. 正文2.1 子章节12.1.1 要点12.1.2 要点22.2 子章节22.2.1 要点12.2.2 要点22.3 子章节32.3.1 要点12.3.2 要点2本文主要分为引言、正文和结论三个部分。
其中正文部分包含了三个子章节,分别是子章节1、子章节2和子章节3。
每个子章节下又包含了各自的要点。
通过这种层级结构,使得文章的结构更加清晰明了。
引言部分对文章的整体进行了概述,包括了概述、文章结构和目的三个方面的内容。
正文部分是文章的核心部分,具体展开了对达梦创建存储过程的实例的讲解。
结论部分对全文进行了总结,并对未来展望进行了描述。
这样的结构安排旨在使读者更好地理解文章内容,并能够按照章节的顺序逐步阅读,加深对达梦创建存储过程的理解。
同时,该结构也有助于作者更好地组织和表达思路,使文章更加清晰和条理。
MySQL存储过程的深入讲解(in、out、inout)
MySQL存储过程的深⼊讲解(in、out、inout)⼀、简介从 5.0 版本才开始⽀持,是⼀组为了完成特定功能的SQL语句集合(封装),⽐传统SQL速度更快、执⾏效率更⾼。
存储过程的优点1、执⾏⼀次后,会将⽣成的⼆进制代码驻留缓冲区(便于下次执⾏),提⾼执⾏效率2、SQL语句加上控制语句的集合,灵活性⾼3、在服务器端存储,客户端调⽤时,降低⽹络负载4、可多次重复被调⽤,可随时修改,不影响客户端调⽤5、可完成所有的数据库操作,也可控制数据库的信息访问权限为什么要⽤存储过程?1.减轻⽹络负载;2.增加安全性⼆、创建存储过程2.1 创建基本过程使⽤create procedure语句创建存储过程存储过程的主体部分,被称为过程体;以begin开始,以end$$结束#声明语句结束符,可以⾃定义:delimiter $$#声明存储过程create procedure 存储过程名(in 参数名参数类型)begin#定义变量declare 变量名变量类型#变量赋值set 变量名 = 值sql 语句1;sql 语句2;...end$$#恢复为原来的语句结束符delimiter ;(有空格)实例:mysql> delimiter $$mysql> create procedure text()-> begin-> select * from stu.a_player;-> end $$Query OK, 0 rows affected (0.00 sec)mysql> delimiter ;调⽤存储过程call 存储过程名(实际参数);mysql> call text;+----+----------+-------+| id | name | score |+----+----------+-------+| 1 | zhangsan | 88 || 2 | lisi | 89 || 3 | wangwu | 67 || 4 | zhaoliu | 90 || 5 | xuli | 80 || 6 | keke | 75 |+----+----------+-------+6 rows in set (0.00 sec)删除存储过程mysql> drop procedure text;2.2 存储过程的参数MySQL存储过程的参数⽤在存储过程的定义,共有三种参数类型,IN,OUT,INOUT,形式如:CREATEPROCEDURE 存储过程名([[IN |OUT |INOUT ] 参数名数据类形...])IN 输⼊参数:表⽰调⽤者向过程传⼊值(传⼊值可以是字⾯量或变量)OUT 输出参数:表⽰过程向调⽤者传出值(可以返回多个值)(传出值只能是变量)INOUT 输⼊输出参数:既表⽰调⽤者向过程传⼊值,⼜表⽰过程向调⽤者传出值(值只能是变量)传递参数实例:INmysql> create procedure test1(in in_id int(2))-> begin-> select * from stu.a_player where id=in_id;-> end $$Query OK, 0 rows affected (0.00 sec)mysql> delimiter ;#将4传递给in_id变量,执⾏事务mysql> call test1(4);+----+---------+-------+| id | name | score |+----+---------+-------+| 4 | zhaoliu | 90 |+----+---------+-------+1 row in set (0.00 sec)#将6传递给in_id变量,执⾏事务mysql> call test1(6);+----+------+-------+| id | name | score |+----+------+-------+| 6 | keke | 75 |+----+------+-------+1 row in set (0.00 sec)OUTmysql> delimiter $$mysql> create procedure test2(out aa int)-> begin-> select aa;-> set aa=2;-> select aa;-> end $$Query OK, 0 rows affected (0.00 sec)mysql> delimiter ;#将@aa变量传递给test2 事务mysql> call test2(@aa);+------+| aa |+------+| NULL |+------+#out向调⽤者输出参数,不接收输⼊的参数,所以aa为null1 row in set (0.00 sec)+------+| aa |+------+| 2 |+------+事务将aa变量设置为2(设置的是全局),则可进⾏输出1 row in set (0.00 sec)Query OK, 0 rows affected (0.00 sec)mysql> select @aa;+------+| @aa |+------+| 2 |+------+1 row in set (0.00 sec)#事务外查询变量,已经被修改IN 、OUT、 INOUT 对⽐mysql> delimiter //mysql> create procedure test3(in num1 int,out num2 int,inout num3 int)-> begin-> select num1,num2,num3;-> set num1=10,num2=20,num3=30;-> select num1,num2,num3;-> end //Query OK, 0 rows affected (0.00 sec)mysql> delimiter ;mysql> call test3(@num1,@num2,@num3);+------+------+------+| num1 | num2 | num3 |+------+------+------+| 1 | NULL | 3 |+------+------+------+1 row in set (0.00 sec)+------+------+------+| num1 | num2 | num3 |+------+------+------+| 10 | 20 | 30 |+------+------+------+1 row in set (0.00 sec)Query OK, 0 rows affected (0.00 sec)in和inout参数会将全局变量的值传⼊存储过程中,⽽out参数不会将全局变量的值传⼊存储过程中。
数据库实验心得体会
数据库实验心得体会篇一:数据库实训总结SQL Server 数据库管理课实训报告这个星期是我们SQL Server 数据库管理课的实训,经过一个星期的实训,让我将书本上的理论与实践相结合,领会到了许多平时课堂上所没有接受的课外知识课外训练,懂得如何去运用自己学到的书本上的知识,而进行的一次分析设计综合的训练。
而本次实训的目的是让我们掌握数据库系统的原理、技术,将理论与实际相结合,应用现有的数据库管理系统软件,规范、科学地完成一个设计与实现。
其实说心里话,在实训数据库之前我对数据库这门课程是既抗拒又害怕的。
从第一节课开始,我在很认真的听老师讲课,而且自己也非常有信心学好这门课程。
但是上了一个月的课程后我发现,对于数据库我学的完全是迷迷糊糊,对于查询命令学的也是似懂非懂,后来老师授课的内容开始越积越多,我不会的没弄懂的也越积越多,最后开始害怕这门课上课,更害怕这门课考试。
抱着不想挂科的心理,在数据库实训之前,我抽了一个星期的时间仔细地看了书,并且把课后习题仔仔细细地重新做了一遍,对这本书的整个知识体系在脑袋里面有个大概的印象,后来老师告诉我们这次实训的目标,于是我对这次实训工作胸中就开始有大致的轮廓。
这次我们实训的内容是从数据库、数据表的创建和修改开始的,我知道了:表是建立关系数据库的基本结构,用来存储数据具有已定义的属性,在表的操作过程中,有查看表信息、查看表属性、修改表中的数据、删除表中的数据及修改表和删除表的操作。
从实训中让我更明白一些知识,表是数据最重要的一个数据对象,表的创建好坏直接关系到数数据库的成败,表的内容是越具体越好,但是也不能太繁琐,以后在实际应用中多使用表,对表的规划和理解就会越深刻。
我们实训的另一个内容是数据库的约束、视图、查询。
查询语句的基本结构,和简单SELECT语句的使用,多表连接查询。
而在视图的操作中,也了解到了视图是常见的数据库对象,是提供查看和存取数据的另一种途径,对查询执行的大部分操作,使用视图一样可以完成。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
select*from 成绩表 select*from 学生信息表
1 存储过程的定义 存储过程(procedure)类似于C语言中的函数 用来执行管理任务或应用复杂的业务规则 存储过程可以带参数,也可以返回结果
存储过程可以包含数据操纵语句、变量、逻辑 控制语句等 2 存储过程的优点 执行速度更快 存储过程只在创造时进行编译即可,以后每次执行存储过程都不需再重新编译,而我们通常使用的SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。 允许模块化程序设计 当对数据库进行复杂操作时(如对多个表进行 Update,Insert,Query,Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。可以极大的提高数据 库的使用效率,减少程序的执行时间,这一点在较大数据量的数据库的操作中是非常重要的。 提高系统安全性
int sum(int a,int b) { int s; s =a+b; return s ; }
存储过程相当于C语言中的函数
存储过程 -------- -------- --------
单个 SELECT 语句 SELECT 语句块 SELECT语句与逻辑控制语句 可以包含 可设定只有某此用户才具有对指定存储过程的使用权存储过程 减少网络流通量
3、存储过程的分类
3.1 系统存储过程 由系统定义,存放在master数据库中 系统存储过程的名称都以“sp_”开头或”xp_”开头 3.2 用户自定义存储过程 由用户在自己的数据库中创建的存储过程
4、常用的系统存储过程 4.1 系统存储过程列表 系统存储过程 说明 sp_databases 列出服务器上的所有数据库。
sp_helpdb 报告有关指定数据库或所有数据库的信息
sp_renamedb 更改数据库的名称
sp_tables 返回当前环境下可查询的对象的列表
sp_columns 回某个表列的信息
sp_help 查看某个表的所有信息
sp_helpconstraint 查看某个表的约束
sp_helpindex 查看某个表的索引
sp_stored_procedures 列出当前环境中的所有存储过程。
sp_password 添加或修改登录帐户的密码。
sp_helptext 显示默认值、未加密的存储过程、用户定义的存储
过程、触发器或视图的实际文本。
4.2 调用常用的系统存储过程 EXECsp_databases --列出当前系统中的数据库 EXECsp_renamedb'Northwind','Northwind1'--修改数据库的名称(单用户访问)
USE stuDB --当前数据库中查询的对象的列表 GO EXECsp_tables--返回某个表列的信息
EXECsp_columns stuInfo --返回某个表列的信息 EXECsp_help stuInfo --查看表stuInfo的信息 EXECsp_helpconstraint stuInfo --查看表stuInfo的约束 EXECsp_helpindex stuMarks --查看表stuMarks的索引 EXECsp_helptext'view_stuInfo_stuMarks'--查看视图的语句文本 EXECsp_stored_procedures--查看当前数据库中的存储过程 4.3 调用常用的扩展存储过程:xp_cmdshell 可以执行DOS命令下的一些的操作,以文本行方式返回任何输出 调用语法: EXECxp_cmdshell DOS命令[NO_OUTPUT]
【案例分析】创建数据库bankDB,要求保存在D:\bank USE master GO
EXECxp_cmdshell'mkdir d:\bank',no_output --创建文件夹D:\bank IFEXISTS(SELECT*FROM sysdatabasesWHEREname='bankDB') DROPDATABASE bankDB GO CREATEDATABASE bankDB ( … )
GO--查看文件夹D:\bank
EXECxp_cmdshell'dir D:\bank\'--查看文件
5、创建存储过程 5.1 定义存储过程的语法 createproc[edure] 存储过程名 @参数 数据类型= 默认值output, ……, @参数n 数据类型= 默认值output AS SQL语句 GO 参数可选 参数分为输入参数、输出参数 输入参数允许有默认值 5.2 创建不带参数的存储过程 【问题】 请创建存储过程,查看本次考试平均分以及未通过考试的学员名单
说明:笔试和机试都通过了60分才算通过。
--创建不带参数的存储过程 createprocedure proc_stu AS declare @avgwri float declare @avglab float
select @avgwri=avg(笔试成绩),@avglab=avg(上机成绩)from 成绩
表 --笔试平均分和机试平均分变量 print'笔试成绩分数='+convert(varchar(10),@avgwri) print'上机成绩分数='+convert(varchar(10),@avglab) if @avgwri>70 and @avglab>70 --显示考试成绩的等级 print'本班成绩:优秀' else print'本班成绩:较差'--显示未通过的学员 print'---------------------------' print' 参加考试不及格的学生 '
select a.学生姓名,a.学号,b.笔试成绩,b.上机成绩from 学生信息表as a innerjoin 成绩表as b on a.学号=b.学号where b.笔试成绩<60
or b.上机成绩<60 GO
5.3 调用存储过程 execute(执行)语句用来调用存储过程 调用的语法: EXEC 过程名 [参数] EXEC proc_stu 5.4带参数的存储过程 存储过程的参数分两种:输入参数、输出参数 输入参数:用于向存储过程传入值,类似C语言的按值传递;
输出参数:用于在调用存储过程后,返回结果,类似C语言的按引用传递;
【问题】 修改上例:由于每次考试的难易程度不一样,每次笔试和机试的及格线可能随时变化(不再是分),这导致考试的评判结果也相应变化。 说明:根据试卷的难度,我们希望笔试和机试的及格线应该是随时变化的,而不
是固定的60分。 【分析】 在述存储过程添加个输入参数:
@writtenPass 笔试及格线
@labPass 机试及格线 --带输入参数的存储过程 createprocedure proc_stu2
int sum (int a, int b) { int s; s=a+b; return s; }
c=sum(5, 8) 传入参数
值
返回结果 @writtenPass int,--输入参数:笔试及格线 @labPass int--输入参数:机试及格线 AS print'========================='
print'参加考试不及格的学生'
select a.学生姓名,a.学号,b.笔试成绩,b.上机成绩from 学生信息表as a --查询没有通过考试的学员 innerjoin 成绩表as b on a.学号=b.学号 where b.笔试成绩<@writtenpass or b.上机成绩<@labpass GO
调用带参数的存储过程 --假定本次考试机试偏难,机试的及格线定为分,笔试及格线定为分
--机试及格线降分后,李斯文(分)成为“漏网之鱼”了 exec proc_stu2 60,55 --或这样调用: EXEC proc_stu2 @labPass=55,@writtenPass=60
5.5 带输入参数的默认值 问题: 如果试卷的难易程度合适,则调用者还是必须如此调用:
EXEC proc_stu2 60,60,比较麻烦 这样调用就比较合理: EXEC proc_stu2 55 --笔试及格线分,机试及格线默认为分
EXEC proc_stu2 --笔试和机试及格线都默认为标准的分 createprocedure proc_stu3 @writtenPass int=60,--笔试及格线:默认为分
@labPass int=60 --机试及格线:默认为分