Mysql查询——深入学习
1、开篇
之前上一篇的随笔基本上是单表的查询,也是mysql查询的一个基本。接下来我们要看看两个表以上的查询如何得到我们想要的结果。
在学习的过程中我们一起进步,成长。有什么写的不对的还望可以指出。
2、查询
(1)多表之间的查询(笛卡尔积) 100* 100 = 10000 查询的数据量可能非常大
SELECT pj_appoint_order.user_name,pj_user_account.account_name FROM pj_appoint_order,pj_user_account;
给表名取别名
SELECT pa.user_name,pu.account_name FROM pj_appoint_order pa,pj_user_account pu;
(2)关联查询
隐示内连接查询。
(Sql92)
SELECT pa.user_name,pu.account_name FROM pj_appoint_order pa,pj_user_account pu WHERE pa.id = pu.pid;
内连接查询。
(Sql99)
SELECT pa.user_name,pu.account_name FROM pj_appoint_order pa INNER JOIN pj_user_account pu ON pa.id = pu.pid;
left join on
如果我写 left join on 就以左表为主
right join on
如果我写 right join on 就以右表为主
例如:SELECT
t1.id id,
t1.order_id AS designOrderId,
t1.manager_id,
t1.project_name projectName,
t1.user_name userName,
t1.user_phone userPhone,
t1.work_price workPrice,
t1.type_id typeId,
t1.create_time createTime,
t1.update_time updateTime,
t1.project_start_time startTime,
t1.project_end_time endTime,
t1.status status,
t3.meet_time meetTime,
t3.meet_type meetType,
t3.meet_content meetContent,
t5.total totalMain,
t6.total totalSub
FROM pj_project_order t1 LEFT JOIN pj_design_order t2 ON t1.order_id = t2.id
LEFT JOIN pj_order_comm_record t3 ON t2.id = t3.order_id
LEFT JOIN pj_order_design_task t4 ON t2.id = t4.order_id
LEFT JOIN pj_order_design_main_material t5 ON t4 .id = t5.task_id
LEFT JOIN pj_order_design_sub_material t6 ON t4.id = t6.task_id
WHERE 1=1
<if test="manager_id != null">
AND t1.manager_id = #{manager_id}
</if>
AND
t1.project_start_time IS NOT NULL
AND
t1.project_end_time IS NULL
</select>
(3)子查询 -我们以一条查询结果 做为查询条件这叫做子查询 --------------子查询的效率不高
SELECT * FROM person WHERE id = 1
SELECT pid FROM car WHERE carname='hanma'
SELECT * FROM person WHERE id = ( SELECT pid FROM car WHERE carname='hanma' );
(4)UNION 结合两个查询集
SELECT * FROM pj_appoint_order WHERE id = 1093 UNION SELECT * FROM pj_appoint_order WHERE id = 1094
Mysql查询——深入学习的更多相关文章
- [转]向facebook学习,通过协程实现mysql查询的异步化
FROM : 通过协程实现mysql查询的异步化 前言 最近学习了赵海平的演讲,了解到facebook的mysql查询可以进行异步化,从而提高性能.由于facebook实现的比较早,他们不得不对php ...
- 从项目上一个子查询扩展学习开来:mysql的查询、子查询及连接查询
上面这样的数据,想要的结果是:如果matchResult为2的话,代表是黑名单.同一个softId,version,pcInfoId的代表是同一个软件,需要去重:同时,如果相同软件里面只要有一个mat ...
- Mysql 查询练习
Mysql 查询练习 ---创建班级表 create table class( cid int auto_increment primary key, caption ) )engine=innodb ...
- MySQL查询重复出现次数最多的记录
MySQL查询的方法很多,下面为您介绍的MySQL查询语句用于实现查询重复出现次数最多的记录,对于学习MySQL查询有很好的帮助作用. 在有些应用里面,我们需要查询重复次数最多的一些记录,虽然这是一个 ...
- MYSQL视图的学习笔记
MYSQL视图的学习笔记,学至Tarena金牌讲师,金色晨曦科技公司技术总监沙利穆 课程笔记的综合. 视图及图形化工具 1. 视图的定义 视图就是从一个或多个表中,导出来的表,是一个虚 ...
- mySQl数据库的学习笔记
mySQl数据库的学习笔记... ------------------ Dos命令--先在记事本中写.然后再粘贴到Dos中去 -------------------------------- mySQ ...
- Mysql数据库基础学习笔记
Mysql数据库基础学习笔记 1.mysql查看当前登录的账户名以及数据库 一.单表查询 1.创建数据库yuzly,创建表fruits 创建表 ) ) ,) NOT NULL,PRIMARY KEY( ...
- 13本热门书籍免费送!(Python、SpingBoot、Entity Framework、Ionic、MySQL、深度学习、小程序开发等)
七月第一周,网易云社区联合清华大学出版社为大家送出13本数据分析以及移动开发的书籍(Python.SpingBoot.Entity Framework.Ionic.MySQL.深度学习.小程序开发等) ...
- 【笔记】MySQL的基础学习(二)
[笔记]MySQL的基础学习(二) MySQL 老男孩 一 视图 视图其实就是给表起个别名 1.创建视图 格式:CREATE VIEW 视图名称 AS SQL语句 CREATE VIEW v1 AS ...
随机推荐
- iFrame 功能详解
目录索引: 一. 简介二. 属性三. 功能四. 应用 一.简介 网页“帧”的概念最早是由Netscape所提出,当时全部由“帧”构成的页面,也被称之为 “框架集”页面,在一个“框架集”页面中,“帧” ...
- Boost条件变量condition_variable_any
Boost条件变量可以用来实现线程同步,它必须与互斥量配合使用.使用条件变量实现生产者消费者的简单例子如下,需要注意的是cond_put.wait(lock)是在等待条件满足.如果条件不满足,则释放锁 ...
- PHP 观察者模式
观察者模式:定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新. [观察者模式中主要角色] 1.抽象主题(Subject)角色: 抽象主题提供了增加 ...
- Nginx配置文件nginx.conf中文详解(转)
######Nginx配置文件nginx.conf中文详解##### #定义Nginx运行的用户和用户组 user www www; #nginx进程数,建议设置为等于CPU总核心数. worker_ ...
- shiro在springmvc里面的集成使用【转】
<dependency> <groupId>commons-collections</groupId> <artifactId>commons-coll ...
- jQuery技巧大放送
1.关于页面元素的引用 通过jquery的$()引用元素包括通过id.class.元素名以及元素的层级关系及dom或者xpath条件等方法,且返回的对象为jquery对象(集合对象),不能直接调用do ...
- dagger2记录篇
作为一个码农,什么都不用多讲,贴代码 build project build module Application public class App extends Application { pri ...
- android 自定义控件——(五)按钮点击变色
----------------------------------按钮点击变色(源代码下有属性解释)------------------------------------------------- ...
- 将Oracle数据库中的数据写入Excel
将Oracle数据库中的数据写入Excel 1.准备工作 Oracle数据库"TBYZB_FIELD_PRESSURE"表中数据如图: Excel模板(201512.xls): 2 ...
- JavaScript 函数
JavaScript 函数 介绍:函数是由事件驱动的或者当它被调用时执行的可重复使用的代码块.嗯,就像Java中封装的方法一样. 将脚本编写为函数,就可以避免页面载入时执行该脚本. 函数包含着一些代码 ...