SQL Server 第四章 存储过程(Procedure),触发器(Trigger),数据完整性(Data Integrity)
use electric
go --变量
--局部变量的声明格式
--declare @局部变量名 数据类型
--局部变量赋值
declare @littlepage int
set @littlepage=18
print cast(@littlepage as varchar(255)) declare @little varchar(255)
select @little=warehouse from Stock
print @little --
--存储过程
-- --if else 语法
--在电力抢修工程数据库中,如果stock表中存在库存量低于1的物资,就显示文本:the amount is not enough;否则显示所有物资信息。
if exists (select * from stock where amount < 1)
print 'the amount is not enough'
else
begin
select * from stock
end --while语法
--将stock表中所有物资单价增加10%,直到有一个物资单价超过15000或单价总和超过50000为止。
while (select sum(unit) from stock) <50000
begin
update stock set unit=unit*1.1
if exists(select * from stock where unit>15000)
break
else
continue
end --wait delay/time 语法
WAITFOR DELAY '00:00:05'
SELECT * FROM stock
WAITFOR TIME '11:15:20'
SELECT * FROM salvaging --case语法
/*用CASE语句格式一实现:在对stock表的查询中,当仓库号的值是“供电局1号仓库”、“供电局2号仓库”
、“供电局3号仓库”时分别返回“北京”、“上海”、“广州”,否则返回“未知”。*/
select mat_no,mat_name,speci,amount,unit,total,
warehouse=
case warehouse
when '供电局1#仓库' then '北京'
when '供电局2#仓库' then '上海'
when '供电局3#仓库' then '广州'
else '未知'
end
from stock --创建一个简单的存储过程,用于返回stock表中的所有记录。
CREATE PROCEDURE exp1
AS
SELECT * FROM stock exec exp1 --创建一个存储过程,通过输入的仓库名称显示出该仓库的所有库存物资信息。
create procedure exp2
@ckmc varchar(255)
as
select * from stock where warehouse=@ckmc exec exp2 '供电局1#仓库' --创建一个带输入参数的存储过程,向stock表中添加一个新的数据行。
create procedure exp3
@mat_no varchar(255),@mat_name varchar(255),@speci varchar(255),@warehouse varchar(255),@amount int,@unit decimal(8,2),@total decimal(8,2)
as
insert stock values(@mat_no,@mat_name,@speci,@warehouse,@amount,@unit,@total) exec exp3 'm014','护套绝缘','BVV-130','供电局5#仓库',500,100.5,100020.00 -- 为了确保Create命令能成功执行,可以在Create Procedure之前执行如下语句:
IF EXISTS (SELECT name FROM sysobjects WHERE name='exp3' and type='P')
DROP PROCEDURE exp3
GO --创建一个带默认参数的存储过程,通过传递的参数显示物资的名称、规格、项目名称、
--是否按期完工等信息,如果没有提供参数,则使用预设的默认值。
CREATE PROCEDURE exp4
@mname varchar(50)='%绝缘%', @pno int=20100001
AS
SELECT mat_name,speci,prj_name,prj_status
FROM stock, salvaging, out_stock
WHERE stock.mat_no=out_stock.mat_no
and salvaging.prj_no=out_stock.prj_no
and mat_name like @mname
and salvaging.prj_no=@pno exec exp4 --创建一个存储过程,求某个抢修工程领取物资的总数量。 create procedure exp5
@pn varchar(255),@sum int output
as
select @sum=sum(amount) from Out_Stock WHERE prj_no=@pn DECLARE @total int
EXECUTE exp5 '', @total OUTPUT
PRINT '该项目领取物资总量为:'+ CAST(@total AS varchar(20)) --23页ppt
--创建一个存储过程,根据输入的工程部门及起始时间段,统计
--汇总该部门在对应时间段内所参与抢修的工程项目总数以及领
--取物资的总成本,并要求输出 CREATE PROCEDURE exp6
@department varchar(50),@start_date datetime,@end_date datetime, @count_prj int OUTPUT, @sum_cost decimal(18,2) OUTPUT
As
SELECT @count_prj=COUNT(salvaging.prj_no),
@sum_cost=SUM(Out_stock.amount*Stock.unit)
FROM salvaging,out_stock,stock
WHERE out_stock.prj_no =salvaging.prj_no
and out_stock.mat_no =Stock.mat_no
and department =@department
and get_date between @start_date and @end_date DECLARE @prjcounts int,@sumcosts decimal(18,2)
EXEC exp6 '工程2部','2011-1-1','2011-1-31',@prjcounts OUTPUT,@sumcosts OUTPUT
PRINT '该部门参与抢修工程项目'+ CAST(@prjcounts AS varchar(20))+'个,总成本为'+CAST(@sumcosts AS varchar(20))
SQL Server 第四章 存储过程(Procedure),触发器(Trigger),数据完整性(Data Integrity)的更多相关文章
- MS SQL Server之光标、存储过程和触发器
光标 通常数据库操作被认为是以数据集为基础的操作,但是光标被用于以记录为单位来进行操作,来获取数据库中的数据的子集.光标一般用于过程化程序里的嵌入的SQL语句. 对光标的定义如下: DECLARE C ...
- SQL Server查询数据库所有存储过程、触发器、索引信息SQL分享
1. 查询所有存储过程 1 select Pr_Name as [存储过程], [参数]=stuff((select ','+[Parameter] 2 from ( 3 select Pr.Name ...
- sql server 常用的系统存储过程
系统存储过程 说明 sp_databases 列出服务上的所有数据库 sp_helpdb 报告有关指定数据库或所有数据库的信息 sp_renamedb 更改数据库的名称 sp_tables 返回当 ...
- Sql Server 带参数的存储过程执行方法
Sql Server 带参数的存储过程执行方法 Visual C# 动态操作 SQL Server 数据库实例教程(4):带参数的存储过程执行方法 上一篇文章介绍了带参数的SQL语句执行方法和不带参数 ...
- [转] sql server 跨数据库调用存储过程
A库存储过程: create PROCEDURE [dbo].[spAAAForTest] ( ) =null , ) =null ) AS BEGIN select N'A' AS a , N'B' ...
- SQL Server 限制IP登陆(登陆触发器运用)
原文:SQL Server 限制IP登陆(登陆触发器运用) 一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 实现代码(SQL Codes) 补 ...
- SQL Server技术问题之存储过程与sql语句的优缺点
优点: 1. 允许模块化程序设计.2.可维护性高,只需创建存储过程一次并将其存储在数据库中,以后即可在程序中调用该过程任意次.存储过程可独立于程序源代码而单独修改,而不需要更改.测试以及重新部署程序集 ...
- SQL SERVER 2008破解加密存储过程(修正存储过程过长解密出来是空白的问题)
SQLServer2005里使用with encryption选项创建的存储过程仍然和sqlserver2000里一样,都是使用XOR进行了的加密.和2000不一样的是,在2005的系统表syscom ...
- SQL Server 数据库的维护(二)__触发器
--维护数据库-- --触发器-- --概述: 触发器是一种特殊类型的存储过程,用来强制执行业务规则.在调用执上,触发器不能像存储过程那样可以由用户通过T-SQL语句直接调用,而是需要有数据库所发生的 ...
随机推荐
- request.getParameterNames()和request.getParameterValues()
request.getParameterNames()方法是将发送请求页面中form表单里所有具有name属性的表单对象获取(包括button).返回一个Enumeration类型的枚举. 通过Enu ...
- 再一波Python实战项目列表
前言: 近几年Python可谓是大热啊,很多人都纷纷投入Python的学习中,以前我们实验楼总结过多篇Python实战项目列表,不但有用还有趣,最主要的是咱们实验楼不但有详细的开发教程,更有在线开发环 ...
- windows环境在本地配nginx
本地搭建了前端项目,但奈何有时候需要https访问的需求,所以做了一个尝试在本地(windows环境)下配置nginx,最终的效果就是 搭建的时候,遇到两个问题: 第一个是如果要在本地搭建https, ...
- BDD中数据的类型及处理方法(python)
BDD中提供了两种数据类型,table和text,以下是数据的文档介绍,最后有我的两个小例子. 1.class behave.model.Table(headings, line=None, rows ...
- 快速排序 之添加复合插入排序和原始序列取中值左pivot
quicksort中,当n小于一定值时,排序效率就比直接插入排序底了,所以,此时就不要再递归下去了,直接插入排序好了:快速的原理就是因为折半递归,所以初始pivot应该有个好一点的选择,这里在原序列左 ...
- win 下 python ImportError: No module named requests
第一次弄爬虫,报库找不到,网上找了半天,一般都让都让改成绝对路径...那不是饮鸩止渴嘛. 然后 在无意中发现,不需要控制台输入pip命令,因为不是在Linux下啊,,win下直接在pycharm里添加 ...
- JavaWeb初级进阶高级学习方向计划
阶段1 语言基础 课程一.Java负基础扫盲课 1.初识Java 本课程从java开发环境配置开始,讲解了java语法基础 .类和面向对象.面向对象编程三大特性:封装.继承.多态.建议零基础学员从本课 ...
- Oauth2.0安全问题浅谈
大家如果对Oauth还不是很了解可以先看下这篇文章https://www.cnblogs.com/maoxiaolv/p/5838680.html 我这篇博客主要是总结一下安全测试过程中遇到Oauth ...
- 关于babel官网的学习
提起babel,前端er大概都不陌生.但是为什么要有babel呢?解决了什么问题?怎么使用babel呢?注意点在哪?以下就从这几个方面总结一下我关于babel学习的结果吧. 为什么要有babel呢? ...
- 洛谷P2611 信息传递
并查集裸题,记录每个点的胜读,取个min就好了 #include<stdio.h> #include<string.h> #include<algorithm> u ...