专栏首页L宝宝聊IT存储过程和触发器的应用

存储过程和触发器的应用

实验案例三:创建视图

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

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

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

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

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

Select语句可以作为一个视图

select Sname,sex,Class from dbo.TStudent where Class='网络班'

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

create view netstudent

as

select Sname,sex,Class from dbo.TStudent where Class='网络班'

从视图中查找数据:

select * from netstudent where sex='男'

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

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

from dbo.TStudent

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

create view V_Tstudent1

as

select StudentID 学号,Sname姓名,sex 性别,cardID 身份证号码,Birthday 生日,Class 班级 from dbo.TStudent

select * from V_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='喜洋洋

本文分享自微信公众号 - L宝宝聊IT(gh_b0e552aa80db),作者:L宝宝

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2017-12-28

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • SQL server 数据库基本插入、删除命令

    L宝宝聊IT
  • Nagios监控系统

    L宝宝聊IT
  • CentOS7.2安装Mysql5.7.13

    (4)更为健壮的复制功能:复制带来了数据完全不丢失的方案,传统金融客户也可以选择使用MySQL数据库。

    L宝宝聊IT
  • SQL语句汇总(一)——数据库与表的操作以及创建约束

    首先,非常感谢大家对上篇博文的支持,真是让本菜受宠若惊,同时对拖了这么久才出了此篇表示抱歉。  

    _DIY
  • mysql查询结果输出到文件

    在mysql命令行环境下执行: sql语句+INTO OUTFILE +文件路径/文件名 +编码方式(可选)

    秋白
  • python: 显示进度条

    JNingWei
  • 7 Papers & Radios | 超图表示学习新框架HNHN;GNN的泛化与表示极限

    论文 1:Implicit Neural Representations with Periodic Activation Functions

    机器之心
  • SQL 基础--> 视图(CREATE VIEW)

    视图来源于表,所有对视图数据的修改最终都会被反映到视图的基表中,这些修改必须服从基表的完整性约束,并同样会触发定义

    Leshami
  • 关于知识蒸馏,这三篇论文详解不可错过

    导语:继《从Hinton开山之作开始,谈知识蒸馏的最新进展》之后,作者对知识蒸馏相关重要进行了更加全面的总结。在上一篇文章中主要介绍了attention tra...

    AI科技大本营
  • java多线程的常用方法(以及注意事项)

    1 /* 2 * 线程的常用方法 3 * 1.start(); 4 * 2.run(); 5 ...

    Gxjun

扫码关注云+社区

领取腾讯云代金券