视图 view

直接操作数据库时,是在逻辑模型层操作的,即给定的集合中的关系都是实实在在存储在数据库中的
出于安全考虑,我们要隐藏特定的数据
在SQL中,允许定义虚关系,他在概念上包含查询的结果,虚关系并不预先进行计算并存储,而是使用虚关系的时候才通过执行查询,被计算出来
不是逻辑模型的一部分,但作为虚关系对用户可见的 关系称为视图

定义视图

mysql> create view abc as                    #定义视图-> select ID,name,dept_name-> from instructor;
Query OK, 0 rows affected
mysql> select * from abc;                    #SQL查询中使用视图

事务

一、事务概念
事务是一种机制、是一种操作序列,它包含了一组数据库操作命令,这组命令要么全部执行,要么全部不执行。因此事务是一个不可分割的工作逻辑单元。在数据库系统上执行并发操作时事务是作为最小的控制单元来使用的。这特别适用于多用户同时操作的数据通信系统。例如:订票、银行、保险公司以及证券交易系统等。

二、事务属性
事务4大属性:
1 原子性(Atomicity):事务是一个完整的操作。不可分割
2 一致性(Consistency):当事务完成时,数据必须处于一致状态。
3 隔离性(Isolation):对数据进行修改的所有并发事务是彼此隔离的。
4 持久性(Durability):事务完成后,它对于系统的影响是永久性的。

三、创建事务
T-SQL中管理事务的语句:
1 开始事务: begin transaction
2 提交事务:commit transaction
3 回滚事务: rollback transaction

事务分类:
1 显式事务:用begin transaction明确指定事务的开始。
2 隐性事务:打开隐性事务:set implicit_transactions on,当以隐性事务模式操作时,SQL Servler将在提交或回滚事务后自动启动新事务。无法描述事务的开始,只需要提交或回滚事务。
3 自动提交事务:SQL Server的默认模式,它将每条单独的T-SQL语句视为一个事务。如果成功执行,则自动提交,否则回滚。

完整性约束

防止对数据的意外破坏,通常被看作是数据库模式设计过程的一部分

eg:表中 教师姓名不能为空 not null

* not nullname varchar(20) not null* unique* checkmysql> create table hehehe  (id varchar(10),choice varchar(10),check (choice in ('a','b','c','d')));
Query OK, 0 rows affected

SQL的数据类型和模式

日期和时间类型

* date 年月日
* time 时分秒
* timestamp date和 time 的组合
date '2016-07-29'
time '09:03:52'
timestamp '2001-04-25 03:02:01'

默认值

SQL允许属性指定默认值

创建索引:
索引是一种数据结构,允许数据库系统高效的找到关系中的那些在索引属性上给定值的元祖
而不用扫描所有元祖

mysql> create index studentID_index on student(ID);
Query OK, 0 rows affected
Records: 0  Duplicates: 0  Warnings: 0

创建表的扩展:

create table stu1 like student;        #创建一个模式相同的表create table stu2 as (               #将查询结果新建为一个表select name,sexfrom student)

授权:
GRANT语句的一般格式:
GRANT <权限>[,<权限>]…
[ON <对象类型> <对象名>]
TO <用户>[,<用户>]…
[WITH GRANT OPTION];

语义:将对指定操作对象的指定操作权限授予指定的用户

收回权限用 revoke

与创建角色 结合
create role teacher;
角色可以像用户那样被授予权限
grant select on takes to teacher
触发器 trigger
指定的事情发生,相应的条件满足,执行触发器

两个要求

* 指明什么条件下执行触发器
* 触发器执行的动作

触发器不能执行数据库以外的更新

触发器可以用来复制或者备份数据库

转载于:https://www.cnblogs.com/tyzZ001/p/5754769.html

