MySQL数据库

前言:

  前面我们了解了什么是数据库,什么是MySQL数据库以及如何运用,接下来我们接着深入学习MySQL。

  (提前声明,以下所提供的事例不标准,仅供参考)

数据库的备份与还原:

  备份: 在cmd中输入 mysqldump -u root -p 数据库名称 > 备份路径

  还原:两种方法

  ①: mysql -u root -p 数据库名称 < 备份路径

    (这个实例,我事先删除了smbms的数据库并重新导入)

  ②: 第一步:在服务器内创建一个数据库

     第二步:source 还原数据库的地址

  当然你也可以更简单,使用可视化工具直接备份和还原。

多表设计之外键的约束:

约束的作用:保证数据的完整性

单标约束:主键、唯一、非空

外键约束:用来保证数据完整性(多表之间)

添加外键约束:alter table 指向的表名 add foreign key (指向的键) references 被指向的表名(被指向的键);

具体示例:

表与表的关系:一对多、多对多、一对一

一对多:在多的一方创建外键指向一的一方主键。

多对多:需要创建第三张表(中间表),在中间表中至少两个字段分别作为外键,指向多对多双方的主键。

一对一:两种方式:

①唯一外键对应的方式:假设一对一是一个一对多关系,需要在多的一方创建外键指向一的一方的主键,将外键设置为唯一。

②主键对应方式:将两个表的主键建立对应关系即可。

多表查询的分类:连接查询、子查询

①连接查询:

(1)交叉查询:查询到的是两个表的笛卡尔积。

select * from 表1 cross join 表2; select * from 表1,表2;

(这里主要看id,这个事例不标准,仅供参考)

(2)内连接:inner join  (inner 可以省略)

  • 显示内连接:

select * from 表1 inner join 表2 on 关联条件;

  • 隐式内连接:

select * from 表1,表2 where 关联条件;

(3)外连接:outer join (outer可有省略)

【这里注意看左外连接和右外连接的事例区别】

  • 左外连接:

select * from 表1 left outer join 表2 on 关联条件;

  • 右外连接:

select * from 表1 right outer join 表2 on 关联条件

②子查询:一个查询语句条件需要依赖另一个查询语句的结果。

  • 带in的子查询
  • 带exists的子查询
  • 带any的子查询
  • 带all的子查询

事务:指的是逻辑上的一组操作,组成这组操作的各个逻辑单元,要么全都成功,要么全都失败

开启事务: start transaction;
提交事务: commit;
回滚事务: rollback;

事务的四大特性:
原子性:事务的不可分割,组成事务的各个逻辑单元不可分割
一致性:事务执行的前后,数据完整性保持一致
隔离性:事务执行不应该受到其他事务的干扰
持久性:事务一旦结束,数据就持久化到数据库中

事务的隔离级别:
安全问题主要体现在读取数据上:脏读、不可重复读、虚读/幻读

脏读:一个事务读到了另一个事务未提交的数据,导致查询结果不一致。
不可重复读:一个事务读到了另一个事务已经提交的update的数据,导致多次查询结果不一致。
虚读/幻读:一个事务读到了另一个事务已经提交的insert的数据,导致多次查询结果不一致。

解决方法:设置事务的隔离级别: 级别由上到下依次增强,但是读取速度依次下降。
read uncommitted:脏读,不可重复读,虚读都有可能发生。
read committed:避免脏读。但是不可重复读和虚读是有可能发生的
repeatable read:避免脏读和不可重复读,但是虚读有可能发生。
serializable:避免脏读,不可重复读,虚读。

设置事务的隔离级别: SET SESSION TRANSACTION ISOLATION LEVEL 隔离级别;
查看当前的隔离级别: SELECT @@tx_isolation;

注意:不同版本的mysql,查看隔离级别语法不同!

上面那个是旧版的,新版的:SELECT @@transaction_isolation;

否则会报错:ERROR 1193 (HY000): Unknown system variable 'tx_isolation'

(关于事务可以自己去尝试)

小结:

  以上就是多表和事务的介绍了,希望能对各位有所帮助。

                            加油

                        时间:2020-03-28 15:39:33

