day15(mysql 的多表查询,事务)

mysql之多表查询

1.合并结果集

  作用:合并结果集就是把两个select语句查询的结果连接到一起!

 

/*创建表t1*/
CREATE  TABLE t1(a INT PRIMARY KEY ,b VARCHAR(10)
)
INSERT INTO t1 VALUES(1,'a');
INSERT INTO t1 VALUES(2,'b');
INSERT INTO t1 VALUES(3,'c');
/*创建t2*/
CREATE  TABLE t2(c INT PRIMARY KEY ,d VARCHAR(10)
)
INSERT INTO t2 VALUES(4,'d');
INSERT INTO t2 VALUES(5,'e');
INSERT INTO t2 VALUES(6,'f');

  合并结果集有两种方式:

    union: 去除重复记录。  

/*使用union进行连接两个select语句*/select * from t1 union select * from t2;
查询结果为:

 

  为了体现去重思想: 我们给t1添加一条数据

insert into t1 values(4,'d');

  重新进行查询则:

select * from t1 union select * from t2;

   证明了 t1表和t2表的相同的数据会去掉

  

   union all:不用出去重复记录。

select * from t1 union all select * from t2;

输出结果中   4d出现了两次

  总结 :  union :连接两个查询语句  去除完全相同的数据

      union all: 连接两个查询语句,不去除完全相同的记录

         要求:被合并的两个结果:列数、列类型必须相同。

2.连接查询

  连接查询就是求出多个表的乘积  eg:t1连接t2,那么查询出来的结果为t1*t2

  

select * from t1,t2;

   连接查询会产生  笛卡尔积

  假设集合A={a,b},集合B={0,1,2},则两个集合的笛卡尔积为{(a,0),(a,1),(a,2),(b,0),(b,1),(b,2)}。可以扩展到多个集合的情况。

  为了去除笛卡尔积给我们带来的多余的数据   我们使用连接查询 给了一个约束条件(外键约束)

  为了更好的体验连接查询的约束条件 我们重新建了两个表

create table classes(cid int primary key auto_increment,cname varchar(20),cnum int
);
insert into classes values(null,'01班',20);       
insert into classes values(null,'02班',30);    
insert into classes values(null,'03班',40);    
insert into classes values(null,'04班',41);   
create table student(
      sid int primary kay auto_increament,
      cname varchar(20),
      sex varchar(1),
      brithday date,
      cno int,
      constraint fk_st_c1 foreign key (cno) references classes (cid)
);

/*给student表添加数据*/
INSERT INTO student VALUES(NULL,'张三','男','1990-09-01',1);
INSERT INTO student VALUES(NULL,'李四','女','1991-02-13',1);
INSERT INTO student VALUES(NULL,'王五','男','1990-03-12',1);
INSERT INTO student VALUES(NULL,'赵六','男','1992-02-12',2);
INSERT INTO student VALUES(NULL,'田七','男','1994-05-21',2);
INSERT INTO student VALUES(NULL,'张五','女','1990-05-17',2);
INSERT INTO student VALUES(NULL,'张老七','女','1990-06-17',3);
INSERT INTO student VALUES(NULL,'王老四','女','1990-04-12',3);
INSERT INTO student VALUES(NULL,'李六','男','1990-09-12',1);  

  班级表                学生表 

                          

 

 学生表中的cno字段的外键是班级表中的cid

这样我们使用连接查询会产生(班级表的条数*学生表的条数=4*9=36)

SELECT COUNT(*) FROM classes ,student 

  加上约束条件使没用的数据过滤掉  使用where关键字

SELECT COUNT(*) FROM classes c,student s  WHERE c.cid=s.cno;

  使无效数据过滤掉,所以union 一般我们不会使用

 

  因此产生了内连接和外连接查询

  内连接分为:   (特点  查询条件必须满足)

    显式内连接(inner join   .....on)   其中  inner关键字可以省略    

        