数据库系统概念学习笔记2相关推荐

  1. 操作系统概念学习笔记 16 内存管理(二) 段页

    操作系统概念学习笔记 16 内存管理 (二) 分页(paging) 分页(paging)内存管理方案允许进程的物理地址空间可以使非连续的.分页避免了将不同大小的内存块匹配到交换空间上(前面叙述的内存管 ...

  2. 操作系统概念学习笔记 11 进程同步(一)

    操作系统概念学习笔记 11 进程同步(一) 互相协作的进程之间有共享的数据,于是这里就有一个并发情况下,如何确保有序操作这些数据.维护一致性的问题,即进程同步. 从底层到高级应用,同步机制依次有临界区 ...

  3. 操作系统概念学习笔记 15 内存管理(一)

    操作系统概念学习笔记 15 内存管理(一) 背景 内存是现代计算机运行的中心.内存有非常大一组字或字节组成,每一个字或字节都有它们自己的地址.CPU依据程序计数器(PC)的值从内存中提取指令.这些指令 ...

  4. 操作系统概念学习笔记 4 操作系统结构和操作简述

    操作系统概念学习笔记 4 操作系统结构和操作简述 操作系统结构 多道程序设计 多道程序设计指的是允许多个程序同时进入一个计算机系统的主存储器并启动进行计算的方法.也就是说,计算机内存中可以同时存放多道 ...

  5. 数据库系统概念笔记-关系模型介绍

    转载自 数据库系统概念笔记-关系模型介绍  作者 CyninMa 数据库系统概念笔记-关系模型介绍 2.1 关系数据库的结构 关系数据库由表(table)的集合构成,每个表有唯一的名字.例如,inst ...

  6. mysql数据库逆心_数据库系统基础笔记(7)--函数

    逆心 MySQL数据库提供了很多函数包括: 数学函数: 字符串函数: 日期和时间函数: 条件判断函数: 系统信息函数: 加密函数: 格式化函数: 一.数学函数 数学函数主要用于处理数字,包括整型.浮点 ...

  7. 数据库系统概念笔记-引言

    转载自 数据库系统概念笔记-引言  作者 CyninMa 数据库系统概念笔记-引言 数据库管理系统(DBMS)由一个互相关联的数据的集合和一组用以访问这些数据的程序组成.这个数据集合通常称作数据库,其 ...

  8. 数据库系统学习笔记(3)

    数据库系统的结构和组成(3) 1. 数据库系统的结构(三级结构,两级映射(数据独立性)) 1.1 数据库系统模式 模式的型(框架):如学生的记录型(学号,姓名,年级,住址) 模式的值:(2001,bo ...

  9. 数据库系统概论笔记整理———第一章(绪论之数据库系统,数据模型,外模式,内模式,层次模型,数据独立性等)

    ❤️ 数据库系统概论 1.数据(data):描述事物的符号记录,可以是数字,图像,音频,视频等. 2.数据的含义称为数据的语义,数据与其语义是不可分的 3.数据库(DB):是长期存储在计算机内,有组织 ...

最新文章

  1. ORACLE 数据泵导入导出数据
  2. cv2.putText
  3. python画笔初始位置_turtle绘画-移动落笔点(改变初始原点)
  4. 洛谷P1330 封锁阳光大学
  5. linux获取随机数的方法集合
  6. 【亲测】二极管电压测试“跳坑”注意事项——硬件的板载测试验证
  7. linux dd使用记录
  8. 电脑重装系统后没声音怎么办
  9. Chapter 2 Open Book——5
  10. android - startActivity浅谈
  11. 获取本机的ip地址(Windows和linux的区别)
  12. 【安全牛学习笔记】Kali Linux基本工具
  13. 接口和继承知识点总结
  14. 绿地再次牵手国际会展业巨头,加速打造会展板块
  15. 如何优雅地使用Origin(小技巧)【推荐】
  16. sublime 的一个神秘快捷键
  17. 探索者TSSD打印比例及绘图比例理解
  18. 计算机中丢失storm.d,WIN7更新错误8024200D的解决方法
  19. 程序员读《马云全转》
  20. catia草图里写字_请问CATIA如何在曲面上写字,麻烦高手解答详细步骤?

热门文章

  1. MFRC522开发笔记
  2. hdu1395 2^x mod n = 1
  3. java8 lambda 排序算法,Java8中排序算法比较器的三种写法(使用lambda表达式实现Comparator比较器)...
  4. Linux命令行下关机【Ubuntu】
  5. 3.2.5 端到端的学习
  6. 第十讲 二阶齐次常系数线性ODE(续)
  7. DOM相关方法,属性整理
  8. queued frame 造成图形性能卡顿
  9. 拼接字符串 新增数据方法
  10. linux 内核 printk 使用