--存储过程--GO--先编译,再执行
--1.GO:批处理语句,GO之前作为一个批次发送服务器编译执行
USE master
GO
CREATE DATABASE TEST_DB
GO
USE TEST_DB
CREATE TABLE TEST
(ID INT,NAME VARCHAR(10))
GO
INSERT INTO TEST VALUES
(1,'张清瑞'),
(2,'柴铭阳')
GO
--2.存储过程(PROCEDURE)
--类似于C#中的方法(封装,重用:编译1次,反复重用)
--作用:
-- 用来执行复杂的业务功能
--优点:
--<1> 效率高,执行速度快(节省了编译时间)
--<2> 减少网络流量
--<3> 安全性高
--<4> 允许在数据库中实现模块化开发
--1 sql 1000 (效率高) 一条sql语句只编译一次
--1 sql 1行 1000次 需要编译1000次,效率低

--语法 数据库对象
CREATE PROC [EDURE] name
@name1 datatype[=默认值] --in 类型参数 默认
....
@name2 datatype OUTPUT --output 向外传值 实现与return相似的功能
AS --分割存储过程的定义和存储过程体(没有软用)
过程体--t_sql
GO
---------------------------------------------------------------------案例分析-------------------------------------------------------------------------------------
--EG1: 无参的存储过程

--查看销售部(sales)的员工信息
--先编译,再调用
CREATE PROCEDURE EmpsInfo
--无参 不用写参数
--WITH ENCRYPTION --源代码加密
AS
PRINT '销售部(sales)的员工信息如下:'
SELECT * FROM EMP WHERE
DEPTNO=(SELECT DEPTNO FROM DEPT WHERE DNAME='sales')
GO

--执行存储过程
EXEC EmpsInfo--执行存储过程
--查看存储过程源代码 :
exec sp_helptext 'EmpsInfo'

ALTER PROCEDURE EmpsInfo--修改存储过程/解密
AS
PRINT '销售部(sales)的员工信息如下:'
SELECT * FROM EMP WHERE
DEPTNO=(SELECT DEPTNO FROM DEPT WHERE DNAME='sales')
GO
DROP PROCEDURE EmpsInfo--删除存存储过程

--EG2. 带有in类型参数的存储过程
--显示任意部门(参数)的员工信息
CREATE PROCEDURE EmpsInfo
@name varchar(20) --参数in,只有in类型参数有默认值
AS
PRINT @name+'部门的员工信息如下:'
SELECT * FROM EMP WHERE
DEPTNO=(SELECT DEPTNO FROM DEPT WHERE DNAME=@name)
GO
--执行存储过程有in类型
EXEC EmpsInfo @name='sales' -----KEY VALUE
EXEC EmpsInfo 'ACCOUNTING' --按顺序传参
EXEC EmpsInfo --参数会使用默认值,如果没有默认值会报错

--EG3.带有输入(in)和输出(output)两种类型参数的存储过程
--求和 int sum(int a,int b)
CREATE PROC GetSum
@a int=0,--in
@b int=0,
@sum int output --output输出类型参数
AS
SET @sum=@a+@b
GO

--执行过程
--key=value
DECLARE @s int
EXEC GetSum @b=10,@a=20,@Sum=@s output
print @s

--思考:存储过程中可以有return 语句吗?
--可以 return 中断过程执行
--return val,val只能返回的是整数.(退化很少用)

--练习:编写过程,向一个空的测试表插入任意行的数据.
--要求,一次插入的数据不能重复
CREATE TABLE DUMP
(
ID int,
NAME nvarchar(20),
PRICE money
)
CREATE PROC AddData
@rowNum int=100
AS
DECLARE @i int=1
WHILE(@i<=@rowNum)
BEGIN
INSERT INTO DUMP VALUES(@i,NEWID(),@i*0.23+5)
SET @i+1

