zoukankan      html  css  js  c++  java
  • ​《数据库系统概念》5-连接、视图和事务

    一、连接
    a)inner join中,on,可以用where替代,但用on来专门指定join条件,其它条件写在where中可读性更好。
    b)outer join
    对于连接字段为空的元祖,使用inner join时不会列出,outer join却不一样,left /right join会保留左(右)侧的连接字段为空的元祖。left join的过程可以理解为先执行inner join,然后再向结果集中添加左侧关系中剩余的元祖。
    在outer join中,on和where就不能互换了
    c)在SQL server中left outer join也是可以写的,但一般会省略inner、outer

    二、视图
    a)前面学习过程中接触的表都是在数据库中实际存在的,但有时用户并不需要一张表的全部信息;甚至有时候不想让用户拿到额外的信息,比如有时只允许用户查阅instructor表的id, name;或者有一些复杂的查询我们不希望每次都去重复写一遍。这时可以使用虚拟的表(virtual relation),即视图(view),视图不属于数据库的表,但可以被用户访问到。
    b)视图的定义
    写法为create view v as <query expression>;其中query expression可以是任何查询语句。比如之前的instructor视图可以这样定义:
    create view faculty as
    select ID, name
    from instructor;
    然后只为用户提供访问faculty视图的权限,就可以达成目的。
    c)视图被定义后,就可以像真实的表一样被使用,视图还可以嵌套视图。在使用到视图的时候,数据库会执行视图的定义语句来生成结果集,所以视图的内容是实时的。
    d) 物化视图(Materialized Views)
    视图一般在被使用时才会实时查询出结果,这种方式虽然能保证数据是最新的,但开销却较大,在一些对计算资源有限制的场合、或者视图被频繁使用的时候、以及对查询速度有要求时,需要视图结果集能被保存起来,这种视图称为物化视图。
    e)视图的更新
    视图可以为查询带来方便,但视图的更新却涉及到多个问题,造成这些问题的根源是对视图的更改需要反映到真实表上。由于允许视图出现在真实表可以出现的任意位置,所以对于之前的faculty视图,就可以插入数据:
    insert into faculty values (30765, ‘Green’);
    但instructor.salary只能插入null了,instructor.salary如果规定不允许为空,则操作会因违反一致性而被阻止。此外再考虑视图关联多张表、视图的嵌套等情况,会使得问题变得非常复杂,所以通常对视图的更新是不被允许的。

    三、事务
    a)SQL标准规定了事务形式为:包含查询、更新语句,必须用commit work或rollback work来结束且”work”可省略。
    b)如果SQL语句可能出错,则可以包含在事务中,commit类似于保存编辑好的文档,而rollback相当于撤销对文档所做的修改。但是事务一旦被commit,就无法再被rollback。事务是原子性的,事务包含的操作要么全部成功,要么全部失败。如果在SQL语句执行过程中发生系统奔溃、断电等事故,只要没有执行过commit,则在系统重启后会首先回滚。
    c)在许多数据库产品中,默认每条单独的SQL就是一个事务,执行结束后自动commit。


    学习资料:Database System Concepts, by Abraham Silberschatz, Henry F.Korth, S.Sudarshan


  • 相关阅读:
    c++类中比较重要的几个函数
    rosbag使用方法
    2.urllib库的使用
    什么叫做API?
    1.爬虫基础
    正则表达式

    time模块
    random模块
    日志处理
  • 原文地址:https://www.cnblogs.com/zhixin9001/p/7853765.html
Copyright © 2011-2022 走看看