一、    视图:
  视图(view)是保存了查询语句的一种数据库对象,其数据来源是查询语句对应的数据表,他的结果与数据表查询的结果一样也是一张虚拟的数据表
  1、 为什么需要视图:
    1) 不同的用户关心的数据可能是不相同的,每个用户可以将关心的数据的查询语句定义为视图,方便以后使用
    2) 针对一些不能被所有用户访问的数据可以通过创建视图只公开不需要保密的数据,提高数据的安全性
    3) 针对复杂的查询,可以将它保存为视图,以后可以简化查询的操作   2、 视图的创建:
    语法:
    CREATE VIEW<视图名称>AS<查询语句>
    举例:
    CREATE VIEW vw_score AS SELECT id 编号,student_no 学生编号,subject_id 课程编号,exam_date 考试日期 FROM tb_score;
  3、 视图的使用:查询视图与查询数据表的操作完全相同
    SELECT * FROM vw_score WHERE 课程编号 = 2; -- 课程编号为2的成绩 二、 事务:
  1、 什么是事务?
    当在执行一些重要的增删改时,往往需要将他们当作一个整体来看待,要么全部执行,要么全部不执行,
    当所有操作都正常结束后可以通过commit语句提交,当其中的全部或部分操作失败后,可以通过rollback语句回滚
  2、 如何使用事务:事务操作的流程
    1) 需要设置数据库管理系统的提交方式为“手动提交“。
        SET AUTOCOMMIT = {0|1};
        0表示手动提交,1表示自动体提交,MySQL默认的提交方式为“自动提交“
    2) 开启事务
        START TRANSACTION;
    3) 执行目标代码:如,转账就是执行两个update操作
    4) 若目标代码没有发生异常,执行提交操作(commit),发生异常执行回滚操作(rollback)
/*举例:模拟一个转账的事务操作,以Java代码的异常处理模板为例,演示事务操作的流程
try {
// 试图执行的目标代码,
SET AUTOCOMMIT = 0;
START TRANSACTION;
UPDATE tb_bank SET amount = amount - 100 WHERE card_no = ;
UPDATE tb_bank SET amount = amount + 100 WHERE card_no = ;
COMMIT;
} catch {
//当目标代码发生异常时会执行的代码块。
ROLLBACK;
} finally {
//不管目标代码是否发生异常,都会被执行的代码块
SET AUTOCOMMIT = 1;
}*/
3、 事务的4个特性:ACID
  1) 原子性(Atomicity):将事务中的所有操作当作一个整体来看待,要么全部执行,要么不执行
  2) 一致性(consistency):事务操作的前后数据要保持一致,如:转账前后的总金额要相同,
  3) 隔离性(isolation):事务之间时相互独立的,一个事务不能依赖其他事务执行结果而发生改变
  4) 永久性(durability):事务完成后的数据需要永久保存起来
4、 事务的隔离级别:
  在SQL规范中针对事务隔离级别设置了4个级别,每一种数据库管理系统都支持这4个级别,所不同的是,默认级别有差异
  1) 读未提交(READ UNCOMMITTED):当一个事务正在读取某个数据但还没有提交之前,其他的事务允许去访问该数据。(Oracle的默认值)
  2) 读已提交(READ COMMITTED):当一个事务正在读取某个数据但还没有提交之前,不允许其他事务访问该数据,只有前面的事务提交了数据后,才能访问。
  3) 可重复读(REPEATABLE READ):当一个事务正在修某个数据但还没有提交之前,其他的事务允许去访问该数据。(MySQL的默认值)
  4) 串行化(序列化)(SERIALIZABLE):所有的事务不管是读还是写数据,都必须要依次访问。
  注:以上的四个级别依次等级提高,效率越低,但实际应用过程中要根据项目的需求寻找一个安全和效率平衡点作为最佳方案。
5、 查看事务的隔离级别:
  通过查看MySQL数据库中保存的事务隔离级别变量来完成,范围有两个:全局(global)、当前会话(session)
  -- 当前会话隔离级别
  SELECT @@session.tx_isolation;
  -- 全局隔离级别
  SELECT @@global.tx_isolation;
6、 修改事务隔离级别:
  1) 通过SQL语句完成修改
  语法:
  SET {global | session} transaction isolation level {事务隔离级别};   2) 通过修改MySQL数据库管理系统的配置文件完成修改:
    a、 找到MySQL安装路径下的my.ini文件
    b、 打开文件找到[mysqld]区域,添加事务隔离级别的配置。
    如:transation-isolation = READ-COMMITTED;
    注:设置完成后是全局效果,所有的事务隔离级别都被修改