014.存储过程(sql实例)的更多相关文章

  1. 数据库存储过程 — Sql Server

    Mysql.Oracle等主流关系型数据库基本都支持存储过程,这里使用Sql Server为例进行说明. 存储过程的概念: Sql Server存储过程 SQL Server 中的存储过程是由一个或多 ...

  2. MySQL存储过程使用实例详解

    本文介绍关于在MySQL存储过程游标使用实例,包括简单游标使用与游标循环跳出等方法 例1.一个简单存储过程游标实例 DROP PROCEDURE IF EXISTS getUserInfo $$CRE ...

  3. 教你管理SQL实例系列(1-15)

    全系列转自:51CTO ->jimshu http://jimshu.blog.51cto.com 目录及原本连接如下: 教你管理SQL实例(1)数据库实例 教你管理SQL实例(2)服务启动帐户 ...

  4. 搜索本地网络内所有可用的SQl实例

    '搜索本地网络内所有可用的SQl实例 Dim instance As SqlDataSourceEnumerator = SqlDataSourceEnumerator.Instance Dim dt ...

  5. 存储过程系列之存储过程sql数据库调用和程序代码调用

    1.存储过程,无参数的存储过程 创建无参数存储存储过程 Create Procedure DCEMREMR_TEMPLATEAs SELECT TOP 10 [FILENAME],[FILETITLE ...

  6. 一次性删除数据库所有表和所有存储过程 SQL语句

    一次性删除数据库所有表和所有存储过程 SQL语句 今天转移数据库数据,需要把数据库原来的表和存储过程清空.删除所有的表:如果由于外键约束删除table失败,则先删除所有约束: --/第1步****** ...

  7. Web Services调用存储过程简单实例

    转:http://www.cnblogs.com/jasenkin/archive/2010/03/02/1676634.html Web Services 主要利用 HTTP 和 SOAP 协议使商 ...

  8. 学习《Oracle PL/SQL 实例讲解 原书第5版》----创建账户

    通过readme.pdf创建student账户. 以下用sys账户登录时都是sysdba. 一.PL/SQL 登录oracle. SYS/123  AS SYSDBA 账户名:sys:密码:123:作 ...

  9. 使用CompletionService结合ExecutorService批处理调用存储过程任务实例

    此实例为java多线程并发调用存储过程实例,只做代码记载,不做详细描述 1.线程池构造初始化类CommonExecutorService.java package com.pupeiyuan.go; ...

随机推荐

  1. jprofile 远程监控linux上的jvm

    环境 客户端:win7+jprofiler_windows-x64_10_0_4.exe linux服务器:tomcat7+jdk1.7+jprofiler_linux_10_0_4.sh 一.客户端 ...

  2. [Python[Anaconda & PyTorch]] -- 使用conda 安装 Torch 出现错误 --Windows

    ... (⊙o⊙)… ... 当时具体的错误我没有截图, 用这个命令时 , conda 会报无法在源中找到PyTorch, 还是什么的错误 有很大的一个可能是, 安装的Anaconda 是32 位的, ...

  3. KMP --关于cogs1570 乌力波

    题目链接:http://cogs.pro:8081/cogs/problem/problem.php?pid=vQzXJkgWa [题目描述] 法国作家乔治·佩雷克(Georges Perec,193 ...

  4. A+B Problem Plus and A-B Problem Plus and A*B Problem Plus

    //we have defined the necessary header files here for this problem. //If additional header files are ...

  5. 虚拟机(VM)安装openwrt-koolshare软路由

    ⒈创建虚拟机 **软路由选择Windows操作系统,因为我们需要在PE环境中进行软路由的写入,固件类型选择BIOS,网络类型选择使用仅主机模式网络,虚拟磁盘类型选择IDE[一定要选择IDE模式],SC ...

  6. Educational Codeforces Round 74 (Rated for Div. 2)补题

    慢慢来. 题目册 题目 A B C D E F G 状态 √ √ √ √ × ∅ ∅ //√,×,∅ 想法 A. Prime Subtraction res tp A 题意:给定\(x,y(x> ...

  7. 剑指offer12:求解double类型的浮点数base和int类型的整数exponent的次方。 保证base和exponent不同时为0

    1. 题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方.保证base和exponent不同时为0. 2. 思路和方法 分析: 由于 ...

  8. php7和PHP5对比的新特性和性能优化

    1  抽象语法树( AST) 1)在 PHP5中,从 php 脚本到 opcodes 的执行的过程是: Lexing:词法扫描分析,将源文件转换成 token 流:    Parsing:语法分析,在 ...

  9. MyBatis 示例-动态 SQL

    MyBatis 的动态 SQL 包括以下几种元素: 详细的使用参考官网文档:http://www.mybatis.org/mybatis-3/zh/dynamic-sql.html 本章内容简单描述这 ...

  10. C#学习基础资料记录---字典(Dictionary),时间表示方法(DateTime.Now),文件操作

    1.字典 https://www.cnblogs.com/gengaixue/p/4002244.html 2.时间的表示方法 DateTime.Now的多种用法 https://www.cnblog ...