--存储过程--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. Hadoop 部署之 Hive (五)

    目录 一.Hive 简介 1.什么是 Hive 2.为什么使用 Hive 3.Hive 的特点 4.Hive 的架构 二.Hive 安装 1.MySQL 安装(datanode01) 2.MySQL ...

  2. beego conf配置文件

    1. 多个配置文件通过include引入 自定义配置文件mysql.conf 在app.conf 中引入mysql.conf include "mysql.conf"

  3. POJ 1734:Sightseeing trip

    Sightseeing trip Time Limit: 1000MS Memory Limit: 65536K Total Submissions: Accepted: Special Judge ...

  4. 手把手教你安装 FastAdmin 到虚拟主机 (phpStudy)

    手把手教你安装 FastAdmin 到虚拟主机 (phpStudy)原文: https://forum.fastadmin.net/thread/2524 下载 FastAdmin下载 FastAdm ...

  5. nginx 转发tcp连接

    背景:公司有一套工作流服务(jira,confluence,bitbucket),目前jira,confluence配置的是从nginx网关进行转发,bitbucket配置的是直接解析到该主机,现在计 ...

  6. POJ3311 Hie with the Pie 【状压dp/TSP问题】

    题目链接:http://poj.org/problem?id=3311 Hie with the Pie Time Limit: 2000MS   Memory Limit: 65536K Total ...

  7. std::unique_lock与std::lock_guard分析

    背景 C++多线程编程中通常会对共享的数据进行写保护,以防止多线程在对共享数据成员进行读写时造成资源争抢,导致程序出现未定义或异常行为.通常的做法是在修改共享数据成员时进行加锁(mutex).在使用锁 ...

  8. java开源APM概要

      候选APM naver/pinpoint(github上2148个star) 韩国的一个公司开源的,有待评估使用情况,就是整体还不是JDK8,有些还是有点费劲,技术上采用agent的方式,对jav ...

  9. 【数据结构】P1449 后缀表达式

    [题目链接] https://www.luogu.org/problem/P1449 [题目描述] 所谓后缀表达式是指这样的一个表达式:式中不再引用括号,运算符号放在两个运算对象之后,所有计算按运算符 ...

  10. IntelliJ IDEA热部署插件JRebel免费激活图文教程(持续更新)转载

    之前教了大家如何免费激活IDEA,大家学会了吗?今天再来教大家如何免费激活JRebel插件,实现真正的热部署,无论是改了代码片段还是配置文件,都可以做到不用重新启动就生效,这种酸爽,谁用谁知道! 这次 ...