--存储过程--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. Flutter 的url_launcher简介

    url_launcher是用于在移动平台中启动URL的Flutter插件,适用于IOS和Android平台.他可以打开网页,发送邮件,还可以拨打电话. github地址:https://github. ...

  2. Tracking of Features and Edges

    目录 Joint Tracking of Features and Edges Joint Tracking of Features and Edges 1. LK光流 基本LK光流运动假设: \[ ...

  3. SpringCloud 与 Dubbo区别

    总览   Dubbo SpringCloud 服务注册中心 Zookeeper Spring Cloud Netfix Eureka 服务调用方式 RPC REST API 服务监控 Dubbo-mo ...

  4. 【AMAD】django-crispy-forms -- 不要再重复编写Django Form了!

    动机 简介 个人评分 动机 这个APP提供了一个template tag和一个template filter,让你可以在模版中快速渲染表单. 简介 django-crispy-forms1可以看作是d ...

  5. centos7服务搭建常用服务配置之二:Rsync+sersync实现数据实时同步

    目录 1.RSYNC数据备份 1.1 rsync服务简介 1.2 rsync特点和优势 1.3 rysnc运行模式简介 1.4 数据同步方式 2 Rsync实验测试 2.1 实验环境说明 2.2 服务 ...

  6. Netty源码剖析-业务处理

    参考文献:极客时间傅健老师的<Netty源码剖析与实战>Talk is cheap.show me the code! ----主线:worker thread 触发pipeline.fi ...

  7. SpringBoot导入mail依赖报错

    报错:Missing artifact org.springframework.boot:spring-boot-starter-mail:jar:2.0.3 之前导入log4j时报的一样的错误,最后 ...

  8. Eureka【故障演练分析】

    1.应用服务启动前不可用 假设eureka server服务在client应用服务启动之前挂掉,或者没有启动,这时应用服务依然可以正常启动,但是会有报错信息: 2019-10-13 14:40:41. ...

  9. java实现4种内部排序

    两种插入类排序: 直接插入排序: public static void insertSort(int[] arr, int len){ for(int i=1; i<len; i++){ int ...

  10. 5-MySQL DBA笔记-开发技巧

    第5章 开发技巧 本章将介绍一些和数据库相关的开发技巧.由于开发领域很广,这里只选取部分比较常见的小技巧.5.1 存储树形数据 有时我们需要保存一些树形的数据结构,比如组织架构.话题讨论.知识管理.商 ...