PostgreSQL-7-数据连接
1、通过WHERE进行简单连接
SELECT * FROM company3,department 不添加WHERE将会显示所有数据
SELECT * FROM company3,department WHERE company3.no = department.id; 通过WHERE构建匹配逻辑
SELECT company3.name,company3.salary,department.dept
FROM company3,department WHERE company3.no = department.id; 显示指定字段
通过select+where,创建多个表的连接
2、内连接(INNER JOIN)
CREATE TABLE employees(
id int PRIMARY KEY,
name text,
age int CHECK(age > 0),
address text,
salary numeric CHECK(salary > 0)
);
INSERT INTO employees VALUES(1,'王大',25,'beijing',10000),(2,'张三',25,'beijing',10000),
(3,'李四',21,'beijing',15000),(4,'李二',28,'shenzhen',10000),
(5,'王五',24,'shanghai',20000),(6,'杨三',19,'shanghai',15000),
(7,'张四',22,'shenzhen',20000),(8,'杨四',20,'beijing',10000);
创建表格1
CREATE TABLE department(id int,dept text,fac_id int);
INSERT INTO department VALUES(1,'IT', 1);
INSERT INTO department VALUES(2,'Engineering', 2);
INSERT INTO department VALUES(3,'HR', 7);
INSERT INTO department VALUES(10,'Market', 10);
创建表格2
SELECT employees.id,employees.name,department.dept
FROM employees INNER JOIN department
ON employees.id = department.id;
基于两个表格的id字段,连接表格,取交集
3、全连接(FULL OUTER JOIN)
SELECT employees.id,employees.name,department.dept
FROM employees FULL OUTER JOIN department
ON employees.id = department.id;
基于两个表格的id字段,连接表格,取并集,缺失值为NULL
4、左外连接(LEFT OUTER JOIN)
SELECT employees.id,employees.name,department.dept
FROM employees LEFT OUTER JOIN department
ON employees.id = department.id;
连接表格后,保留employees的所有数据条目
5、右外连接(RIGHT OUTER JOIN)
SELECT employees.id,employees.name,department.dept
FROM employees RIGHT OUTER JOIN department
ON employees.id = department.id;
连接表格后,保留department的所有数据条目
6、交叉连接
SELECT employees.id,dept,salary FROM employees CROSS JOIN department;
笛卡尔积:检索出的行的数目为第一个表中的行数乘以第二个表中的行数
当两个表有共同名称的字段(比如id),将会报错,所以这里需要指示,例如employees.id
多个连接条件
SELECT employees.id,employees.name,department.dept
FROM employees INNER JOIN department
ON employees.id = department.id
AND employees.id = department.fac_id;
JOIN连接三个表
CREATE TABLE education(name text,edu text);
INSERT INTO education VALUES('王大','本科'),('张三','本科'),
('李四','硕士'),('李二','本科'),
('王五','PHD'),('杨三','硕士'),
('张四','PHD'),('杨四','本科');
创建表格3
SELECT employees.id,employees.name,employees.age,employees.salary,department.dept
FROM (employees INNER JOIN education ON employees.name = education.name)
FULL OUTER JOIN department ON employees.id = department.id;
注意嵌套写法
PostgreSQL-7-数据连接的更多相关文章
- PostgreSQL查询数据(连接查询和子查询)
原料 --用户表 create table "SysUser"( "UserId" serial, --用户Id,自增 "UserName" ...
- Tapdata Cloud 2.1.4 来啦:数据连接又上新,PolarDB MySQL、轻流开始接入,可自动标记不支持的字段类型
需求持续更新,优化一刻不停--Tapdata Cloud 2.1.4 来啦! 最新发布的版本中,在新增数据连接之余,默认标记不支持同步的字段类型,避免因此影响任务的正常运行. 更新速览 ① 数 ...
- 帆软报表FineReport中数据连接之Weblogic配置JNDI连接
1. 制作报表的原理 在帆软报表FineReport设计器中先用JDBC连接到数据库,建立数据库连接,然后用SQL或者其他方法创建数据集,使用数据集制作报表,然后把建立的数据库连接从JDBC连接改成J ...
- 帆软报表FineReport中数据连接之Jboss配置JNDI连接
使用sqlsever 2000数据库数据源来做实例讲解,帆软报表FineReport数据连接中Jboss配置JNDI大概的过程和WEBSPHERE以及WEBLOGIC基本相同,用JDBC连接数据库制作 ...
- 帆软报表FineReport中数据连接之Websphere配置JNDI连接
以oracle9i数据源制作的模板jndi.cpt为例来说明如何在FineReport中的Websphere配置JNDI连接.由于常用服务器的JNDI驱动过大,帆软报表FineReport中没有自带, ...
- 帆软报表FineReport中数据连接之Tomcat配置JNDI连接
1. 问题描述 在帆软报表FineReport中,通过JNDI方式定义数据连接,首先在Tomcat服务器配置好JNDI,然后在设计器中直接调用JNDI的名字,即可成功使用JNDI连接,连接步骤如下: ...
- 帆软报表FineReport中数据连接的JDBC连接池属性问题
连接池原理 在帆软报表FineReport中,连接池主要由三部分组成:连接池的建立.连接池中连接使用的治理.连接池的关闭.下面就着重讨论这三部分及连接池的配置问题. 1. 连接池原理 连接池技术的核心 ...
- Netbeans 中创建数据连接池和数据源步骤(及解决无法ping通问题)
1.启动glassfish服务器, 在浏览器的地址栏中输入 http://localhost:4848 2.首先建立JDBC Connection Pools: 3.new 一个Connectio P ...
- htc M8 无法自动恢复数据连接(4g)的问题解决
情况如下:htc m8 tdd-lte的双待手机,4g.2g同时在线. 本月出现,在短时间没有信号的情况后,无法恢复数据连接,哪怕是edge,更不论4g了. 尝试各种方法无解.最后咨询10086解决此 ...
- Ajax之数据连接信息捕获
connDB.properties: DB_CLASS_NAME=com.mysql.jdbc.Driver DB_URL=jdbc:mysql://127.0.0.1:3306/db_datab ...
随机推荐
- LuNamp和LuManager的目录结构
/|---- etc/|-------- my.cnf #mysql配置文件|-------- ipfw.conf #ipfw防火墙的配置文件(仅FreeBSD)|---- home/|------- ...
- jquery中attr和prop的区别—判断复选框选中状态
最近项目中需要用jquery判断input里checkbox是否被选中,发现用attr()获取不到复选框改变后的状态,最后查资料发现jQuery 1.6以后新增加了prop()方法,借用官方的一段描述 ...
- RobotFramework教程使用笔记——requests和requestslibrary库
Robotframework也可以进行接口测试,只要导入相应的库就可以做到. 一.准备工作 1.导入requests,使用pip,或者手动下载 pip install requests 2.导入req ...
- iap 应用内购买相关的解释
应用范围app Store Review Guidelines : https://developer.apple.com/app-store/review/guidelines/ 中 11.12 ...
- android实现文字渐变效果和歌词进度的效果
要用TextView使用渐变色,那我们就必须要了解LinearGradient(线性渐变)的用法. LinearGradient的参数解释 LinearGradient也称作线性渲染,LinearGr ...
- 异步执行js脚本——防止阻塞
JS允许我们修改页面中的所有方面:内容,样式和用户进行交互时的行为. 但是js同样可以阻塞DOM树的形成并且延迟页面的渲染. 让你的js变成异步执行,并且减少不必要的js文件从而提高性能. JavaS ...
- nyoj 1279 (河南省第九届ACM比赛 D 题)
思路:变换一下坐标系新的坐标系就是给定的两条直线,变换之后求 x,y 都严格递增的点的个数的max: 求 x,y 都严格递增的点的个数的max,按照x的从小到大排序,x相同的按照y的从大到小排序然后对 ...
- object_test.py
#方法,属性,私有化加双下划线 ''' __a 从外部无法访问,但是类的内部可以访问.实际上还是能在类外访问这些私有方法,尽管不应该这么做:s._A__a 如果不需要使用这种方法但是又不行让其他对象不 ...
- 「UOJ#117」 欧拉回路
欧拉回路 - 题目 - Universal Online Judge 题意: 给定有向图或无向图,求一条欧拉回路. 题解 心路历程:woc什么傻哔东西->哇真香我的吗!(逃 首先我知道很多人把欧 ...
- button的FlatStyle和FlatAppearance属性
FlatStyle是处理边框的样式,而FlatAppearance是用来设置边框的颜色,宽度和鼠标移动和点击时的效果设置FlatStyle为Flat,并且设置FlatAppearance下的Borde ...