MySQL数据库02的更多相关文章

  1. 004.CI4框架CodeIgniter, 配置mysql数据库,并进行数据库查询

    01.在app的Config目录的Database文件里面填写数据库配置,并把pConnect设置成true,此处为一直连接mysql数据库 02.在Models中,创建一个System目录,再在Sy ...

  2. MySQL数据库学习: 02 —— 数据库的安装与配置

                             MySQL安装图解 一.MYSQL的安装 1.打开下载的mysql安装文件mysql-5.0.27-win32.zip,双击解压缩,运行“setup. ...

  3. 数据库02 /MySQL基础数据类型、完整性约束、sql_mode模式

    2.MySQL基础数据类型.完整性约束.sql_mode模式 目录 2.MySQL基础数据类型.完整性约束.sql_mode模式 1. MySQL常用数据类型 MySQL常用数据类型预览 1. 1 数 ...

  4. MySQL学习02(操作数据库)

    操作数据库 结构化查询语句分类 名称 解释 命令 DDL(数据库定义语言) 定义和管理数据对象,例如数据库和数据表 create.drop.alter DML(数据操作语言) 用于操作数据库对象中所包 ...

  5. 如何在删除ibdata1和ib_logfile的情况下恢复MySQL数据库

    昨天,有个朋友对公司内部使用的一个MySQL实例开启binlog,但是在启动的过程中失败了(他也没提,为何会失败),在启动失败后,他删除了ibdata1和ib_logfile,后来,能正常启动了,但所 ...

  6. 【Data Cluster】真机环境下MySQL数据库集群搭建

    真机环境下MySQL-Cluster搭建文档  摘要:本年伊始阶段,由于实验室对不同数据库性能测试需求,才出现MySQL集群搭建.购置主机,交换机,双绞线等一系列准备工作就绪,也就开始集群搭建.起初笔 ...

  7. 在Ubuntu中建立MySQL数据库

    最近在做一个关于云计算安全系统的项目,需要用到MySQL数据库,现在把建立数据库的步骤记录下来. 一.用命令在Ubuntu上安装MySQL # sudo apt-get update # sudo a ...

  8. 二进制包安装MySQL数据库

    1.1二进制包安装MySQL数据库 1.1.1 安装前准备(规范) [root@Mysql_server ~]# mkdir -p /home/zhurui/tools ##创建指定工具包存放路径 [ ...

  9. MYSQL数据库相关知识合集

    1  MYSQL取得某一范围随机数: 关键词:RAND() [产生0~1之间的随机数] mysql> SELECT RAND( ), RAND( ), RAND( ); +----------- ...

随机推荐

  1. 18岁,赚到了人生中的第一个10W!

    大家好,我是九歌 今年我18岁,赚到了我人生中的第一个10W 截至2019年10月14日,我已经做了43天的公众号啦,粉丝也悄然增长到了1W8,感谢各位读者朋友给我的支持和鼓励. 相信大部分读者都是从 ...

  2. WiFi曝出安全漏洞几近“裸奔”:运营商能借机收割一波红利吗?

    ​    作为大众生活中不可或缺的基础架构,也是智能生活普及的推动性力量,运营商的重要性毋庸置疑.但无奈的是,一直以来运营商都似乎是站在了大众的"对立面".看似光鲜亮丽,但在壮观的 ...

  3. 产品需求说明书PRD模版

    <软件自动化测试开发>出版了 XXX产品需求说明书 [版本号:V+数字]                 编  制: 日  期: 评  审: 日  期: 批  准: 日  期:       ...

  4. 从iPhone下滑 看科技转型之困

    看科技转型之困" title="从iPhone下滑 看科技转型之困"> 毫无疑问,苹果正在面临一次关键转型.最近苹果股价较高点134.54美元下跌21%以上的实事, ...

  5. 20170220-coroutine

    协程 coroutine 最近频繁的听说到 "协程" 这个词,花了一段时间肤浅的研究了一下.对于 "它是一个什么东西" 有了一个大概的了解. from wiki ...

  6. mysql插入数据报错一二

    上周selenium+phantomjs+python3简单爬取一个网站,往数据库写数据遇到以下两个问题,记录一下: 报错一:Data truncated for column 'update_tim ...

  7. harbor自动清理镜像

    harbor定时清理镜像 ​ 分享下最近写harbor仓库镜像自动清理脚本思路,很长时间不写shell脚本,这次的脚本也是匆匆写的,还有很多可优化点,感兴趣的可以参考自己优化下,写的不完善地方也希望指 ...

  8. 7-4 jmu-python-判断是否构成三角形 (10 分)

    7-4 jmu-python-判断是否构成三角形 (10 分)   输入三角形的三边,判断是否能构成三角形.若能构成输出yes,否则输出no. 输入格式: 在一行中直接输入3个整数,3个整数之间各用一 ...

  9. 关于HTTP那些事

    写这篇文章的原因 记录前端性能优化用到的关键概念 简化大家对HTTP的学习 大家或许面试的时候可以用得到哦 HTTP是什么 Web的应用层协议(超文本传输协议HyperText Transfer Pr ...

  10. webpack里的externals

    最近在用webpack做一些是sdk相关的东西,有几个概念总结一下: 1.library要做sdk,一定要做的一个配置,用于说明最终的SDK暴露给调用者的一个名称例如:library: 'HelloJ ...