2.查询数据(SELECT语句) 在PostgreSQL中,SELECT语句用于从数据库表中检索数据。 数据以结果表格的形式返回。 这些结果表称为结果集。...4.删除数据(DELETE语句) DELETE语句用于从表中删除现有记录。 “WHERE”子句用于指定删除所选记录的条件,如是不指定条件则将删除所有记录。...5.数据排序(ORDER BY子句) PostgreSQL ORDER BY子句用于按升序或降序对数据进行排序。数据在一列或多列的基础上进行排序。...6.分组(GROUP BY子句) PostgreSQL GROUP BY子句用于将具有相同数据的表中的这些行分组在一起。 它与SELECT语句一起使用。...FULL外连接从LEFT手表和RIGHT表中返回所有行。 它将NULL置于不满足连接条件的位置。
多表操作 外键约束 添加外键 语法 注意 表与表之间的关系 子查询的缺陷 一对多的关系 一对多的建表原则 多对多的关系 多对多的建表原则 一对一的例子 一对一的建表原则 多表案例分析 多表查询...---- 表与表之间的关系 子查询的缺陷 麻烦 mysql的子查询会单独创建一张临时表存放查询的结果集,等到整体查询完成之后会自动删除这个临时表 ---- 一对多的关系 一个部门下可以有多个员工,但是一个员工只能属于一个部门...---- 一对多的建表原则 在多的一方创建外键指向一的一方的主键 ---- 多对多的关系 一个学生可以选择多门课程,一个课程可以被多个学生选择、 多对多的建表原则 需要创建中间表,中间表中至少有两个字段...,来指定什么样的右表数据与左表匹配,那就使用on条件 如果是为了对整个临时表做筛选,那就使用where条件 如果是为了筛选左表的数据,也要使用where条件,因为左表的数据必定存在于临时表中,所有筛选左表的数据和筛选整个临时表一样...JOIN中 如果是为了筛选整个右表数据,来指定什么样的右表数据与左表匹配,那就使用on条件 如果是为了对整个临时表做筛选,那就使用where条件 如果是为了筛选左表的数据,也要使用where条件
、相似查询 • 多列:任意列组合查询 GiST • 空间类型:方位(上、下、左、右),空间关系(相交、包含),空间距离排序(KNN) • 范围数据:=, &&, , >, -|-,..., 1% 异常数据 索引特性 只有B-tree,GiST,GIN和BRIN索引类型支持多列索引。...PostgreSQL支持对表中部分数据建立索引,使用部分索引的一个主要原因是避免索引常见值。...由于搜索常见值的查询将不会使用索引,所以根本没有必要在索引中保留这些行,这样可以直接排除掉一部分数据,减少了索引的大小,性能更快。...PostgreSQL支持仅索引扫描,当要查询的目标列都在索引中时,直接使用索引中的键值进行返回,不需要回表操作。 技术永无止境,加油吧。 Catch.jpg
一、知识点名称 多表联合查询(一对多数据显示、多对多数据展示) 二、知识点业务场景 一对多关联: 学生和成绩的关系 用户与订单的关系 企业与员工的关系...用户与银行卡的关系 多对多关联: 学生和选课的关系 订单和商品的关系 用户和角色的关系 角色和权限的关系...) 四、功能实现步骤讲解 创建一张课程表 创建一张老师表 创建一张学生表 创建学生成绩中间表 1、一对多关联 将两个业务表关联查询,根据不同的需求,使用不同的连接方式,老师和课程表是一对多的关系...SQL语句如下: 查询出来的结果 二、多对多关联 将两个业务表和一个中间表,这三个表进行关丽娜查询,根据不同的需求,使用不同的连接方式。...学生和成绩表是多对多的关系。
关系型数据库:建立在关系模型基础上,由多张相互连接的二维表组成的数据库。...和 having 的区别: 执行时机不同:where是分组之前进行过滤,不满足where条件不参与分组;having是分组后对结果进行过滤。...多表关系 一对多(多对一) 多对多 一对一 一对多 案例:部门与员工 关系:一个部门对应多个员工,一个员工对应一个部门 实现:在多的一方建立外键,指向一的一方的主键 多对多 案例:学生与课程 关系:...左外连接: 查询左表所有数据,以及两张表交集部分数据。...dept的emp,右连接可以查询到没有emp的dept 自连接查询 当前表与自身的连接查询,自连接必须使用表别名 语法: SELECT 字段列表 FROM 表A 别名A JOIN 表A 别名B ON 条件
rollup在最后记录后面新增一行,显示select查询时聚合函数的统计和计算结果 连接查询 - 内连接 1、连接查询的介绍 连接查询可以实现多个表的查询,当查询的字段数据来自不同的表就可以使用连接查询来完成..., on 表示两个表的连接查询条件 左连接以左表为主根据条件查询右表数据,右表数据不存在使用null值填充。...连接查询 - 自连接 1、自连接查询 左表和右表是同一个表,根据连接查询条件查询两个表中的数据。...E-R模型的效果图: 说明: 实体: 用矩形表示,并标注实体名称 属性: 用椭圆表示,并标注属性名称, 关系: 用菱形表示,并标注关系名称 一对一 一对多 多对多 一对一的关系: 说明: 关系也是一种数据...,需要通过一个字段存储在表中 1对1关系,在表A或表B中创建一个字段,存储另一个表的主键值 一对多的关系: 说明: 1对多关系,在多的一方表(学生表)中创建一个字段,存储班级表的主键值 多对多的关系:
(显示左右表中全部数据) 全连接查询:是在内连接的基础上增加 左右两边没有显示的数据 注意: mysql并不支持全连接 full JOIN 关键字 注意: 但是mysql 提供了 UNION...#分析步骤: #多对一 /一对多 #1.站在左表的角度去看右表(情况一) 如果左表中的一条记录,对应右表中多条记录.那么他们的关系则为 一对多 关系.约束关系为:左表普通字段, 对应右表foreign...注意:如果左表与右表的情况反之.则关系为 多对一 关系.约束关系为:左表foreign key 字段, 对应右表普通字段....#一对一 #2.站在左表的角度去看右表(情况二) 如果左表中的一条记录 对应 右表中的一条记录. 则关系为 一对一关系....#多对多 #3.站在左表和右表同时去看(情况三) 如果左表中的一条记录 对应 右表中的多条记录,并且右表中的一条记录同时也对应左表的多条记录. 那么这种关系 则 多对多 关系.
6.6.2、一对多(多对一) 一对多(多对一):最为常见的就是一对多!一对多和多对一,这是从哪个角度去看得出来的。...t_user和t_section的关系,从t_user来看就是一对多,而从t_section的角度来看就是多对一!这种情况都是在多方创建外键!...6.6.3、多对多 例如t_stu和t_teacher表,即一个学生可以有多个老师,而一个老师也可以有多个学生。这种情况通常需要创建中间表来处理多对多关系。...,有时需要设置查询结果的显示格式,可以使用 CONCAT 函数来 连接字符串。...9.4.1.2、右连接 右连接就是先把右表中所有记录都查询出来,然后左表满足条件的显示,不满足显示NULL。
(也就是说仍然有主从表的关系) ? 一对多(多对一): 最为常见的就是一对多!一对多和多对一,这是从哪个角度去看或者说以谁为参照物。 ...多对多: 例如t_stu和t_teacher表,即一个学生可以有多个老师,而一个老师也可以有多个学生。这种情况通常需要创建中间表来处理多对多关系。 ...左外连接是先查询出左表(即以左表为主),然后查询右表,右表中满足条件的显示出来,不满足条件的显示NULL。 这么说你可能不太明白,我们还是用上面的例子来说明。 ...但在左连接中,因为emp表是左表,所以左表中的记录都会查询出来,即“张三”这条记录也会查出,但相应的右表部分显示NULL。 ? ...右连接就是先把右表中所有记录都查询出来,然后左表满足条件的显示,不满足显示NULL。
作者:不剪发的Tony老师 来源:CSDN 本文介绍关系数据库的设计思想:在 SQL 中,一切皆关系。 在计算机领域有许多伟大的设计理念和思想,例如: 在 Unix 中,一切皆文件。...关系模型中的数据结构就是关系表,包括基础表、派生表(查询结果)和虚拟表(视图)。 常用的关系操作包括增加、删除、修改和查询(CRUD),使用的就是 SQL 语言。...WHERE 用于指定数据过滤的条件,在关系运算中被称为选择(Selection),示意图如下: ? ORDER BY 用于对查询的结果进行排序,示意图如下: ?...JOIN 在 SQL 中,不仅实体对象存储在关系表中,对象之间的联系也存储在关系表中。因此,当我们想要获取这些相关的数据时,需要使用到另一个操作:连接查询(JOIN)。...左外连接(Left Outer Join)返回左表中所有的数据;对于右表,返回满足连接条件的数据;如果没有就返回空值。左外连接的原理如下图所示: ?
外键作用: 确保数据库数据的完整性和一致性 添加外键: 例如:foreign key(dept_id) references dept(id) 表关系: 一对多(多对一) (1)一个班级中可能会有多个学生...(1~) (2)一个学生只能属于一个班级(11),两者合并结果还是1 因此,班级表和学生表是一对多的关系 对于一对多的两张表,可以在多的一方添加列,保存一的一方的主键,从而保存两张表之间的关系...保存另一张表的主键,从而保存两张表之间的关系 多对多 (1)一个学生对应多个老师(1~) (2)一个老师也对应多个学生(1*),两者合并结果是* 因此,学生表和老师表是多对多的关系 对于多对多的关系...; 上面的查询(inner join…on…)方式也叫做内连接查询 外连接查询 1.左外连接查询 显示左侧表中的所有记录,如果在右侧表中没有对应的记录,则显示为null 语法: select ....多表查询 1、**(左外连接)**列出所有部门和部门下的员工,如果部门下没有员工, 显示为null。
表与表之间的关系 一对一 用户表和身份信息表,用户表是主表 男人表、女人表 create table man( mid int primary key auto_increment,...学生表和课程表,通常情况都是将多对多的关系拆分为一对多或者多对一的关系 至少需要三张表 create table student( cid int primary key auto_increment...为什么要使用多张表 避免出现大量的数据的冗余 并不是表拆的越多越好,需要根据实际情况进行拆分 3. 概念 同时查询多张表 4....- 注意: 内连接不写连接条件会出现笛卡尔积的结果,应该避免这种情况,而外连接不写连接条件会报错 - select from emp natural join dept; - select...注意的问题: - 括号 - 可以在主查询的where select having from 后面,都可以使用子查询 - 不可以在group by 后面使用子查询 - 主查询和子查询可以不是同一张表
以上备份数据库的命令中需要用户名和密码,即表明该命令要在用户没有登录的情况下使用 2....二.多表设计与实现(外键约束) 系统设计中,实体之间的关系有三种:一对一,一对多,多对多 也就是说,数据库开发中表与表之间的关系有三种,而表与表之间关系是通过外键来维护的。...外连接可依据连接表保留左表, 右表或全部表的行而进一步分为左外连接, 右外连接和全连接. 注意:mysql只支持左外连接与右外连接,而不支持全连接。 1....; 上面这条sql我们使用的是左外连接,它的意思就是说以user表为准,保留user表中所有数据,右表orders中没有关联的数据,那么就以null关联显示出来, 执行的结果如下: 2....; 这条sql我们使用的是右外连接,它的意思就是说以orders表为准,保留orders表中所有数据,左表user中没有关联的数据,那么就以null关联显示出来 五.多表查询-子查询 练习: 1.查看用户为张三的订单详情
多表关系 多表关系: 一对一 :在任意一方加入外键,关联另一方的主键,并设置外键为唯一(UNIQUE)。 一对多(多对一) :在多的一方建立外键,指向一的一方的主键。...多对多 :建立第三张表作为中间表,中间表至少包含两个外键,分别关联双方主键。 2. 多表查询 多表查询: 在多张表中查询数据。...—— LEFT OUTER JOIN 连接查询 —— 左外连接: 外连接 —— 左外连接: ①查询表1所有数据,包含表1和表2交集部分的数据。...`id`; 右外连接 —— RIGHT OUTER JOIN 连接查询 —— 右外连接 外连接 —— 右外连接: ①查询表2所有数据,包含表1和表2交集部分的数据。...`id`; 联合查询 —— UNION、UNION ALL 联合查询: UNION查询就是把多次查询的结果合并,行程新的结果集 -- 使用UNION,对结果去重 -- 使用UNION ALL,不对结果去重
,所以各个表结构之间也存在各种联系,基本上分为三种: —— 一对多(多对一) —— 多对多 —— 一对一 1、一对多 案例:部门与员工的关系 关系:一个部门对应多个员工,一个员工对应一个部门 实现:在多的一方建立外键...,指向一的一方的主键 ---- 2、多对多 案例:学生与课程之间的关系 关系:一个学生可以选修多门课程,一门课程也可以供给多个学生选择 实现:建立第三张中间表,中建表至少包含俩个外键,分别关联俩方主键...A、B交集的部分数据 外连接:左外连接:查询左表所有数据,以及俩张表交集部分的数据 右外连接:查询右表所有数据,以及俩张表交集部分的数据 自连接:当前表与自身表的连接查询...,那么就查询不到 查询结果 ---- 外连接 外连接查询的语法 ——左外连接 SELECT 字段列表 FROM LEFT [OUTER] JOIN 表2 ON 条件 相当于查询表1(左表)的所有数据包含表... outer 可以省略 案例演示 代码(左外连接) --1.查询emp表中所有数据,和对应部门信息(左外连接) -- 表结构: emp ,dept -- 连接条件: emp.dept_id = dept.id
案例说明 本案例以一对多关系的分类和商品表为例,进行常见的几种查询 交叉连接查询 语法:select * from A,B 内连接查询(使用的关键字 inner join -- inner...可以省略) 隐式内连接:select * from A,B where 条件; 显示内连接:select * from A inner join B on 条件; 外连接查询(使用的关键字 outer...= category.cid AND cname='家电' 内连接 左外连接: left outer join 左外链接列出左边关系中所有的元组 显示结果通常是 左表全部+右表有关联关系的部分,...WHERE cname='服饰') AND price < 500; 理论补充:表之间的关系 一对多关系 常见实例:客户和订单,分类和商品,部门和员工....多对多关系: 常见实例:学生和课程、用户和角色 多对多关系建表原则:需要创建第三张表,中间表中至少两个字段,这两个字段分别作为外键指向各自一方的主键.
目录 MySQL多表关系 一对一 一对多 多对多 MySQL外键约束 创建外键 数据插入 删除 多表联合查询 交叉连接查询 内连接查询 外连接查询 子查询关键字 自关联 MySQL多表关系 MySQL...表与表之间的三种关系 一对多关系:最常见的关系:学生对班级 , 员工对部门 多对多关系:学生与课程 , 用户与角色 一对一关系:使用较少,因为一对一关系可以合成为一张表 一对一 一个学生对应一个身份证号码...一对多 一个部门可以有多名员工,但一个员工只能归于一个部门 在多的一方建立外外键指向一的一方 多对多 下表为多对多关系,由下表可知多对多关系的中间表至少需要2个外键...多表联合查询 交叉连接查询 • 交叉连接查询返回被连接的两个表所有数据行的笛卡尔积 • 笛卡尔积 可以理解为一张表的每一行去和另外一张表的任意一行进行匹配...“false”,外层查询不执行 EXISTS后面的子查询不返回任何实际数据,只返回真或假,当返回真时 where条件成立 注意,EXISTS关键字,比IN关键字的运算效率高,因此,在实际开发中,特别是大数据量时
多表操作DQL 表之间的关系 合并结果集 连接查询 子查询 表与表的关系 一对多:主外键关联并且外键也是独一无二 例如:一夫一妻制 husband_id husband_name 1 张三 2 李四...course_id 1 1 1 2 2 1 2 2 学生有多门课,一个课也有多个学生,用第三张来设置外键就可以实现这种多对多的关系 合并结果集 什么是合并结果集 合并结果集就是把两个select语句的查询结果合并到一起...就需要自连接,当成两张表然后对应关系连接使用 */ SELECT * FROM 表 a INNER JOIN 表 b ON a.xxx = xxx AND a.yyy = b.xxx; 外连接 左外连接...(左连接) 两表满足条件相同的数据查出来,如果左边表当中有不相同的数据,也把左边表当中的数据查出来。...左边表当中的数据全部查出,右边表当中,只查出满足条件的内容 右连接 和左连接定义一样,左边只显示筛选出来的,右边全显示 自然连接 连接查询会产生无用笛卡尔集,我们通常使用主外键关系等式来去除它。
目录MySQL多表关系一对一一对多多对多MySQL外键约束创建外键数据插入删除多表联合查询交叉连接查询内连接查询外连接查询子查询关键字自关联MySQL多表关系MySQL表与表之间的三种关系一对多关系...:最常见的关系:学生对班级 , 员工对部门多对多关系:学生与课程 , 用户与角色一对一关系:使用较少,因为一对一关系可以合成为一张表一对一 一个学生对应一个身份证号码 一对多一个部门可以有多名员工,但一个员工只能归于一个部门...在多的一方建立外外键指向一的一方编辑多对多 下表为多对多关系,由下表可知多对多关系的中间表至少需要2个外键编辑 MySQL外键约束创建外键 格式: constraint foreign...交叉连接查询 •交叉连接查询返回被连接的两个表所有数据行的笛卡尔积 •笛卡尔积可以理解为一张表的每一行去和另外一张表的任意一行进行匹配 •假如A表有m行数据,B表有n行数据,则返回m*n行数据 •笛卡尔积会产生很多冗余的数据...后面的子查询不返回任何实际数据,只返回真或假,当返回真时 where条件成立注意,EXISTS关键字,比IN关键字的运算效率高,因此,在实际开发中,特别是大数据量时,推荐使用EXISTS关键字select
领取专属 10元无门槛券
手把手带您无忧上云