看到这篇带图的关于sql的连接查询,转过来作为参考
SQL 多表连接查询分为:内连接,外连接,交叉连接
内连接的使用 根据表中共同的列进行匹配,特别是存在主外键关系。
一般用的比较多
外连接 分为 左外连接,右外连接,完整连接
交叉连接返回的记录是两张表相乘的记录数
内连接主要一主表的信息为主 如果没有数据就不显示
例如 我们来看实例:
先建两张表:
create table student
(
id int primary key identity(1,1),
name varchar(50)
)
create table grade(
id int primary key identity(1,1),
score money
)
alter table grade add sid int
select * from grade
alter table grade add constraint fk_sid foreign key(sid) references student(id)
insert into student values('哈哈')
insert into student values('喜喜')
insert into student values('呵呵')
insert into student values('郁闷')
insert into student values('小强')
insert into student values('小马')
insert into grade values(90,1)
insert into grade values(80,2)
insert into grade values(70,null)
select * from student
select * from grade
内连接查询方式有两种:
1.select s.*,g.* from student s ,grade g where s.id=g.sid;
2.select s.*, g.* from student s inner join grade g on s.id=g.sid;
我们看到 我们主表没有主表没有匹配信息的时候 其他的记录没有显示
下面我们来看外连接:主要以从表信息为主 从表没有主表记录则显示为null
select s.*,g.* from student s left join grade g on s.id=g.sid
select s.*,g.* from student s right join grade g on s.id=g.sid
还可以是
select s.*,g.* from student s left outer join grade g on s.id=g.sid
select s.*,g.* from student s right outer join grade g on s.id=g.sid
看他是左还是右
下面来看看 完整连接:将两表的 左和右 基础数据全部查询出来 当一个表没有另一个表的记录的时候 则为nul 反之右表也是一样
select s.* ,g.* from student s full join grade g on s.id=g.sid
select s.* ,g.* from student s full outer join grade g on s.id=g.sid
交叉连接查询 :先返回 左表所有行,左表行在与右表行一一组合,等于两个表相乘
select s.*,g.* from student s cross join grade g
分享到:
相关推荐
本文实例讲述了thinkPHP5框架实现多数据库连接,跨数据连接查询操作。分享给大家供大家参考,具体如下: 1. 多数据库连接 方法1:在需要连接其他数据库的地方,使用Db::connect()方法动态连接数据库,方法参数为...
主要介绍了Java使用Jdbc连接Oracle执行简单查询操作,结合实例形式详细分析了java基于jdbc实现Oracle数据库的连接与查询相关操作技巧,需要的朋友可以参考下
socket异步连接——示例代码 socket异步连接——示例代码 socket异步连接——示例代码
示例代码中,我们使用了Python的mysql.connector库来连接MySQL数据库并执行SQL语句。 在实际使用时,你需要将your_username和your_password替换为你的MySQL数据库的用户名和密码,将mydatabase替换为你的数据库名称...
1_连接查询与子查询示例.sql
winform 和wpf连接PLC设备使用ModbusTCP的示例。
flash 连接 数据库 示例 flash连接数据库示例
本文实例讲述了MySQL 多表关联一对多查询实现取最新一条数据的方法。分享给大家供大家参考,具体如下: MySQL 多表关联一对多查询取最新的一条数据 遇到的问题 多表关联一对多查询取最新的一条数据,数据出现重复 ...
java连接mysql示例,非常简单的示例,不过需要大家自己在本地建立自己的mysql数据库。
C#连接数据库示例
JSP连接SQL示例
ADO.NET链接对象(SqlConnection或者OracleConnection)默认情况都开启连接池(平时编程时...示例中会看到如何控制连接池个数,链接对象关闭连接放回链接池中,有其他连接对象打开连接时重连接池中取得空闲的对应连接。
包含了DB2通过JDBC连接数据库进行数据查询和SQL Server通过JDBC进行数据查询的示例以及相应的jar包文件。
Winform中连接Mysql8并查询表中数据进行显示示例代码 Winform中连接Mysql8并查询表中数据进行显示示例代码 Winform中连接Mysql8并查询表中数据进行显示示例代码 Winform中连接Mysql8并查询表中数据进行显示示例代码
VS2008和Access的数据库连接及操作完整示例.zipVS2008和Access的数据库连接及操作完整示例.zipVS2008和Access的数据库连接及操作完整示例.zipVS2008和Access的数据库连接及操作完整示例.zipVS2008和Access的数据库...
C#连接数据库示例源码
jsp连接数据库连接池代码示例,有连接池类
用java编写的数据库连接池源码及调用示例源码,jdbcPool是连接池源码,jdbcPoolTest是调用示例源码。
vs调用postgre示例,使用的是vs2010,一个简单的控制台程序demo,本地运行通过
一个简易的vba连接数据库并根据sql语句进行查询的excel报表,对刚入门的新手是入门教程