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

SQL的区别及注意事项

数据库 db 数据库 dba 数据库工程师 存放数据的仓库 分类 对象关系型数据库,将数据(表)以文件方式存储在磁盘上,mysql,oracle,sqlserver 非关系型数据库,也叫nosql,以键值对的形式去存放数据...查询返回的结果集是一张虚拟表。...(pageIndex-1)*pageSize,pageSize 如何确保数据的完整性 注意 主键约束不能为空,且唯一 唯一约束可以为多个null,它只需保证存在的值唯一 连接查询 合并结果集:需要保证结果集字段一样...内连接 外连接 左外连接 右外连接 内连接 内连接是用来把满足某一个条件两个结果集合并起来,并一一对应, 此时两张表中任意一张表中的关联字段在例外一张表关联字段中不存在, 那么该数据则不会显示...外连接 是以一张表为主表,另一张表为匹配表,主表的内容全部显示,然后用匹配表去匹配主表中的内容 在左外连接中,左表为主表,右表为匹配表 在右外连接中,右表为主表,左表为匹配表

70420

一文搞定MySQL多表查询中的表连接(join)

对应关系:关键字段中有重复值的表为多表,没有重复值的表为一表。 表对应关系 一对一关系 在一对一关系中,A 表中的一行最多只能匹配于 B 表中的一行,反之亦然。...如果相关列都是主键或都具有唯一约束,则可以创建一对一关系。 这种关系并不常见,因为一般来说,按照这种方式相关的信息都在一个表中。可以利用一对一关系来: 分割具有多列的表。...在这种关系中,A 表中的一行可以匹配 B 表中的多行,但是 B 表中的一行只能匹配 A 表中的一行。例如,部门表和 人员表之间具有一对多关系:每个部门有很多员工,但是每个员工只属于一个部门。...只有当一个相关列是一个主键或具有唯一约束时,才能创建一对多关系。 ? 多对多关系 在多对多关系中,A 表中的一行可以匹配 B 表中的多行,反之亦然。...而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。

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

    java数据库的介绍和使用_java实现数据库的查询

    --连接查询 --内连接 --等值连接:建立在父子表关系上,用等号来连接两个表 select e.empno,e.ename,e.job,e.sal,d.deptno,d.dname from emp...--左外连接(LEFT OUTER JOIN):左外连接可以把左表中不满足对应关系的数据查询出来 select e.empno,e.ename,e.job,e.sal,d.deptno,d.dname...--3.外键的数据类型必须与主表中主键的数据类型完全相同 --4.外键可以是null值 /* 表与表之间的关系 */ --1.一对多: 一张表中的一条记录再另一张表中出现多次 --2.多对多: 要想两张表之间实现多对多的关系...,必须有一张中间表,通过中间表创建与两张表的外键约束,实现多个一 对多,使用这种方式创建外键约束,非常适合实现多个一对多。...--3.一对一:一张表里的记录,在另外一张表里只能出现一次.表和表之间的关系必须通过外键来创建,但是外键一创建就是一对多,因此在从表里将外键设置唯一性约束,实现一对一 版权声明:本文内容由互联网用户自发贡献

    1.3K30

    定了!MySQL基础这样学

    6.5.1.3、结论 6.5.1.4、例子 6.5.2、外键约束(foreign key) 6.5.3、唯一性约束(unique) 6.6、表与表之间的关系 6.6.1、一对一 6.6.2、一对多(...t_user和t_section的关系,从t_user来看就是一对多,而从t_section的角度来看就是多对一!这种情况都是在多方创建外键!...九、多表查询 9.1、连接查询     在实际开发中,大部分的情况下都不是从单表中查询数据,一般是多张表进行联合查询取出最终的结果,一般一个业务都会对应多张表。 ​...左连接有连接的写法,右连接也有对应的左连接的写法。用左连接LEFT的时候,说明上面(左边)的表是主表。...典型的例子就是一对多,遇到一对多问题的时候背口诀:一对多?两张表,多的表加外键。

    2.2K20

    MySQL基础

    关系型数据库:建立在关系模型基础上,由多张相互连接的二维表组成的数据库。...,则采用默认值 DEFAULT 检查约束(8.0.1版本后) 保证字段值满足某一个条件 CHECK 外键约束 用来让两张图的数据之间建立连接,保证数据的一致性和完整性 FOREIGN KEY 约束是作用于表中字段上的...主表名(主表字段名) ON UPDATE 行为 ON DELETE 行为; 多表查询 多表关系 一对多(多对一) 多对多 一对一 一对多 案例:部门与员工 关系:一个部门对应多个员工,一个员工对应一个部门...实现:在多的一方建立外键,指向一的一方的主键 多对多 案例:学生与课程 关系:一个学生可以选多门课程,一门课程也可以供多个学生选修 实现:建立第三张中间表,中间表至少包含两个外键,分别关联两方主键...; 一对一 案例:用户与用户详情 关系:一对一关系,多用于单表拆分,将一张表的基础字段放在一张表中,其他详情字段放在另一张表中,以提升操作效率 实现:在任意一方加入外键,关联另外一方的主键,并且设置外键为唯一的

    1.9K10

    N天爆肝数据库——MySQL(3)

    默认值 约束: 概念 约束是作用于表中字段上的规则,用于限制存储在表中的数据。...和完整性 外键约束: 概念 外键用来让两张表中的数据之间建立连接,从而保证数据的一致性和完整性。...CASCADE ON DELETE CASCADE; 多表关系 概述 各个表结构之间相互存在联系有:一对多,多对多,一对一 一对多(多对一) 实现:在多的一方建立外键,指向一的一方的主键 举例:员工和部门...多对多 实现:建立第三张中间表,中间表至少包含两个外键,费别关联两方的主键 案例:学生于课程 一对一 实现:在任意一方加入外键,关联另外一方的主键,并且设置外键为唯一的(UNIQUE) 案例:用户与用户详细信息的关系...多表查询 概述:指从多张表中查询数据 笛卡尔积:在多表查询时,需要消除无效的笛卡尔积 分类 连接查询 内连接:相当于查询A,B交集部分数据 外连接 左外连接:查询左表所有数据,以及两张表交集部分数据

    18720

    day05_MySQL学习笔记_02

    主键用于唯一地标识表中的每一条记录,可以定义一列或多列为主键。      特点:主键的数据唯一,且不能为null。   ...注意:MySQL在唯一约束下可以允许有多个null值,Oracle、SQL Server 在唯一约束下不可以有多个null值。       ...(也就是说仍然有主从表的关系) ?     一对多(多对一):       最为常见的就是一对多!一对多和多对一,这是从哪个角度去看或者说以谁为参照物。  ...以表emp为主。     左外连接是先查询出左表(即以左表为主),然后查询右表,右表中满足条件的显示出来,不满足条件的显示NULL。     ...但在左连接中,因为emp表是左表,所以左表中的记录都会查询出来,即“张三”这条记录也会查出,但相应的右表部分显示NULL。 ?

    2.1K20

    MySQL数据查询之多表查询

    ,如果被DEFAULT约束的位置没有值,那么这个位置将会被DEFAULT的值填充 表与表之间的联系 1.表关系分类:   总体可以分为三类: 一对一 、一对多(多对一) 、多对多 2.如何区分表与表之间是什么关系...#分析步骤: #多对一 /一对多 #1.站在左表的角度去看右表(情况一) 如果左表中的一条记录,对应右表中多条记录.那么他们的关系则为 一对多 关系.约束关系为:左表普通字段, 对应右表foreign...注意:如果左表与右表的情况反之.则关系为 多对一 关系.约束关系为:左表foreign key 字段, 对应右表普通字段....#一对一 #2.站在左表的角度去看右表(情况二) 如果左表中的一条记录 对应 右表中的一条记录. 则关系为 一对一关系....#多对多 #3.站在左表和右表同时去看(情况三) 如果左表中的一条记录 对应 右表中的多条记录,并且右表中的一条记录同时也对应左表的多条记录. 那么这种关系 则 多对多 关系.

    8.2K20

    MySQL之多表查询

    ,如果被DEFAULT约束的位置没有值,那么这个位置将会被DEFAULT的值填充   九.表与表之间的关系 1.表关系分类:   总体可以分为三类: 一对一 、一对多(多对一) 、多对多 2.如何区分表与表之间是什么关系...#分析步骤: #多对一 /一对多 #1.站在左表的角度去看右表(情况一) 如果左表中的一条记录,对应右表中多条记录.那么他们的关系则为 一对多 关系.约束关系为:左表普通字段, 对应右表foreign...注意:如果左表与右表的情况反之.则关系为 多对一 关系.约束关系为:左表foreign key 字段, 对应右表普通字段....#一对一 #2.站在左表的角度去看右表(情况二) 如果左表中的一条记录 对应 右表中的一条记录. 则关系为 一对一关系....#多对多 #3.站在左表和右表同时去看(情况三) 如果左表中的一条记录 对应 右表中的多条记录,并且右表中的一条记录同时也对应左表的多条记录. 那么这种关系 则 多对多 关系.

    8.6K120

    Mysql数据库2

    key多表的分析和设计 关系分类:一对多的关系:一个部门可以有多个员工, 一个员工只能属于某一个部门....一个分类下有多个商品, 一个商品只能属于某一个分类.一个用户产生多个订单, 一个订单只能属于某一个用户.多对多的关系:一个学生可以选择多门课程, 一个课程也可以被多个学生选择.一个订单包含多个商品, 一个商品也可以在多个订单中....一对一的关系: 一个公司只能对应一个注册地址, 一个注册地址只能对应一个公司.多表建表原则一对多的建表原则:* 在"多"的一方创建一个字段, 作为外键, 指向"一"的一方的主键.多对多的建表原则:*...需要创建第三张表(中间表), 在中间表中至少需要有两个字段, 分别作为外键指向多对多双方的主键.一对一的建表原则:* 唯一外键对应.多表查询连接查询交叉连接: //了解 select * from...左外连接: 左边表的全部 和 两个表的交集.

    65230

    Web-第六天 MySQL回顾学习

    4.2.3 一对一关系:(了解) 在实际的开发中应用不多.因为一对一可以创建成一张表. 两种建表原则: 外键唯一:主表的主键和从表的外键(唯一),形成主外键关系,外键唯一unique。...例如用户表和用户帐户表 原因二:将经常查询的字段放到一张表中,不经常查询的数据放到一张表中 一对多: 如:类别表和商品表、用户表和订单表 一对多建表原则:在多的一方(从表)中创建外键与一的一方(主表)的主键进行关联...父子关系。 多对多: 如:订单表与商品表、用户表和角色表、角色表和功能表 多对多的建表原则:在两张表的中间建立一个关系表维护两张表的多余多的关系 注意:怎么看两张表的关系?...连接产生的结果集,可以定义为首先对两张表做笛卡尔积(交叉连接) -- 将 A 中的每一行和 B 中的每一行组合,然后返回满足连接谓词的记录。...; 上面这条sql我们使用的是左外连接,它的意思就是说以user表为准,保留user表中所有数据,右表orders中没有关联的数据,那么就以null关联显示出来, 执行的结果如下: ?

    83020

    MySQL-多表操作

    它用于返回连接关键字(RIGHT JOIN)右表(主表)中所有的记录,以及左表(从表)中符合连接条件的记录。 当右表的某行记录在左表中没有匹配的记录时,左表中相关的记录将设为空值。...判断指定的条件是否在子查询语句返回的结果集中。 然后根据比较结果完成相关需求的操作。 行子查询 当子查询的结果是一条包含多个字段的记录(一行多列)时,称为行子查询。...外键约束 添加外键约束 外键指的是-一个表中引用另一个表中的一列或多列,被引用的列应该具有主键约束或唯一性约束, 从而保证数据的一-致性 和完整性。 ➢被引用的表称为主表。...ON DELETE与ON UPDATE用于设置主表中的数据被删除或修改时,从表对应数据的处理办法。 ? 关联表操作 实体之间具有一对一、一对多和多对多的联系。...➢具有关联的表中的数据,可以通过连接查询的方式获取,并且在没有添加外键约束时,关联表中的数据插入、更新和删除操作互不影响。

    3.2K20

    Oracle查看分析执行计划、建立索引以及SQL优化

    前提条件:表有一个复合索引,且在查询时有除了前导列(索引中第一列)外的其他列作为条件,并且优化器模式为CBO时 当Oracle发现前导列的唯一值个数很少时,会将每个唯一值都作为常规扫描的入口,在此基础上做一次查找...散列(hash)技术:在记录的存储位置和记录具有的关键字key之间建立一个对应关系 f ,使得输入key后,可以得到对应的存储位置 f(key),这个对应关系 f 就是散列(哈希)函数; 采用散列技术将记录存储在一块连续的存储空间中...JOIN( RIGHT JOIN,右外连接) FULL OUTER JOIN( FULL JOIN,全外连接) a) LEFT JOIN(左连接): 返回的结果不仅包含符合连接条件的记录,还包含左边表中的全部记录...(若返回的右表中某行记录在左表中没有匹配项,则左表中的返回列均为空值) 两种写法: Ⅰ:select a.id A_ID, a.name A_NAME, b.id B_ID, b.name B_NAME...特别注意:(+) 操作符在左表的连接条件上表示右连接,在右表的连接条件上表示左连接。

    4.1K20

    SQL面试 100 问

    左外连接(LEFT OUTER JOIN),返回左表中所有的数据行;对于右表中的数据,如果没有匹配的值,返回空值。...全外连接(FULL OUTER JOIN),等价于左外连接加上右外连接,返回左表和右表中所有的数据行。MySQL 不支持全外连 接。...,而需要使用左外连接或者右外连接;否则可能缺少某些部门的结果。...行子查询(row query):返回包含一个或者多个值的单行结果(一行多列),标量子查询是行子查询的特例。表子查询(table query):返回一个虚拟的表(多行多列),行子查询是表子查询的特例。...关系用于表示两个实体之间的关联。例如,员工属于部门。三种主要的关系是一对一、一对多和多对多关系。例如,一个员工 只能属于一个部门,一个部门可以有多个员工,部门和员工是一对多的关系。

    2.5K22

    Oracle数据库学习

    由于一个班级可以有多个学生,在关系模型中,这两个表的关系可以称为“一对多”,即一个classes的记录可以对应多个students表的记录。...为了表达这种一对多的关系,我们需要在students表中加入一列class_id,让它的值与classes表的某条记录相对应: id class_id name other columns… 1 1 小明...删除列是通过DROP COLUMN ...实现的。 多对多 通过一个表的外键关联到另一个表,我们可以定义出一对多关系。有些时候,还需要定义“多对多”关系。...一对一 一对一关系是指,一个表的记录对应到另一个表的唯一一个记录。...使用主键索引的效率是最高的,因为主键会保证绝对唯一。 唯一索引 在设计关系数据表的时候,看上去唯一的列,例如身份证号、邮箱地址等,因为他们具有业务含义,因此不宜作为主键。

    1.9K40

    MySQL表的增删改查(进阶)

    表的设计 在数据库设计中,表之间的关系是至关重要的。MySQL支持一对一、一对多和多对多的关系。 一对一 每个记录只对应另一个表中的一条记录。...一对多 一种常见的表关系,在这种关系中,父表的每一条记录可以与子表中的多条记录相关联。 多对多 多对多关系通常需要一个中间表来映射两张表的关系。 4....FROM 表1,表2 where 表1.列名 = 表2.列名; ​ 6.2 左连接(LEFT JOIN) 左连接(也叫左外连接)返回左表中的所有记录,以及右表中匹配的记录。...FROM 表1 LEFT JOIN 表2 ON 表1.列名 = 表2.列名; 6.3 右连接(RIGHT JOIN) 右连接(也叫右外连接)与左连接类似,不同之处在于它返回右表中的所有记录,以及左表中匹配的记录...如果左表中没有匹配的记录,结果中的左表字段将为NULL。 SELECT 列1, 列2, ...

    6310

    2024Mysql And Redis基础与进阶操作系列(6)作者——LJS

    且这些表 的数据之间存在一定的关系,如下图: MySQL多表之间的关系可以概括为:一对一、一对多/多对一关系,多对多 1.1 一对一关系 比如 一个学生只有一张身份证; 一张身份证只能对应一学生...在任一表中添加唯一外键,指向另一方主键,确保一对一关系。 一般一对一关系很少见,遇到一对一关系的表最好是合并表。...1.2 一对多/多对一关系 比如: 部门和员工关系:一个部门有多个员工,一个员工只能对应一个部门 实现规则: 在多的一方建立外键,指向一的一方的主键 1.3 多对多关系 举例...中间表至少包含两个字段,将多对多的关系,拆成一对多的关系,中间表至少要有两个外键,这两个外键分别指向原来的那两张表的主键 2....; 多行多列 查询返回的结果是一张临时表 子查询回显的数据类型 单行单列 返回的是一个具体列的内容,可以理解为一个单值数据; 单行多列 返回一行数据中多个列的内容; 多行单列 返回多行记录之中同一列的内容

    11410

    SQL多表查询常用语句总结

    一、多表关系 (一)概述 项目开发中,在进行数据库表结构设计时,会根据业务需求及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各个表结构之间也存在着各种联系,基本上分为三种: 一对多...(多对一):在多的一方建立外键,指向一的一方的主键 多对多:建立中间表,包含两个外键,分别关联两方主键 一对一:一对一关系多用于单标拆分,将一张表的基础字段放在一张表中,其他详细字段放在另一张表,以提升操作效率...;实现:在仁义一方加入外键,并且设置外键为唯一的(UNIQUE) 二、多表查询概述 (一)多表查询概述 概述:指从多张表中查询数据 笛卡尔积:笛卡尔积是指在数学中,两个集合A集合和B集合的所有组合情况。...(在多表查询时,需要消除无效的笛卡尔积) (二)多表查询分类: 连接查询: ①内连接:相当于查询A,B交集部分数据 ②外连接: 左外连接:查询左表所有数据,以及两张表交集部分数据 右外连接...常用的操作符:=、、IN、NOT IN 表子查询(子查询结果为多行多列 子查询返回的结果是多行多列,这种子查询称为表子查询。

    69660

    MYSQL(基本篇)——一篇文章带你走进MYSQL的奇妙世界

    MYSQL却在工作中遇到ORACLE却无法使用的情况 数据库的启动和连接 数据库的正常启动一般在cmd命令行中: # 启动: net start mysql80 # 关闭: net stop mysql80...: 约束是作用于表中字段上的,可以在创建表/修改表的时候加上约束 外键绑定 定义: 用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性。...会根据业务需求以及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所有各个表之间也存在着各种联系 表与表的关系大致分为三种: 一对多 关系:一个部门对应多个员工,一个员工对应一个部门 实现...:在多的一方建立外键,指向一的一方的主键 多对多 关系:一个学生选择多个课程,一个课程有多个学生选择 实现:建立第三张中间表,中间表至少包含两个外键,分别关联两方主键 一对一 关系:一对一关系常用于单表内容过多...SOME 子查询返回列表中,有任意一个满足即可 ALL 子查询返回列表的所有值都必须满足 行子查询 概念: 子查询返回的结果是一行(可以是多列),这种子查询被称为行子查询 常用操作符: = 、

    1.7K40

    【21】进大厂必须掌握的面试题-65个SQL面试

    它用于合并两个表或从中检索数据。SQL中有4个连接,即: 内连接 右连接 左连接 全连接 Q6。 SQL中CHAR和VARCHAR2数据类型有什么区别?...左连接: MySQL中的左连接用于返回左表中的所有行,但仅返回右表中满足连接条件的匹配行。 右连接: MySQL中的右连接用于返回右表中的所有行,但仅返回满足连接条件的左表中的匹配行。...SQL中的组功能有什么需求? 组函数在一组行上工作,并且每个组返回一个结果。一些常用的组函数是:AVG,COUNT,MAX,MIN,SUM,VARIANCE。 Q34。什么是关系,它们是什么?...关系或链接是在相互关联的实体之间。关系定义为数据库中表之间的连接。存在各种关系,即: 一对一关系。 一对多关系。 多对一关系。 自引用关系。 Q35。...如何从表中选择唯一记录? 您可以使用DISTINCT关键字从表中选择唯一记录。

    6.9K22
    领券