SELECT * FROM classes c INNER JOIN student s ON c.cid=s.cno;
SELECT * FROM classes c  JOIN student s ON c.cid=s.cno; /*省略inner关键字*/

    隐式内连接

      就是我们刚才提到的连接查询

     

SELECT * FROM classes c,student s  WHERE c.cid=s.cno;

    外连接 

      左外连接:  左表作为基础

        left outer join   on

SELECT * FROM classes c LEFT OUTER JOIN student s ON c.cid=s.cno;

  把班级表作为基础  查询出来的结果为:

                     

      右外连接:  右表作为基础

        right outer join on 

SELECT * FROM classes c RIGHT OUTER JOIN student s ON c.cid=s.cno;

   把学生表作为基础  查询出来的结果为:

                        

 

        使用一张图来总结左连接和右连接

    

 

3.子查询 

      子查询:一个select语句中包含了另一个select语句

    子查询的位置

      where后   :作为条为被查询的一条件的一部分

 

      from 后     :   作表;

   当子查询出现在where后作为条件时,还可以使用如下关键字:

 

    1. any
    2. all

 

      子查询结果集的形式:

 

      1. 单行单列(用于条件)
      2. 单行多列(用于条件)
      3. 多行单列(用于条件)
      4. 多行多列(用于表)

 

    

查询学生生日在91年之后的班级的信息。
select * from classes where cid in (SELECT cno FROM student WHERE birthday > '1991-01-01');
带exists的子查询
查询学生生日大于91年1月1日,如果记录存在,前面的SQL语句就会执行
select * from classes where exists (SELECT cno FROM student WHERE birthday > '1991-01-01');
带any的子查询
SELECT * FROM classes WHERE cid > ANY (SELECT cno FROM student )
带all的子查询
SELECT * FROM classes WHERE cid > ALL (SELECT cno FROM student)

 

  事务

 

事务的特性(面试题)

 

原子性:指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。 

 

一致性:事务必须使数据库从一个一致性状态变换到另外一个一致性状态。转账前和转账后的总金额不变。

 

隔离性:事务的隔离性是多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离。

 

持久性:指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。

 

 

 

4、事务的隔离级别

 

赃读:指一个事务读取了另一个事务未提交的数据。

 

