MySQL连表update操作 一、介绍 记录一下MySQL连表后进行update的操作,这可以一口气同时改动到多张表的数据,可以取到关联表的数据进行更新。...作用还是比较大的,如下 二、使用 1)建表 分别有以下四张表,分别为 学生表 班级表 学生评分表 班级评分表 CREATE TABLE `tb_student` ( `id`...NOT NULL COMMENT '班级ID', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT = '学生表'...; 模型如下图 2)连表更新 如果班级里张三比较调皮,在班级座位后面睡觉被校长发现了,要把这位学生和所在班级的评分,各扣10分 如果是以前,我可能是写两条update语句的sql,现在的话,可以关联起来这样写...`name` = '张三'; ---- 那么此时,我们只需要做一点小小的改动,就可以把上述sql改为连表update的了。
数据操作语言:表连接查询(一) 从多张表中提取数据 从多张表提取数据,必须指定关联的条件。如果不定义关联条件就会出现无条件连接,两张表的数据会交叉连接,产生 笛卡尔积。...表连接分为两种:内连接 和 外连接 内连接是结果集中只保留符合连接条件的记录 外连接是不管符不符合连接条件,记录都要保留在结果集中 内连接的简介 内连接是最常见的一种表连接,用于查询多张关系表符合连接条件的记录...内连接的多种语法形式 SELECT ...... FROM 表1 JOIN 表2 ON 连接条件; SELECT .........t_emp e JOIN t_dept d ON e.deptno=d.deptno JOIN t_salgrade s ON e.sal BETWEEN s.losal AND s.hisal; 内连接的数据表不一定必须有同名字段...,只要字段之间符合逻辑关系就可以 内连接练习2 查询与 SCOTT 相同部门的员工都有谁?
关键字distinct 去除重复记录 可配合分组函数使用 select distinct job,deptno from emp; 未使用 distinct之前 使用后: 笛卡尔积现象:当两张表进行连接查询的时候
个人博客:"DBA老司机带你删库跑路" 建库 库名:linux50 字符集:utf8 校验规则:utf8_general_ci  建表 ---- 表一 表名:student(学生表) 字段...表名:course(课程表) 字段 数据类型要求 是否为空 注释 cno 最多20位 否 课程号(主键) cname 可变长 否 课程名称 tno 可变长 否 教师编号  ---- 表三 表名...(数据自定义) 2.将曾导、徐导、李导信息插入教师表中(数据自定义) 3.将数学、语文、英语学科插入到课程表中(数据自定义) 4.将分数插入到成绩表中(数据自定义) 查询练习: 1.查询student表中的所有记录的...3.查询student表的所有记录。 4.查询score表中成绩在60到80之间的所有记录。 5.查询score表中成绩为85,86或88的记录。...6.查询student表中1班或性别为“女”的同学记录。 7.以class降序查询Student表的所有记录。 8.以cno升序、mark降序查询Score表的所有记录 9.查询2班的学生人数。
数据操作语言:表连接查询(二) 内连接查询联系1 查询底薪超过公司平均底薪的员工信息? # 查询底薪超过公司平均底薪的员工信息?...JOIN t_dept d ON e.deptno=d.deptno WHERE d.dname="RESEARCH"; SELECT FLOOR(28.9); SELECT CEIL(1.1); 内连接查询联系
本篇博客主要介绍的内容是表的连接,在MySql中表的连接分为内连接和外连接,下面,我们直接进入主题把 内连接 内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我们前面学习的查询都是内连接...-- 语法 select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件; 对于内连接,我们还是通过案例来进行练习,加强理解: 显示SMITH的名字和部门名称 --...前面的写法 select emp.ename,dept.dname from emp,dept where emp.deptno=dept.deptno andename='SMITH'; -- 内连接写法...,学习完内连接,我们在来看一看外连接。...d.deptno=e.deptno; -- 方法二: select d.dname, e.* from emp e right join dept d on d.deptno=e.deptno; 通过上面我们了解了表的内连接与外连接
个人网站:【芒果个人日志】 原文地址:SAP ABAP——内表(二)【创建内表】 - 芒果个人日志 (wyz-math.cn) 作者简介: THUNDER王,一名热爱财税和SAP ABAP...- 效果演示 参照局部表类型定义内表 - 创建流程 - 示例代码 - 效果演示 参照全局表定义内表 - 创建流程 - 示例代码 - 效果演示 参照全局表类型定义内表 - 创建流程 -...全局表类型参数 - 示例代码 - 效果演示 旧式内表定义法 - 创建流程 - 示例代码 - 效果演示 参照局部结构体类型定义内表 - 创建流程 -1.首先定义结构体类型 TYPES:BEGIN...DATA:GT_SFLIGHT TYPE T_SFLIGHT. - 效果演示 参照局部表类型定义的内表效果图 ---- 参照全局表定义内表 - 创建流程 DATA:itab TYPE <target...旧式内表定义法即使没有使用[WITH HEADER LINE]语句,也默认包含表头行 旧式内表定义法只能用于标准表的创建 - 示例代码 DATA:BEGIN OF GT_SFLIGHT OCCURS 0
文章概要:本文主要介绍一下SAP ABAP中内表的命令,主要包括了内表赋值、内表初始化、内表排序、内表属性四个方面 每日一言:只有忍得住寂寞,才能够见明日的繁华。...目录 内表赋值 两个内表结构一致: - 不带表头行内表赋值 - 带表头行内表赋值 两个内表结构不一致: - 不带表头行内表赋值 - 带表头行内表赋值 内表初始化 -同时删除表数据和释放内存空间 -只删除表数据而不释放内存空间...-释放内存空间 内表排序 整表排序(除了排序表以外) -案例代码演示 -效果演示 指定排序字段(除了排序表以外) -案例代码演示 -效果演示 内表属性 -案例代码演示 -效果演示 -不设置内表初始大小效果演示...内表赋值 两个内表结构一致: - 不带表头行内表赋值 MOVE itab1 TO itab2....WRITE:/ '该内表的数据件数是:',GV_LINES,/'该内表的初始大小是:',GV_OCCURS,/'该内表的类型是:',GV_KIND. -不设置内表初始大小效果演示 效果演示2
个人网站:【芒果个人日志】 原文地址:SAP ABAP——内表(九)【删除内表数据】 - 芒果个人日志 (wyz-math.cn) 作者简介: THUNDER王,一名热爱财税和SAP...文章概要:本文主要介绍一下SAP ABAP中内表的增删查改语句中的删除内表数据的相关语句,包括利用关键字删除数据,利用索引删除数据,利用WHERE语句删除数据,删除重复语句行 每日一言:书山有路勤为径...WRITE:'内表数据删除前:'. LOOP AT GT_SFLIGHT INTO GS_SFLIGHT....WRITE:'内表数据删除后:'. LOOP AT GT_SFLIGHT INTO GS_SFLIGHT....WRITE:'内表数据删除前:'. LOOP AT GT_SFLIGHT INTO GS_SFLIGHT.
个人网站:【芒果个人日志】 原文地址:SAP ABAP——内表(十)【读取内表数据】 - 芒果个人日志 (wyz-math.cn) 作者简介: THUNDER王,一名热爱财税和SAP...文章概要:本文主要介绍一下SAP ABAP中内表的增删查改语句中的读取内表数据的相关语句,包括利用关键字读取数据,利用索引读取数据 每日一言:将来的你一定会感谢现在奋斗的自己。...WRITE:'内表数据展示如下:'. LOOP AT GT_SFLIGHT INTO GS_SFLIGHT....WRITE:'内表数据展示如下:'. LOOP AT GT_SFLIGHT INTO GS_SFLIGHT....WRITE:'内表数据展示如下:'. LOOP AT GT_SFLIGHT INTO GS_SFLIGHT.
目录 内表概要 内表的分类 不同内表速度比较及适用场景 内表概要 - 内表定义 内表是SAP ABAP中最具有影响力且最重要的功能之一,简而言之,用一句话概括内表的定义就是:内表是可以在程序内部定义并且使用的表...如下图展示出了参照数据库表sflight定义的内表的结构 参照sflight定义的内表结构 - 内表与数据库表区别 内表和数据库表的很大区别在于:数据库表中存放的数据是永久的;而内表是动态数组...- 内表的作用 一般来说针对数据库表中数据的操作,都要首先将数据库表中数据输出到内表中,再通过内表对数据进行处理,最后再更新回数据库表中,在这过程中,内表相当于起到一个中间桥梁的作用,极大地保护了数据库表中数据的安全性...内表的分类 在SAP ABAP中内表有三种类型,它们分别是标准表,排序表以及哈希表,下面将依次介绍三种表 - 标准表 标准表是有顺次索引的树型结构内表,是利用索引查找内表行数据时易于使用的内表类型。...不同内表速度比较及适用场景 为了更加直观地展现三种内表的速度和适用场景,将其制作成比较表展现如下: 语句 标准表 排序表 哈希表 READ语句速度比较 速度慢 速度快 速度最快 APPEND语句速度比较
个人网站:【芒果个人日志】 原文地址:SAP ABAP——内表(八)【修改内表数据】 - 芒果个人日志 (wyz-math.cn) 作者简介: THUNDER王,一名热爱财税和SAP...文章概要:本文主要介绍一下SAP ABAP中内表的增删查改语句中的修改内表数据的相关语句,包括利用关键字修改数据,利用索引修改数据,利用WHERE语句修改数据 每日一言:通过辛勤工作获得财富才是人生的大快事...WRITE:'内表修改前数据'. LOOP AT GT_SFLIGHT INTO GS_SFLIGHT....WRITE:'内表修改前数据'. LOOP AT GT_SFLIGHT INTO GS_SFLIGHT....ENDLOOP. - 效果演示 使用where语句修改内表数据
在MySQL中如果两张表的字符排序集(Collate)不同(比如一张表为utf8mb4_general_ci, 另一张表为utf8mb4_unicode_ci),在连表查询时就可能会如下类似的错误:...collations (utf8mb4_general_ci,IMPLICIT) and (utf8mb4_unicode_ci,IMPLICIT) for operation '=' ### 可以通过如下语句修改表的字符排序集
那么这SQL不优化直接第一次执行需要多久(这里强调第一次是因为MYSQL带有缓存功能,执行过一次的同样SQL,第二次会快很多。) ?...8、执行distinct去重复数据 9、执行order by字句 10、执行limit字句 这里得知,Mysql 是先执行内联表然后再进行条件查询的最后再分组,那么想想这SQL的条件查询和分组都只是一个表的...总结: 整个过程中我们得知,其实EXPLAIN有时候并不能指出你的SQL的所有问题,有一些隐藏问题必须要你自己思考,正如我们这个例子,看起来临时表是最大效率低的源头,但是实际上9W的临时表对MYSQL来说不足以挂齿的...我们进行内联查询前,最好能限制连的表大小的条件都先用上了,同时尽量让条件查询和分组执行的表尽量小。感谢您们的阅读,如果有更好的方案,欢迎留言交流!!! 估计到这里,你猜这里就是全部的优化方案?...总结: 其实这个优化方案跟我上一篇文章MYSQL一次千万级连表查询优化(一)解决原理一样,都是解决了内联表后数据就变得臃肿了,这时候再进行条件查询和分组就太吃亏了,于是我们可以先对单表进行条件处理,再进行连表查询
个人网站:【芒果个人日志】 原文地址:SAP ABAP——内表(五)【追加内表数据—INSERT】 - 芒果个人日志 (wyz-math.cn) 作者简介: THUNDER王,一名热爱财税和...文章概要:本文主要介绍一下SAP ABAP中内表的增删查改语句中的追加内表数据的INSERT相关语句,包括使用关键字追加和使用索引追加以及不同类型内表使用INSERT追加数据的不同效果 每日一言:别人能做到的事...WRITE:'追加前内表数据'. LOOP AT GT_SFLIGHT INTO GS_SFLIGHT....只支持关键字追加数据 使用关键字INSERT效果比较 1.默认追加数据到内表最后一行 2.与APPEND语句具有相同效果 1.按照内表排序的顺序追加数据 2.若关键字不唯一,重复的数据 会追加到相同数据的上一行中...影响了排序表的排列顺序,则程序报错 不能使用索引进行INSERT - 案例代码演示(排序表和哈希表使用关键字INSERT) 依次解除下面案例代码中这两种内表的注释,比较排序表和哈希表各自使用关键字
个人网站:【芒果个人日志】 原文地址:SAP ABAP——内表(七)【追加内表数据—COLLECT】 - 芒果个人日志 (wyz-math.cn) 作者简介: THUNDER王,一名热爱财税和...文章概要:本文主要介绍一下SAP ABAP中内表的增删查改语句中的追加内表数据的COLLECT相关语句 每日一言:黄金时代是在我们的前面,而不在我们的后面。...目录 COLLECT语句 - 案例代码演示(关键字相同) - 效果演示(关键字相同) - 案例代码演示(关键字不同) - 效果演示(关键字不同) COLLECT语句 对内表使用COLLECT语句时,除了关键字以外的数据类型必须为数字类型...SAP ABAP中COLLECT语句以关键字为基准合计内表中数字类型的字段,如果内表没有定义关键字,则会自动以字符串类型的字段为关键字。
个人网站:【芒果个人日志】 原文地址: SAP ABAP——内表(六)【追加内表数据—APPEND】 - 芒果个人日志 (wyz-math.cn) 作者简介: THUNDER王,一名热爱财税和...文章概要:本文主要介绍一下SAP ABAP中内表的增删查改语句中的追加内表数据的APPEND相关语句,包括使用索引追加数据(APPEND语句不能使用关键字追加数据)以及不同类型内表使用APPEND追加数据的不同效果...PS:如果使用[SORTED BY col]语句则会自动以字段col为基准降序排序后追加数据,此语句只适用于标准表,另外还需用[INITIAL SIZE n]指定内表大小!!...ENDLOOP. - 效果演示 利用索引追加多条数据 ---- 不同类型内表APPEND的不同效果 \ 标准表 排序表 哈希表 区别 1.默认追加数据到最后一行 2.可以使用[SORTED BY...-效果代码演示 为内表追加了一行空行
1、连表查询的原因 (1)如果查询结果不在一个表中,在多个表中,那就需要将表关联,进行连表查询。 (2)连表查询大多数都作用在外键得基础上。—表与表之间有关联。...2.1表与表之间存在的关系 (1)一对多:在多的一方添加外键列 (2)多对多:需要创建一个中间表,该表中至少有两个外键列 2.2连表查询 2.3内连接 内连接演示—结果都是一样,只是语法不同。...连表得条件。...-- 连表查询时,如果不使用连表条件则出现笛卡尔集。...A表 inner join B表 on 连表条件。
——果戈理 今天做了个小测试啊 我自己造了一百万多条(1029708条)数据 这里测试呢我们首先是编写了一个LEFT JOIN 连表SQL如下 SELECT * FROM `film`...("耗时:" + ((endTime - startTime) / (1000.0 * 1000.0)) + " ms"); 最后耗时为22289.5385 ms,大约20来秒,可以看到明显比上面的连表查询要快...,所以再连一次差别也并不是特别大 但可以明显看出,多了4秒左右 我们写成单表的话 long startTime = System.nanoTime(); List films =...发现仅仅多了一秒左右啊 上面的连表SQL,就算在language表的language_id上加了索引,也是耗时35314.184 ms 也远远没有我们的单表快 所以结论: 同样的数据,单表多次查询在正确使用下...,比连表确实快不少 但连表只需要一条SQL而单表需要写一大堆代码
领取专属 10元无门槛券
手把手带您无忧上云