数据库完整性是指数据库中数据的正确性和相容性。
完整性约束条件的作用对象
定义与实现完整性约束:实体完整性 、参照完整性、 用户定义的完整性
**************************实体完整性**************************
实体完整性 :在mysql中,实体完整性是通过主键约束和候选键约束实现的。
主键列必须遵守的规则
主键约束与候选键约束的区别
***********************参照完整性*******************************
references tbl_name(index_col_name,…) [on delete reference_option] [on update reference_option]
tbl_name:指定外键所参照的表名
index_col_name:指定被参照的列名
on delete:指定参照动作相关的sql语句
reference_option:指定参照完整性约束的实现策略 (restrict-限制策略 | cascade-级联策略 | set null-置空策略 | no action-不采取实施策略)
**********************用户定义的完整性****************************
非空约束:not null
check 约束:check(expr)
命名完整性约束:constraint [symbol] symbol:指定的约束名字
只能给基于表的完整性约束指定名字,无法给基于列的完整性约束指定名字
命名完整性约束的方法是在各种完整性约束的定义说明之前加上关键字( constraint )和该约束的名字
更新完整性约束
使用alter table语句更新与列或表有关的各种约束。
什么是触发器:是用户定义在关系表上的一类由事件驱动的数据对象, 也是一种保证数据完整性的方法。
*************************创建触发器******************************
使用create trigger语句创建触发器
create trigger trigger_name trigger_time trigger_event on tbl_name for each row trigger_body
trigger_name:指定触发器的名称
trigger_time:指定触发器被触发的时刻
trigger_event:指定触发器的触发事件
tbl_name:指定与触发器相关联的表名
for each row :指定对于受触发事件影响的每一 行都要激活触发器的动作
trigger_body:指定触发器动作主体
例如:在数据库mysql_test的表customers中创建一个触发器 customers_insert_trigger,用于每次向表customers插入一行数据时, 将用户变量str的值设置为one customer added!
create trigger mysql_test.customers_insert_trigger after insert -> on mysql_test.customers for each row set @str=‘one customer added!’
使用drop语句删除触发器
语法:drop trigger [if exists][schema_name.]trigger_name
例如:drop trigger if exists mysql_test.customers_insert_trigger;
使用触发器
insert触发器 delete触发器 update触发器
*******************insert触发器***********************
在insert触发器代码内,可引用一个名为new(不区分大小写)的虚拟 表,来访问被插入的行。 在before insert触发器中,new中的值可以被更新
例如:在数据库mysql_test的表customers中重新创建触发器 customers_insert_trigger,用于每次向表customers插入一行数据时, 将用户变量str的值设置为新插入客户的id号。
create trigger mysql_test.customers_insert_trigger after insert -> on mysql_test.customers for each row set @str=new.cust_id;
********************delete触发器*************************
在delete触发器代码内,可引用一个名为old(不区分大小写)的虚拟 表,来访问被删除的行。 old中的值全部是只读的,不能被更新。
*******************update触发器***************************
在update触发器代码内,可引用一个名为old(不区分大小写)的虚拟 表,来访问update语句执行前的值,也可以引用一个名为new(不区 分大小写)的虚拟表来访问更新后的值
例如:在数据库mysql_test的表customers中创建一个触发器 customers_update_trigger,用于每次更新表customers时,将该表中cust_address列 的值设置为cust_contact列的值。
create trigger mysql_test.customers_update_trigger before update -> on mysql_test.customers for each row -> set new.cust_address=old.cust_contact;
数据库的安全性是指保护数据库以防止不合法的使用而造成数据泄露、更 改或破坏,所以安全性对于任何一个dbms来说都是至关重要的。
安全性与访问控制:身份验证 、数据库用户权 限确认
使用create user语句创建mysql账户
语法:create user user [identified by [password]’password’]
例如:在mysql服务器中添加两个新的用户,其用户名分别为zhangsan 和lisi,他们的主机名均为localhost,用户zhangsan的口令为123,用户 lisi的口令为对明文456使用password()函数加密返回的散列值。
create user ‘zhangsan’@’localhost’ identified by ‘123’, -> ‘lisi’@’localhost’ identified by password -> ‘*531e182e272080ab0740fe2f2d689dbe0146e04’;
使用drop user语句删除用户账号
语法:drop user user [,user]…
例如:drop user lisi@localhost
使用rename user语句修改用户账号
例如:rename user ‘zhangsan’@’localhost’ to ‘wangwu’@’localhost’;
使用set password语句修改用户登录口令
set password [for user]= { password(‘new_password’) |’encrypted password’ }
例如:set password for 'username'@'localhost' = password('pass');
使用grant语句为用户授权
grant priv_type [(column_list)] [,priv_type [(column_list)]] … on [object_type] priv_level to user_specification [,user_specification] … [with grant option]
例如:授予用户zhangsan在数据库mysql_test的表customers上拥有对 列cust_id和列cust_name的select权限。
grant select(cust_id,cust_name) -> on mysql_test.customers -> to’zhangsan’@’localhost’;
授予当前系统中一个不存在的用户liming和用户huang,要求创建 这两个用户,并设置对应的系统登录口令,同时授予他们在数据库 mysql_test的表customers上拥有select和update的权限。
grant select,update -> on mysql_test.customers -> to 'liming'@'localhost' identified by '123', -> 'huang'@'localhost' identified by '789';
授予系统中已存在的wangwu可以在数据库mysql_test中执行所有 数据库操作的权限
grant all -> on mysql_test.* -> to ‘wangwu’@’localhost’;
授予系统中已存在的wangwu拥有创建用户的权限
grant create user -> on *.* -> to ‘wangwu’@’localhost’;
权限的转移
授予当前系统中不存在的用户 zhou 在数据库mysql_test的表customers上 拥有select和update的权限,并允许其可以将自身的这个权限授予给其他 用户
grant select,update -> on mysql_test.customers -> to ‘zhou’@’localhost’ identified by ‘123’ -> with grant option;
使用revoke语句撤销用户权限
revoke priv_type [(column_list)] [,priv_type [(column_list)]] … on [object_type] priv_level from user [,user] …
回收系统中已存在用户zhou在数据库mysql_test的表customers 上的select权限
revoke select -> on mysql_test.customers -> from ‘zhou’@’localhost’;
所谓事务是用户定义的一个数据操作序列,这些操作可作为一个完整的工 作单元,要么全部执行,要么全部不执行,是一个不可分割的工作单位。 事务中的操作一般是对数据的更新操作,包括增、删、改。
以begin transaction语句开始 以 commit 语句或 rollback语句结束
事务的特征(acid):
例题:依据事务的acid特征,分析并编写银行数据库系统中的转账事务t:从账 户a转账s金额资金到账户b
begin transaction read(a); a=a-s; write(a); if(a<0)rollback; else read(b); b=b+s write(b); commit;}
并发操作问题
封锁是最常用的并发控制技术 基本思想:需要时,事务通过向系统请 求对它所希望的数据对象加锁,以确保 它不被非预期改变
锁 :一个锁实质上就是允许或阻止一个事务对一个数据对象的存取特权。
基本的封锁类型:
封锁的工作原理:
封锁的粒度
封锁的级别又称为一致性级别或隔离度
死锁和活锁
可串行性
两段封锁法
数据丢失的途径:
1.计算机硬件故障
2.计算机软件故障
3.病毒
4.人为误操作
5.自然灾害
6.盗窃
数据库备份与恢复的概念
使用select into…outfile语句备份数据
select *into outfile ‘file_name’ export_options | into dumpfile ‘file_name’
file_name:指定数据备份文件的名称
使用load data…infile语句恢复数据
简述恢复数据的方法?
备份数据库mysql_test中表customers的全部数据到c盘的backup目录 下一个名为backupfile.txt的文件中,要求字段值如果是字符则用双引号 标注,字段值之间用逗号隔开,每行以问号为结束标志。然后,将备份后 的数据导入到一个和customers表结构相同的空表customers_copy中。
select * from mysql_test.customers into outfile ‘c:/backup/backupfile.txt’ fields terminated by ’,’ optionally enclosed by “” lines terminated by ‘?’;
如对本文有疑问, 点击进行留言回复!!
网友评论