不可重复读:在一个事务内读取表中的某一行数据,多次读取结果不同。一个事务读取到了另一个事务提交后的数据。(update

 

虚读(幻读):是指在一个事务内读取到了别的事务插入的数据,导致前后读取不一致。 (insert)

 

 

 

数据库通过设置事务的隔离级别防止以上情况的发生:

 

* 1READ UNCOMMITTED: 赃读、不可重复读、虚读都有可能发生。

 

* 2READ COMMITTED: 避免赃读。不可重复读、虚读都有可能发生。(oracle默认的)

 

* 4REPEATABLE READ:避免赃读、不可重复读。虚读有可能发生。(mysql默认)

 

* 8SERIALIZABLE: 避免赃读、不可重复读、虚读。

 

级别越高,性能越低,数据越安全

 

 

 

mysql中:

 

查看当前的事务隔离级别:SELECT @@TX_ISOLATION;

 

更改当前的事务隔离级别:SET TRANSACTION ISOLATION LEVEL 四个级别之一。

 

设置隔离级别必须在事务之前

 

 

 

练习:设置事务的隔离级别为 read uncommitted

 

时间

线程1

线程2

说明

t1

begin;

 

 

t2

select * from account where name='zs';

结果1000

 

 

t3

 

begin;

 

t4

 

update account set money=money+100 where name='zs';

 

t5

select * from account where name='zs';

结果1100

 

读到了另一个线程未提交事务的数据。赃读发生了

t6

 

commit;

 

t7

select * from account where name='zs';

结果1100

 

读到了另一个线程提交事务的update数据。不可重复读发生了

t8

 

insert into account values(4,'zl',1000);

执行insert语句插入数据,事务自动提交了

 

t9

select * from account;

查到4条数据

 

读到了另一个线程自动提交事务的insert语句数据。虚读发生了

t10

commit;

 

 

 

转载于:https://www.cnblogs.com/fjkgrbk/p/mysql_moreTable.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/454997.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vue router传参_新手使用vue-router传参时注意事项

1. 使用name和params组合传参this.$router.push({name: details, params: {id: 233}})路由配置import Vue from vueimport Router from vue-router Vue.use(Router) export default new Router({ mode: history, routes: [ { path: /details, name: details, component: resolv…

逻辑综合工具DesignCompiler使用教程

逻辑综合工具Design Compiler使用教程 图形界面design vision操作示例 逻辑综合主要是将HDL语言描述的电路转换为工艺库器件构成的网表的过程。综合工具目前比较主流的是synopsys公司Design Compiler,我们在设计实践过程中采用这一工具。Design compiler有两种工作…

遍历结构体_三菱ST语言编程(3)——结构体变量

上篇文章介绍了数组,是一组相同类型数据的列表,那么不同类型的数据能否组合到一起用一个标签表示呢?答案当然是可以的,而实现这个功能的就是结构体(struct)。建立结构体在三菱结构化编程的界面中左侧程序部件里可以找到结构体标签…

中的 隐藏鼠标菜单_Mac移动隐藏删除顶部菜单栏图标教程

苹果菜单栏贯穿 Mac 的屏幕顶部。左侧是苹果菜单和应用菜单,应用菜单一般显示你当前使用的Mac软件的所有功能菜单。右侧通常是以图标显示的状态菜单,帮助你快速查看Mac的状态以及快速访问某些Mac软件。移动图标位置若想要重新排列状态菜单栏的图标&#…

[hadoop] kettle spoon 基础使用 (txt 内容抽取到excel中)

spoon.bat 启动kettle。 测试数据 1. 新建转换 输入中选择文本文件输入 双击设置文本输入 字符集、分隔符设置 获取对应的字段,预览记录。 拖入 excel输出,设置转换关系 设置输出路径 获取字段 启动转换 导入的excel数据(设置好格式,图中ID,A…

apache 支持.htaccess重写url

1. httpd.conf 添加&#xff1a; <Directory />Options Indexes FollowSymLinks MultiviewsAllowOverride allRequire all grantedRewriteEngine On</Directory> 开启&#xff1a; 在phpinfo里找到&#xff1a; 说明开启成功。 2.httpd-vhosts.conf &#xff08;开…

redis基本用法学习(C#调用FreeRedis操作redis)

FreeRedis属于常用的基于.net的redis客户端&#xff0c;EasyCaching中也提供适配FreeRedis的包。根据参考文献4中的说法&#xff0c;FreeRedis和CsRedis算是近亲&#xff08;都是GitHub中账号为2881099下的开源项目&#xff09;&#xff0c;因此其用法特别相似。FreeRedis的主要…

opencv:图像的基本变换

0.概述 图像变换的基本原理都是找到原图和目标图的像素位置的映射关系&#xff0c;这个可以用坐标系来思考&#xff0c;在opencv中&#xff0c; 图像的坐标系是从左上角开始(0,0)&#xff0c;向右是x增加方向(cols)&#xff0c;向下时y增加方向(rows)。 普通坐标关系&#xff1…

中通知设置响铃_主动切断干扰源——手机“通知”精细化管理

上周去参加我福福幼儿园的母亲节活动&#xff0c;内容是孩子和家长一起穿手链。期间我发现和我同桌的一个家长的手机不停在响&#xff0c;当然伴随着注意力被打断。不仅是这位家长自己&#xff0c;连我也受到了干扰。于是职业病又犯了&#xff0c;我悄悄的看了一眼这位家长的手…

python安装各种插件

http://www.lfd.uci.edu/~gohlke/pythonlibs/#pip 感受&#xff1a;如果编辑pip真的一直出问题&#xff0c;考虑降成32位的进行安装。毕竟合理搭配比木桶突出有用。转载于:https://www.cnblogs.com/osmondwang/p/7307678.html

编写数学公式的好工具

2019独角兽企业重金招聘Python工程师标准>>> http://private.codecogs.com/latex/eqneditor.php 转载于:https://my.oschina.net/yizhichao/blog/1542153

dev gridview 打印列数过多_R语言:如何将多张统计图绘制在一张上面

在使用R语言进行数据可视化的时候&#xff0c;常常需要将多张统计图表绘制在同一张图上面&#xff0c;从而更高效地传递信息&#xff0c;下面我们就来一起看看具体如何实现。一、使用R语言自带的函数绘制的图像R语言本身就已经内置了许多绘图函数&#xff0c;能够满足较为基本的…

[转]vue全面介绍--全家桶、项目实例

慢慢了解vue及其全家桶的过程 原文http://blog.csdn.net/zhenghao35791/article/details/67639415 简介 “简单却不失优雅&#xff0c;小巧而不乏大匠”。 2016年最火的前端框架当属Vue.js了&#xff0c;很多使用过vue的程序员这样评价它&#xff0c;“vue.js兼具angular.js和R…

TS 188字节流结构图

应该说真正了解TS&#xff0c;还是看了朋友推荐的《数字电视业务信息及其编码》一书之后&#xff0c;MPEG2 TS和数字电视是紧密不可分割的&#xff0c;值得总结一下其中的一些关系。 ISO/IEC&#xff0d;13818&#xff0d;1&#xff1a;系统部分&#xff1b; ISO/IEC&#xff…

二进制安装mysql 5.7、mariadb (附yum安装方式)

前言&#xff1a;本文以mariadb为例进行讲解&#xff0c;安装mysql同理&#xff0c;并以通过测试。安装前查找系统已安装的相关包&#xff08;rpm -qa|grep -e "mysql" -e "mariadb"&#xff09;并进行卸载。1、准备mariadb存储数据库文件的目录。mkdir -p…

GLSL/C++ 实现滤镜效果

入门效果之浮雕 "浮雕"图象效果是指图像的前景前向凸出背景。常见于一些纪念碑的雕刻上。要实现浮雕事实上很easy。我们把图象的一个象素和左上方的象素进行求差运算。并加上一个灰度。这个灰度就是表示背景颜色。这里我们设置这个插值为128 (图象RGB的值是0-255)。同…

cv mat的shape_pybind11—opencv图像处理(numpy数据交换)

前言C opencv中图像和矩阵的表示采用Mat类&#xff0c;比如imread()读取的结果就是返回一个Mat对象。对于python而言&#xff0c;numpy 通常用于矩阵运算&#xff0c; 矩阵&#xff0c;图像表示为numpy.ndarray类。因此&#xff0c;想要将python numpy.ndarray的数据传递到C op…

H.264算法的优化策略

文章来源&#xff1a; http://www.tichinese.com/Article/Video/200909/2150.html 编辑&#xff1a;小乙哥 1 代码优化的主要方法 通过代码移植能够获得在DSP上初步运行的代码&#xff0c;但是它由于没有考虑到DSP自身的硬件特点&#xff0c;不适合DSP强大的并行处理能力&#…

吃饭、睡觉、打星星之“打星星”!

大家见过这样的星星么&#xff1f; 你想要多少就可以多少的星星&#xff01;&#xff01;&#xff01; 下面我们就来用奇妙的JavaScript来实现 首先我们要引入一个输入包 let readline require("readline-sync");然后再让客户输入数字&#xff0c;并将其存放起来con…

使用iconv-lite解决node当中不支持GBK编码的问题

1、Node环境当中不支持GBK编码 node.js当中的Buffer对象支持的编码格式的种类有限&#xff0c;大概有ascii、utf8、utf16le、ucs2、base64、binary、hex。不支持GBK的编码形式。对于windows系统来说&#xff0c;由于历史原因&#xff0c;许多文件默认的编码格式均为GBK。 比如我…