准备我们需要的表结构和数据 两张表 studnet(学生)表和score(成绩)表, 创建表的SQL语句如下 CREATE TABLE `student` ( `id` int(11) NOT NULL, `no` varchar(20) DEFAULT NULL, `name` varchar(20) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; CREATE TABLE `score` (…
首先,新建数据表aaa.bbb以及他们相关联的数据表avb:字段名如下图 填充点数据,如下: 上面设计表的时候,故意在两个表中有相同字段con,如果不做处理的话,在php程序中,看看什么情况?得到的结果集中的con是aaa表的,还是avb表的? $sql = "SELECT * FROM aaa LEFT JOIN avb ON aaa.a_id = avb.a_id"; $db->query($sql); $result_list = $db->get_all(); ec…
准备我们需要的表结构和数据 两张表 studnet(学生)表和score(成绩)表, 创建表的SQL语句如下 CREATE TABLE `student` ( `id` int(11) NOT NULL, `no` varchar(20) DEFAULT NULL, `name` varchar(20) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; CREATE TABLE `score` (…
mysql连接查询: Mysql连接查询支持多表连接 对同一张表可以重复连接多次(别名在多次连接同一张表时很重要) 例题1: 下面有2张表 teams表 比赛结果表:result 问题: 得出一张表: 主队,客队,比赛成绩,比赛时间 方法一:(子查询和连接查询混合) step1: select result.id, t_name as h_name,match_time,result from teams join result on teams.t_id=result.h_id step2:…
本文用到的表 CREATE TABLE `cls` ( `cls_id` ) NOT NULL AUTO_INCREMENT, `name` ) NOT NULL, PRIMARY KEY (`cls_id`) ) cls表--班级表 CREATE TABLE `stu` ( `stu_id` ) NOT NULL AUTO_INCREMENT, `name` ) NOT NULL, `age` ) DEFAULT NULL, `cls_id` ) DEFAULT NULL, `score` )…
参考地址:http://blog.csdn.net/u011277123/article/details/54863371 1.MySQL连接查询 连接查询:将多张表(>=2)进行记录的连接(按照某个指定的条件进行数据拼接). 连接查询的意义: 在用户查看数据的时候,需要显示的数据来自多张表. 连接查询分类:SQL中将连接查询分成四类: 内连接,外连接,自然连接和交叉连接 1.1.交叉连接: 交叉连接: cross join, 从一张表中循环取出每一条记录, 每条记录都去另外一张表进行匹配: 匹…
转: 细说MySQL连接查询:内连.左连和右连 简介: MySQL 的连接查询,通常都是将来自两个或多个表的行结合起来,基于这些表之间的共同字段,进行数据的拼接.首先,要确定一个主表作为结果集,然后将其他表的行有选择 性的连接到选定的主表结果集上.使用较多的连接查询包括:内连接.左连接和右连接. 准备两张表做演示,这两张表必须要有相同的字段内容可匹配,这两张表是 id 和 bianhao 列 mysql> select * from a_player; +----+----------+----…
一.概述 在实际开发中,大部分情况下都不是在单表中进行数据操作,一般都是多张表进行联合查询.通常一个业务就会对应的有好几张表.MySql中的连接查询分为交叉连接,内连接,外连接三部分.其中交叉连接也叫笛卡尔积,也是内连接的一种. 二.连接查询常用方法 准备数据表:员工信息表(emp) 以及部门信息表(demp)   1.交叉连接: 也叫笛卡尔积.特点:不使用任何选择条件,直接把表1中的每个行与表2中的每个行进行一一匹配.因此该方式会产生很多重复数据,用的比较少.下面我们根据具体例子来进行详细解读…
连接查询 交叉连接语法: select  * | 字段列表 from 表1  cross join 表2 内连接: select *|字段列表 from 左表 inner join 右表 on 左表.字段 = 右表.字段; (inner可以省略) 左外连接(左连接)   select *|字段列表 from 左表 left outer join 右表 on 左表.字段 = 右表.字段; (outer可以省略) 右外连接(右连接) select *|字段列表 from 右表 left outer…
CREATE TABLE `chx` (   `id` VARCHAR(20) NOT NULL,   `name` VARCHAR(50) DEFAULT NULL,   `name2` CHAR(4) DEFAULT NULL,   `name3` VARCHAR(4) DEFAULT NULL,   `score` INT(11) DEFAULT NULL,   PRIMARY KEY (`id`) ) ENGINE=INNODB DEFAULT CHARSET=utf8 CREATE T…