存储过程和触发器的应用

实验案例三:创建视图

方法一:在图形界面下创建视图(以Myschool数据库为例)

创建一个视图,分别来自三个的表的三个列,并重命名列,生成的视图名为student_info,如下图所示:

通过查询语句查看视图:select * from student_info

方法二:使用语句创建视图(以schoolDB数据库为例)

进行数据库设计的时候,一个表有很多列,我们可以在表上创建视图,只显示指定的列。

Select语句可以作为一个视图

selectSname,sex,Classfromdbo.TStudentwhereClass='网络班'

1、创建视图,筛选行和列

createviewnetstudent

as

selectSname,sex,Classfromdbo.TStudentwhereClass='网络班'

从视图中查找数据:

select*fromnetstudentwheresex='男'

创建视图,更改列的表头,计算列,产生计算列

selectStudentID,Sname,sex,cardID,Birthday,Email,Class

fromdbo.TStudent

2、创建视图,更改列的表头

createviewV_Tstudent1

as

selectStudentID学号,Sname姓名,sex性别,cardID身份证号码,Birthday生日,Class班级fromdbo.TStudent

select*fromV_Tstudent1

以后再去查询的时候就非常方便了。

实验案例四:存储过程

1、常用的系统存储过程

exec sp_databases --列出当前系统中的数据库

exec sp_renamedb 'mybank','bank' --改变数据库名称(单用户访问)

use MySchool

go

exec sp_tables --当前数据库中可查询对象的列表

exec sp_columns student --查看表student中列的信息

exec sp_help student --查看表student的所有信息

exec sp_helpconstraint student --查看表student表的约束

exec sp_helptext view_student_result --查看视图的语句文本

exec sp_stored_procedures --返回当前数据库中的存储过程列表

2、常用的扩展存储过程(在C盘下创建一个文件夹bank)

exec xp_cmdshell 'mkdir c:\bank',no_output --创建文件夹c:\bank

exec xp_cmdshell 'dir c:\bank\' --查看文件

如果执行不了上面的语句,请开启下面的功能。然后再次执行上面的两条语句。

若xp_cmdshell作为服务器安全配置的一部分而被关闭,请使用如下语句启用:

exec sp_configure 'show advanced options', 1 --显示高级配置选项(单引号中的只能一个空格隔开)

go

reconfigure --重新配置

go

exec sp_configure 'xp_cmdshell',1 --打开xp_cmdshell选项

go

reconfigure --重新配置

go

3、用户自定义的存储过程(以schoolDB数据库为例,计算网络管理专业的平均分)

use schoolDB

go

if exists (select * from sysobjects where name='usp_getaverageresult')

drop procedure usp_getaverageresult

go

create procedure usp_getaverageresult

as

declare @subjectid nvarchar(4)

select @subjectid=subjectid from dbo.TSubject where subJectName='网络管理'

declare @avg decimal (18,2)

select @avg=AVG(mark) from dbo.TScore wheresubJectID=@subjectid

print '网络管理专业平均分是:'+convert(varchar(5),@avg)

go

exec usp_getaverageresult

实验案例五:触发器

(Myschool数据库为例)

创建触发器(禁止修改admin表中数据):

create trigger reminder

on admin

for update

as

print '禁止修改,请联系DBA'

rollback transaction

go

执行语句,查看错误信息:

update Admin set LoginPwd='123' where LoginId='benet'

select * from Admin

实验案例六:创建触发器

(Myschool数据库为例)

要求:创建一个触发器,以确保student表中的数据不会被删除。

create trigger stu_del

on student

for delete

as

print '你不具备删除管理员信息的权限'

rollback transaction

go

执行一条delete语句,测试结果。

delete from Student where StudentName='喜洋洋

本文来自企鹅号 - 全球大搜罗媒体

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏PPV课数据科学社区

Android数据库高手秘籍(一)——SQLite命令

要想熟练地操作任何一个数据库,最最基本的要求就是要懂SQL语言,这也是每个程序员都应该掌握的技能。虽说SQL博大精深,要想精通确实很难,但最基本的一些建表命令,...

3855
来自专栏c#开发者

Oracle 开放源代码项目

Oracle 开放源代码项目 这是无数个可扩展、使用以及构建于 Oracle 技术的开放源代码项目中的一个简短的示例。如果您有自己喜欢的开放源代码项目未在此处列...

8408
来自专栏吴柯的运维笔记

部署Cacti监控平台实现网络监控

Cacti是一套基于PHP,MySQL,SNMP及RRDTool开发的网络流量监测图形分析工具。 Cacti是通过 snmpget来获取数据,使用 RRDtoo...

4558
来自专栏别先生

SQLyog图形化l数据库的操作和学习

1:首先SQLyog作为mysql的图形化操作工具,是一个收费的工具,但是在天朝大国,任何收费的软件都可以被破解,具体软件的安装不做多叙述,支持正版,毕竟作为一...

4575
来自专栏文渊之博

SQL Server中的锁的简单学习

简介     在SQL Server中,每一个查询都会找到最短路径实现自己的目标。如果数据库只接受一个连接一次只执行一个查询。那么查询当然是要多快好省的完成工作...

2745
来自专栏杨建荣的学习笔记

浅谈MySQL中的事务隔离级别(r11笔记第86天)

之前写了一篇浅谈事务(一),算是对事务的一个基本认识,今天来简单总结一下事务的隔离级别,虽然是老掉牙的知识点,重温一下还是值得的。 在MySQL中基...

3369
来自专栏杨建荣的学习笔记

MySQL 8.0初体验

从决定安装MySQL 8.0到开始行动,也就不到一个小时的时间,一个小时的时间能干些啥呢,来简单体验下8.0,官网上能看到这个丰富的表情包。

1504
来自专栏文渊之博

T-SQL性能调整(一)--编译和重新编译

概念简介 我们平时所说的查询在SQLServer 中主要有两部分来实现: 编译查询,主要包括了五个环节(缓存查找、分析、代数化、优化、缓存新计划) ?     ...

1889
来自专栏架构师之路

InnoDB并发如此高,原因竟然在这?

《InnoDB行锁,如何锁住一条不存在的记录?》埋了一个坑,没想到评论反响剧烈,大家都希望深挖下去。原计划写写InnoDB的锁结束这个case,既然呼声这么高,...

1503
来自专栏杨建荣的学习笔记

MySQL中insert语句没有响应的问题分析(r11笔记第21天)

今天开发的一个同学问我一个MySQL的问题,说在测试数据库中执行一条Insert语句之后很久没有响应。我一看语句是一个很常规的insert into xxx ...

36612

扫码关注云+社区

领取腾讯云代金券