简单sql存储过程实例、储过程实战
学习分享必看: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存储过程实例、储过程实战相关推荐
- SQL存储过程实例具体解释
SQL存储过程实例具体解释 本文用3个题目,从建立数据库到创建存储过程,具体解说数据库的功能. 题目1 学校图书馆借书信息管理系统建立三个表: 学生信息表:student 字段名称 数据类型 说明 s ...
- java sql函数_Java调用Sql存储过程实例讲解
1.使用不带参数的存储过程 使用 JDBC 驱动程序调用不带参数的存储过程时,必须使用 call SQL 转 义序列.不带参数的 call 转义序列的语法如下所示: {call procedure-n ...
- mysql简单的存储过程实例_mysql存储过程简单实例
MySql存储过程简单实例: /********************* 创建表 *****************************/ delimiter // DROP TABLE if ...
- mysql存储过程if多命令_MySQL存储过程if-存储过程中的if-db2存储过程if多条件
存储过程的if,else怎幺写? Oracle 是下面这种写法: IF testvalue > 100 THEN dbms_output.put_line( '100+' ); ELSIF te ...
- 9.SQL存储过程实例详解
本文用3个题目,从建立数据库到创建存储过程,详细讲解数据库的功能. 题目1 学校图书馆借书信息管理系统建立三个表: 学生信息表:student 字段名称 数据类型 说明 stuID char(10) ...
- 详细实例全面解析SQL存储过程
存储过程(Stored Procedure),是一组为了完成特定功能的SQL 语句,类似一门程序设计语言,也包括了数据类型.流程控制.输入和输出和它自己的函数库.存储过程可以说是一个记录集,它是由一些 ...
- SQL 存储过程 procedure 讲解+代码实例
文章目录 1. 存储过程概述 2. 创建存储过程 create procedure 2.1. 参数 in.out.inout 3. 调用存储过程 call 4. 查看存储过程 4.1. 查看存储过程的 ...
- mysql5.7存储过程实例_MySQL 存储过程简单实例
1.创建实例数据库 CREATE DATABASE procdb DEFAULT CHARSET utf8; USE procdb; 2.创建要使用的表 CREATE TABLE tb ( id IN ...
- MySQL实验7存储过程_mysql的总结7--存储过程-阿里云开发者社区
1.定义:存储过程是一组为了完成某个特定功能而编写的SQL程序集. 2.优点: <1>.通过把处理封装在简单易用的单元中,简化复杂的操作. <2>.提高性能.使用存储过程比使用 ...
- python封装sql脚本_pymysql的简单封装代码实例
这篇文章主要介绍了pymysql的简单封装代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 #coding=utf-8 #!/usr/bin/ ...
最新文章
- 如何使用有限的数据来训练 GANs?
- python计算学生平均年龄_CodeSalt | Python解决按学生年龄排序的实际问题
- Python.Paste指南之Deploy(1)-概念
- 用神经网络分类奇数和偶数
- java学习路线_java学习路线_我的入坑路
- 成功更新至Win8.1 update
- php5.4 session配置,Session
- 快速构建Windows 8风格应用33-构建锁屏提醒
- asp网站配置错误解决汇总_1
- 博导眼里本科生的科研能力:“他们还在玩泥巴”
- 网络编程 socket介绍
- Docker基本命令入门
- 7-5 抓老鼠啊~亏了还是赚了? (20 分)
- Centos7.2下安装redis通用键值命令
- 海航通信启动通信+大数据战略 海航宽带首次发布
- Java之拦截器与过滤器
- 代码检查、评审、单元测试工具 大搜集
- PR(Adobe Premiere Pro)软件基础知识
- Maven配置文件示例
- android应用程序耗电,Android的十大耗电量应用程序,在软件中排名第一