博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
存储过程和触发器
阅读量:5998 次
发布时间:2019-06-20

本文共 922 字,大约阅读时间需要 3 分钟。

1、创建一个名为score_sc的触发器,要求输入的成绩必须在0到100之间

create trigger score_sc  --trigger触发器的标志,名字为score_sc的触发器

on sc                    --作用在sc表之上

for insert,update        --操作范围是插入和更新

as declare @score int       --declare用于声明变量 

@score声明的变量,int为声明类型 begin                    --每一个begin要对应一个end否则会报错,本触发器三个begin和三个end

select @score = grade from inserted --声明变量等于grade,inserted为查如何更新的标志符

if @score not between 0 and 100     --触发器的条件

begin rollback                            --回滚

print '成绩输入不合法,请重新输入'

end

else

begin print '操作成功!'

end

end   

2、创建一个存储过程根据课程名查询选修这门课的人数                            

 create proc ssc_3          --procedure为存储过程的标志,ssc_3为存储过程的名字

@cnumber char(20),@ccount int output   --声明一个变量@cname 类型char,变量@ccount,类型为int,output为输出

as                                     --char的长度如果不够的话查询出来的结果会是0

select @ccount=count(*) from sc,course

where sc.cno=course.cno and   --为声明的变量赋值 go                                 

以下语句执行创建的存储过程,下面三个语句要一起执行,否则无法得到结果

declare @ccount int            

exec ssc_3 '数据库',@ccount output  --exec为执行的标识符,ssc_6为存储过程的名字,数据库为变量@ccount的值

select '选修人数是:',@ccount

转载于:https://www.cnblogs.com/goforitjava/p/3478505.html

你可能感兴趣的文章
我的设计模式:从模版设计模式谈到建造者模式
查看>>
RIP动态路由协议配置思路及原理
查看>>
修改防火墙策略设置
查看>>
免费OA的选型遵循的原则
查看>>
京东到家基于netty与websocket的实践
查看>>
对新入门程序员,有用的几点建议!
查看>>
计算机二级报名步骤
查看>>
iphone 6s pp助手 越狱
查看>>
用BCV备份Oracle数据库
查看>>
Oracle 常用的dump
查看>>
下载源代码编译安装
查看>>
psql无法执行 和启动报错
查看>>
lua 简单实现 面向对象
查看>>
如何更改SVN 用户名
查看>>
条件语句练习-比分预测
查看>>
货物管理系统(数据结构顺序表)
查看>>
WIN 7下硬盘安装Fedora 17最详细教程
查看>>
老外超牛X的一句话***
查看>>
centos升级python(从2.6.6升级到2.7.8)
查看>>
PHP - 如何在HTML中格式化显示JSON数据
查看>>