MySQL 10章_视图、事务的更多相关文章

  1. MySQL 05章_模糊查询和聚合函数

    在之前的查询都需要对查询的关机中进行“精确”.“完整”完整的输入才能查询相应的结果, 但在实际开发过程中,通常需要考虑用户可能不知道“精确”.“完整”的关键字, 那么就需要提供一种不太严格的查询方式, ...

  2. MySQL 11章_索引、触发器

    一. 索引: . 为什么要使用索引: 一本书需要目录能快速定位到寻找的内容,同理,数据表中的数据很多时候也可以为他们创建相应的“目录”,称为索引,当创建索引后查询数据也会更加高效 . Mysql中的索 ...

  3. C Primer Plus_第10章_数组和指针_编程练习

    1. /*rain.c 针对若干年的降水量数据,计算年降水总量.年降水平均量,以及月降水平均量*/ #include <stdio.h> #define MONTHS 12 #define ...

  4. 04747_Java语言程序设计(一)_第10章_网络与数据库编程基础

    例10.1说明InetAddress类的用法的应用程序. public class Example10_1 { public static void main(String args[]) { try ...

  5. 全国计算机等级考试二级教程-C语言程序设计_第10章_字符串

    字符型指针数组 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> //参数中,int a ...

  6. 04737_C++程序设计_第10章_面向对象设计实例

    10.6.2 使用包含的参考程序及运行结果. 头文件cpp10.h 源文件cpp10.cpp 源文件Find10.cpp 头文件cpp10.h #if ! defined(CPP10_H) #defi ...

  7. MySQL 08章_数据库设计

    一. 关系模型与对象模型之间的对应关系 序号 关系模型:数据库 对象模型:java程序 1 数据表table 实体entity:特殊的java类 2 字段field 属性attribute/字段fie ...

  8. mysql 09章_存储过程和函数

    一. 函数和存储过程的相同点: 函数和存储过程都是事先预编译并保存在数据库中的特殊的数据库对象, 需要执行相应功能时就可以直接通过“函数名”.“存储过程”调用其中的代码,以提高执行效率和代码的复用性. ...

  9. MySQL 07章_子查询

    子查询就是查询中还可以嵌套其他的查询,通常是内层查询的结果作为外层查询的条件来使用 执行循序,自内向外依次执行 一.内层查询返回“单列单行”的结果 -- 1.查询宋江的出生日期 SELECT TIME ...

随机推荐

  1. 5. Python数据类型之元组、集合、字典

    元组(tuple) 元组创建很简单,只需要在小括号中添加元素,并使用逗号隔开即可.与列表不同的是,元组的元素不能修改.如下代码所示: tup1 = () tup2 = (1) tup3 = (1,) ...

  2. web自动化selenium click()方法失效的解决办法

    使用Python写web-ui自动化脚本时,如果浏览器窗口比较小或者电脑屏幕比较小时, 可能会遇到页面元素的点击click()方法失效的问题,报错如下: Element <span>... ...

  3. Java 并发理论简述

    一:为什么需要多线程? 线程是Java语言中不可或缺的重要部分,它们能使复杂的异步代码变得简单,简化复杂系统的开发:能充分发挥多处理器系统的强大计算能力.多线程和多进程的区别与选择可以参考我的另一篇博 ...

  4. 6-vim-移动命令-01-方向和行内移动

    移动 命令模式下快速移动光标 编辑操作命令与移动命令结合使用 1.上下左右 命令 功能 手指 h 向左 食指 j 向下 食指 k 向上 中指 l 向右 无名指 2.行内移动 命令 英文 功能 w wo ...

  5. mysql的索引方法btree和hash的区别

    原文链接: http://www.91w.net/database/330.html 1. Hash索引: Hash 索引结构的特殊性,其检索效率非常高,索引的检索可以一次定位,不像B-Tree 索引 ...

  6. java oop第10章_JDBC03(MVC分层模式)

    引言:在进行程序开发的时候,为了更加利于程序的管理我们引入了新的开发模式MVC分层模式,即按功能将程序代码分别分为M(Model模型).V(View视图).C(Controller控制器)三个组成部分 ...

  7. 因kernel too old 而 centos6.8 升级内核

    因为docker运行centos 的时候,报错了,错误为kernel too old .我看了一下是因为os的内核不行了,需要升级下内核. 查看默认版本: uname -r 忘记截图了,内核大概是2. ...

  8. Visio2016专业版永久激活码

    Visio2016专业版永久激活码: [Key]:NKVJM-8MTT4-8YDFR-6738M-DPFJH [Key]:W9WC2-JN9W2-H4CBV-24QR7-M4HB8 [Key]:7K8 ...

  9. vue中数据绑定遇到的问题

    <!-- 使用element中的表格组件,在编辑的时候传递每行的数据 --> <el-button size="small" type="success ...

  10. 0928CSP-S模拟测试赛后总结

    依旧跌落.昨天只是偶然诈尸.我依旧是那个第二机房垫底大垃圾. 赛时打的很放松.因为T1想到了正解.对拍也打了.尽管用了大约一半的考试时间. 但是对拍拍了很久没有出错.如果你在2019年9月28日晚一下 ...