学习分享必看:javacto.taobao.com

实例1:只返回单一记录集的存储过程。

银行存款表(bankMoney)的内容如下

Id

userID

Sex

Money

001

Zhangsan

30

002

Wangwu

50

003

Zhangsan

40

要求1:查询表bankMoney的内容的存储过程

create procedure sp_query_bankMoney
as
select * from bankMoney
go
exec sp_query_bankMoney

注*  在使用过程中只需要把中的SQL语句替换为存储过程名,就可以了很方便吧!

实例2(向存储过程中传递参数):

加入一笔记录到表bankMoney,并查询此表中userID= Zhangsan的所有存款的总金额。

Create proc insert_bank @param1 char(10),@param2 varchar(20),@param3 varchar(20),@param4 int,@param5 int output
with encryption ---------加密
as
insert bankMoney (id,userID,sex,Money)
Values(@param1,@param2,@param3, @param4)
select @param5=sum(Money) from bankMoney where userID='Zhangsan'
go
在SQL Server查询分析器中执行该存储过程的方法是:
declare @total_price int
exec insert_bank '004','Zhangsan','男',100,@total_price output
print '总余额为'+convert(varchar,@total_price)
go

在这里再啰嗦一下存储过程的3种传回值(方便正在看这个例子的朋友不用再去查看语法内容):

1.以Return传回整数

2.以output格式传回参数

3.Recordset

传回值的区别:

output和return都可在批次程式中用变量接收,而recordset则传回到执行批次的客户端中。

实例3:使用带有复杂 SELECT 语句的简单过程

  下面的存储过程从四个表的联接中返回所有作者(提供了姓名)、出版的书籍以及出版社。该存储过程不使用任何参数。

USE pubs
IF EXISTS (SELECT name FROM sysobjects
         WHERE name = 'au_info_all' AND type = 'P')
   DROP PROCEDURE au_info_all
GO
CREATE PROCEDURE au_info_all
AS
SELECT au_lname, au_fname, title, pub_name
   FROM authors a INNER JOIN titleauthor ta
      ON a.au_id = ta.au_id INNER JOIN titles t
      ON t.title_id = ta.title_id INNER JOIN publishers p
      ON t.pub_id = p.pub_id
GO

  au_info_all 存储过程可以通过以下方法执行:

EXECUTE au_info_all

实例4:使用带有参数的简单过程

CREATE PROCEDURE au_info
   @lastname varchar(40),
   @firstname varchar(20)
AS
SELECT au_lname, au_fname, title, pub_name
   FROM authors a INNER JOIN titleauthor ta
      ON a.au_id = ta.au_id INNER JOIN titles t
      ON t.title_id = ta.title_id INNER JOIN publishers p
      ON t.pub_id = p.pub_id
   WHERE  au_fname = @firstname
      AND au_lname = @lastname
GO

  au_info 存储过程可以通过以下方法执行:

EXECUTE au_info 'Dull', 'Ann'
-- Or
EXECUTE au_info @lastname = 'Dull', @firstname = 'Ann'
-- Or
EXECUTE au_info @firstname = 'Ann', @lastname = 'Dull'

实例5:使用带有通配符参数的简单过程

CREATE PROCEDURE au_info2
@lastname varchar(30) = 'D%',
@firstname varchar(18) = '%'
AS
SELECT au_lname, au_fname, title, pub_name
FROM authors a INNER JOIN titleauthor ta
   ON a.au_id = ta.au_id INNER JOIN titles t
   ON t.title_id = ta.title_id INNER JOIN publishers p
   ON t.pub_id = p.pub_id
WHERE au_fname LIKE @firstname
   AND au_lname LIKE @lastname
GO

  au_info2 存储过程可以用多种组合执行。下面只列出了部分组合:

EXECUTE au_info2
-- Or
EXECUTE au_info2 'Wh%'
-- Or
EXECUTE au_info2 @firstname = 'A%'
-- Or
EXECUTE au_info2 '[CK]ars[OE]n'
-- Or
EXECUTE au_info2 'Hunter', 'Sheryl'
-- Or
EXECUTE au_info2 'H%', 'S%'

