首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【数据库_03】MySQL-多表操作事务

一、多表查询 1....概述 ① 什么是事务 * 被事务管理的操作要么都成功要么都失败 ② 事务的提交方式 * 自动提交(MySQL) * 执行完一条SQL语句后自动提交 * 手动提交(...持久化 事务结束后,数据库会持久化保存 * 隔离性 多个事务之间相互独立 * 一致性 事务操作前后数据量不变(类似能量守恒) 2....事务执行的步骤 ① 开启事务 start transaction ② 执行操作 delete ··· insert ··· update ··· ③ 提交事务...where:从基表或视图中选择满足条件的元组(不能使用聚合函数) join:多表查询连接查询 on:多表查询连接查询条件 group by:分组,一般和聚合函数一起使用 having:在元组的基础上进行筛选

87720

MySQL多表查询和事务

概念: 如果一个包含多个步骤的业务操作,被事务管理,那么这些操作要么同时成功,要么同时失败。 2. 操作: 1....: set @@autocommit = 0; 事务的四大特征: 原子性:是不可分割的最小操作单位,要么同时成功,要么同时失败。...持久性:当事务提交或回滚后,数据库会持久化的保存数据。 隔离性:多个事务之间。相互独立。 一致性:事务操作前后,数据总量不变 事务的隔离级别(了解) 概念:多个事务之间隔离的,相互独立的。...但是如果多个事务操作同一批数据,则会引发一些问题,设置不同的隔离级别就可以解决这些问题。...幻读:一个事务操作(DML)数据表中所有记录,另一个事务添加了一条数据,则第一个事务查询不到自己的修改。

1.6K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MYSQL多表查询与事务

    多表查询 避免笛卡尔积 ? select * from emp,dept where emp.`dept_id` = dept.`id`;#设置过滤条件(隐式内连接) select emp....在某些成功的操作完成之后,后续的操作有可能成功有可能失败,但是不管成功还是失败,前面操作都已经成功,可以在当前成功的位置设置一个回滚点。...可以供后续失败操作返回到该位置,而不是返回所有操作,这个点称之为回滚点。 事务与隔离 ? ? ?...set global transaction isolation level read uncommitted;#设置事务隔离级别为读未提交 读未提交时,当A对数据进行操作但未提交时,B读取的信息是未提交信息...使用serializable隔离级别,一个事务没有执行完,其他事务的SQL执行不了,可以挡住幻读 ? DCL语句 mysqld是MySQL的主程序,服务器端。

    98720

    MySQL-多表操作

    多表查询 联合查询 联合查询是多表查询的一种方式,在保证多个SELETE语句的查询字段数相同的情况下,合并多个查询的结果 SELECT··· UNION [ALL|DISTINCT] SELECT···...但由于WHERE是限定已全部查询出来的记录,那么在数据量很大的情况下,此操作会浪费很多性能,所以此处推荐使用ON实现内连接的条件匹配。...然后根据比较结果完成相关需求的操作。 行子查询 当子查询的结果是一条包含多个字段的记录(一行多列)时,称为行子查询。...当数据源是子查询时必须为其设置别名,同时也是为了将查询结果作为一个表使用时,可以进行条件判断、分组、排序以及限量等操作。 ?...关联表操作 实体之间具有一对一、一对多和多对多的联系。 ➢具有关联的表中的数据,可以通过连接查询的方式获取,并且在没有添加外键约束时,关联表中的数据插入、更新和删除操作互不影响。

    3.2K20

    笔记29-MySQL多表&事务

    * 要完成多表查询,需要消除无用的数据 * 多表查询的分类: 1. 内连接查询: 1....`id`; 事务 1. 事务的基本介绍 1. 概念: * 如果一个包含多个步骤的业务操作,被事务管理,那么这些操作要么同时成功,要么同时失败。 2. 操作: 1....一致性:事务操作前后,数据总量不变 3. 事务的隔离级别(了解) * 概念:多个事务之间隔离的,相互独立的。...但是如果多个事务操作同一批数据,则会引发一些问题,设置不同的隔离级别就可以解决这些问题。 * 存在问题: 1. 脏读:一个事务,读取到另一个事务中没有提交的数据 2....不可重复读(虚读):在同一个事务中,两次读取到的数据不一样。 3. 幻读:一个事务操作(DML)数据表中所有记录,另一个事务添加了一条数据,则第一个事务查询不到自己的修改。

    23330

    Django ORM 多表操作

    目录 Django ORM 多表操作 表模型 表关系 创建模型 逆向到表模型 插入数据 ORM 添加数据(添加外键) 一对多(外键 ForeignKey) 一对一 (OneToOneFeild) 多对多...ManyToManyField):在第三张关系表中新增数据 ORM 修改数据 ORM 删除和清空数据 跨表查询 基于对象的跨表查询 基于双下划线的跨表查询 聚合查询 示例 F查询 Q查询 Django ORM 多表操作...6、若有模型类存在外键,创建数据时,要先创建外键关联的模型类的数据,不然创建包含外键的模型类的数据时,外键的关联模型类的数据会找不到 逆向到表模型 插入数据 ps:插入几条数据方便操作 ORM...='163@qq.com').first() author = author_det.author print(author.name) # 李白 基于双下划线的跨表查询 上面的操作类似子查询...,将上一个查询结果当作该次查询的条件使用,那么现在演示的跨表操作,就类似sql连表操作(inner join···),是两种不同的查询方法 '''基于双下划线的跨表操作:连表操作''' '

    1.8K20

    Django ORM 多表操作(二)

    目录 Django ORM 多表操作(二) 多对多操作常用API 分组查询 单表分组查询示例 多表分组查询练习 查询练习 ORM 事务 ORM 常见字段和参数 ORM常见字段 ORM 常见参数 choices...多对多关联关系的三种方式 方式一:自己创建第三张表 方式二:通过ManyToManyFeild自动创建第三张表 方式三:设置ManyTomanyField并指定自行创建的第三张表 元信息 原生sql Django ORM 多表操作...(二) 多对多操作常用API add remove clear set 示例 # 当前生成的书籍对象 book_obj=Book.objects.create(title="三国演义",price...: '南方出版社', 'book_num': 1}, {'name': '东方出版社', 'book_num': 1}, {'name': '西方出版社', 'book_num': 0}]> ORM 事务...'''django开启事务''' 导入模块: from django.db import transaction # 示例 from django.db import transaction

    1.1K20

    java事务_Java 事务详解

    一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。...持久性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。...(2)Hibernate事务绑定 Hibernate使用本地线程绑定事务(所以不能在一个线程中启动多个线程去操作不同的数据工作),当请求Service方法时打开通过Soring AOP 自动打开 Hibernate...(1)JTA 在应用系统数据量越来越大时,系统数据就需要分布在不同的数据库中,当业务需求在多个数据库中做原子性操作时就可以选择JTA (Java Transaction API),JTA事务比JDBC事务更强大...(2)JTA原理 不同的数据库有不同的数据库供应商,JTA就是将这个不同的数据库管理起来,统一创建一个原子事务,全部成功即成功,一个不成功就回滚所有的操作(JTA还是较重量级) (3)实例 Spring

    1.5K20

    【框架】多表操作与缓存技术

    转载请注明出处:http://blog.csdn.net/qq_26525215 多表操作 关系型数据库具有三种常用关系:一对一关系、一对多关系和多对多关系。...all : 所有情况下均进行关联操作。 none:所有情况下均不进行关联操作。这是默认值。...save-update:执行save/update/saveOrUpdate时进行关联操作 delete:在执行delete时进行关联操作。...1、Hibernate缓存范围以及分类 (缓存的范围分为三类) (1) 事务范围: 缓存只能被当前事务访问。缓存的生命周期依赖于事务的生命周期,当事务结束时,缓存也就结束生命周期。...事务可以是数据库事务或者应用事务,每个事务都有独自的缓存。 (2) 应用范围: 缓存被应用范围内的所有事务共享的。这些事务有可能是并发访问缓存,因此必须对缓存采取必要的事务隔离机制。

    48110

    数据库_mysql多表操作

    多表操作 实际开发中,一个项目通常需要很多张表才能完成。例如:一个商城项目就需要分类表(category)、商品表(products)、订单表(orders)等多张表。...且这些表的数据之间存在一定的关系,接下来我们将在单表的基础上,一起学习多表方面的知识。 ?...主表的主键); [外键名称]用于删除外键约束的,一般建议“_fk”结尾 altertable 从表 drop foreignkey 外键名称 l 使用外键目的: n 保证数据完整性 1.3 一对多操作...table products add constraint product_fkforeign key (category_id) references category (cid); 1.3.3 操作...pid) references products(pid); ### 联合主键(可省略) alter table `orderitem` add primary key (oid,pid); 1.4.3 操作

    2.2K80
    领券