简单sql存储过程实例、储过程实战相关推荐

  1. SQL存储过程实例具体解释

    SQL存储过程实例具体解释 本文用3个题目,从建立数据库到创建存储过程,具体解说数据库的功能. 题目1 学校图书馆借书信息管理系统建立三个表: 学生信息表:student 字段名称 数据类型 说明 s ...

  2. java sql函数_Java调用Sql存储过程实例讲解

    1.使用不带参数的存储过程 使用 JDBC 驱动程序调用不带参数的存储过程时,必须使用 call SQL 转 义序列.不带参数的 call 转义序列的语法如下所示: {call procedure-n ...

  3. mysql简单的存储过程实例_mysql存储过程简单实例

    MySql存储过程简单实例: /********************* 创建表 *****************************/ delimiter // DROP TABLE if ...

  4. mysql存储过程if多命令_MySQL存储过程if-存储过程中的if-db2存储过程if多条件

    存储过程的if,else怎幺写? Oracle 是下面这种写法: IF testvalue > 100 THEN dbms_output.put_line( '100+' ); ELSIF te ...

  5. 9.SQL存储过程实例详解

    本文用3个题目,从建立数据库到创建存储过程,详细讲解数据库的功能. 题目1 学校图书馆借书信息管理系统建立三个表: 学生信息表:student 字段名称 数据类型 说明 stuID char(10) ...

  6. 详细实例全面解析SQL存储过程

    存储过程(Stored Procedure),是一组为了完成特定功能的SQL 语句,类似一门程序设计语言,也包括了数据类型.流程控制.输入和输出和它自己的函数库.存储过程可以说是一个记录集,它是由一些 ...

  7. SQL 存储过程 procedure 讲解+代码实例

    文章目录 1. 存储过程概述 2. 创建存储过程 create procedure 2.1. 参数 in.out.inout 3. 调用存储过程 call 4. 查看存储过程 4.1. 查看存储过程的 ...

  8. mysql5.7存储过程实例_MySQL 存储过程简单实例

    1.创建实例数据库 CREATE DATABASE procdb DEFAULT CHARSET utf8; USE procdb; 2.创建要使用的表 CREATE TABLE tb ( id IN ...

  9. MySQL实验7存储过程_mysql的总结7--存储过程-阿里云开发者社区

    1.定义:存储过程是一组为了完成某个特定功能而编写的SQL程序集. 2.优点: <1>.通过把处理封装在简单易用的单元中,简化复杂的操作. <2>.提高性能.使用存储过程比使用 ...

  10. python封装sql脚本_pymysql的简单封装代码实例

    这篇文章主要介绍了pymysql的简单封装代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 #coding=utf-8 #!/usr/bin/ ...

最新文章

  1. 如何使用有限的数据来训练 GANs?
  2. python计算学生平均年龄_CodeSalt | Python解决按学生年龄排序的实际问题
  3. Python.Paste指南之Deploy(1)-概念
  4. 用神经网络分类奇数和偶数
  5. java学习路线_java学习路线_我的入坑路
  6. 成功更新至Win8.1 update
  7. php5.4 session配置,Session
  8. 快速构建Windows 8风格应用33-构建锁屏提醒
  9. asp网站配置错误解决汇总_1
  10. 博导眼里本科生的科研能力:“他们还在玩泥巴”
  11. 网络编程 socket介绍
  12. Docker基本命令入门
  13. 7-5 抓老鼠啊~亏了还是赚了? (20 分)
  14. Centos7.2下安装redis通用键值命令
  15. 海航通信启动通信+大数据战略 海航宽带首次发布
  16. Java之拦截器与过滤器
  17. 代码检查、评审、单元测试工具 大搜集
  18. PR(Adobe Premiere Pro)软件基础知识
  19. Maven配置文件示例
  20. android应用程序耗电,Android的十大耗电量应用程序,在软件中排名第一

热门文章

  1. 软件需求分析报告模板
  2. python使用matplotlib可视化矢量流场图、使用streamplot函数可视化矢量流场图、矢量流场图包含坐标和方向
  3. 关于lisp的一些资源
  4. 推荐系统项目实战-电影推荐系统
  5. python-数据结构-大学生-航空订票系统
  6. Java面试题全集中
  7. matlab画空间直线,空间直线x y=z怎么画
  8. 飞机大战java_Java飞机大战
  9. Linux内核开发-入门篇
  10. 大数据技术_ 基础理论 之 数据采集与预处理