一使用SELECT子句进行多表查询

SELECT字段名FROM表1,表2…WHERE表1.字段=表2.字段AND其它查询条件

SELECT a.id,a.name,a.address,a.date,b.math,b.english,b.chinese FROM tb_demo065_tel AS b,tb_demo065 AS a WHERE a.id=b.id

二使用表的别名进行多表查询

如:

SELECT a.id,a.name,a.address,b.math,b.english,b.chinese FROM tb_demo065 a,tb_demo065_tel b WHERE a.id=b.id AND b.id='$_POST[textid]'
SELECT a.id,a.name,a.address,b.math,b.english,b.chinese FROM tb_demo065 AS a,tb_demo065_tel AS b WHERE a.id=b.id
SELECT a.id,a.name,a.address,b.math,b.english,b.chinese FROM tb_demo065 a,tb_demo065_tel b WHERE a.id=b.id 
  • 别名通常是一个缩短了的表名,用于在连接中引用表中的特定列,如果连接中的多个表中有相同的名称列存在,必须用表名或表的别名限定列名
  • 如果定义了表的别名就不能再使用表名

三合并多个结果集

SQL语言中,可以通过UNION或ALL将多个SELECT语句的查询结果合并输出,这两个关键字的使用说明如下:

UNION:利用该关键字可以将多个SELECT语句的查询结果合并输出,并删除重复行

ALL:利用该关键字可以将多个SELECT语句的查询结果合并输出,但不会删除重复行

在使用UNION或ALL关键字将多个表合并输出时,查询结果必须具有相同的结构并且数据类型必须兼容,另外使用UNION时两张表的字段数量也必须相同,否则会提示SQL语句有错误。

e.x:SELECT id,name,pwd FROM tb_demo067 UNION SELECT uid,price,date FROM tb_demo067_tel
SELECT id,name,sex,date FROM tb_demo068 WHERE id in(SELECT id FROM tb_demo068 WHERE id='$_POST[test]')

五复杂的嵌套查询

多表之间的嵌套查询可以通过谓词IN实现,语法格式如下:

test_expression[NOT] IN{ subquery}

六嵌套查询在查询统计中的应用

实现多表查询时,可以同时使用谓词ANY、SOME、ALL,这些谓词被称为定量比较谓词,可以和比较运算符联合使用,判断是否全部返回值都满足搜索条件.SOME和ANY谓词是存在量的,只注重是否有返回值满足搜索条件,这两个谓词的含义相同,可以替换使用;ALL谓词称为通用谓词,它只关心是否有谓词满足搜索要求.

SELECT * FROM tb_demo069_people WHERE uid IN(SELECT deptID FROM tb_demo069_dept WHERE deptName='$_POST[select]')SELECT a.id,a.name FROM tb_demo067 AS a WHERE id<3)
SELECT people.name,people.chinese,people.math,people.english FROM (SELECT name,chinese,math,english FROM tb_demo071) AS people

(1)由比较运算符引入的内层子查询只包含一个表达式或列名,在外层语句中的WHERE子句内命名的列必须与内层子查询命名的列兼容
(2)由不可更改的比较运算符引入的子查询(比较运算符后面不跟关键字ANY或ALL)不包括GROUPBY或HAVING子句,除非预先确定了成组或单个的值
(3)用EXISTS引入的SELECT列表一般都由*组成,不必指定列名
(4)子查询不能在内部处理其结果

八使用子查询作表达式

SELECT(SELECTAVG(chinese)FROMtb_demo071),(SELECTAVG(english)FROMtb_demo071),(SELECTAVG(math)FROMtb_demo071)FROMtb_demo071
SELECT (SELECT AVG(chinese) FROM tb_demo071) AS yuwen ,(SELECT AVG(english) FROM tb_demo071) AS yingyu,(SELECT AVG(math) FROM tb_demo071) AS shuxue FROM tb_demo071
e.x:SELECT * FROM tb_demo074_student UNION SELECT * FROM tb_demo074_fasten

十一对联合后的结果进行排序

为了UNION的运算兼容,要求所有SELECT语句都不能有ORDERBY语句,但有一种情况例外,那就是在最后一个SELECT语句中放置ORDERBY子句实现结果的最终排序输出。

e.x:SELECT * FROM tb_demo074_student UNION SELECT * FROM tb_demo074_fasten ORDER BY id

十二条件联合语句

SELECT * FROM tb_demo076_BEIJING GROUP BY name HAVING name='人民邮电出版社' OR name='机械工业出版社' UNION SELECT * FROM tb_demo076_BEIJING GROUP BY name HAVING name <>'人民邮电出版社' AND name <>'机械工业再版社' ORDER BY id

十三简单内连接查询

SELECT filedlist FROM table1 [INNER] JOIN table2 ON table1.column1 = table2.column1
SELECT a.name,a.address,a.date,b.chinese,b.math,b.english FROM tb_demo065 AS a INNER JOIN tb_demo065_tel AS b on a.id=b.id
SELECT a.name,a.address,a.date,b.chinese,b.math,b.english FROM tb_demo065 AS a INNER JOIN tb_demo065_tel AS b on a.id=b.id WHERE b.id=(SELECT id FROM tb_demo065 WHERE tb_demo065.name='$_POST[text]')

十五使用外连接实现多表联合查询

(1)LEFTOUTERJOIN表示表之间通过左连接方式相互连接,也可简写成LEFTJOIN,它是以左侧的表为基准故称左连接,左侧表中所有信息将被全部输出,而右侧表信息则只会输出符合条件的信息,对不符合条件的信息则返回NULL
e.x:SELECTa.name,a.address,b.math,b.englishFROMtb_demo065ASALEFTOUTERJOINtb_demo065_telASbONa.id=b.id

(2)RIGHTOUTERJOIN表示表之间通过右连接方式相互连接,也可简写成RIGHTJOIN,它是以右侧的表为基准故称右连接,右侧表中所有信息将被全部输出,而左侧表信息则只会输出符合条件的信息,对不符合条件的信息则返回NULL
E.X:SELECTa.name,a.address,b.math,b.englishFROMtb_demo065ASARIGHTOUTERJOINtb_demo065_telASbONa.id=b.id

十六利用IN或NOTIN关键字限定范围

e.x:SELECT * FROM tb_demo083 WHERE code IN(SELECT code FROM tb_demo083 WHERE code BETWEEN '$_POST[text1]' AND '$_POST[text2]')

十七由IN引入的关联子查询

e.x:SELECT * FROM tb_demo083 WHERE code IN(SELECT code FROM tb_demo083 WHERE code = '$_POST[text]')
e.x:SELECT name,math FROM tb_demo083 GROUP BY id HAVING math > '95'

更多相关文章

  1. 《Android和PHP最佳实践》官方站
  2. Python list sort方法的具体使用
  3. android用户界面之按钮(Button)教程实例汇
  4. TabHost与RadioGroup结合完成的菜单【带效果图】5个Activity
  5. Android(安卓)UI开发第十七篇——Android(安卓)Fragment实例(Lis
  6. Android——Activity四种启动模式
  7. Android布局(序章)
  8. Android发送短信方法实例详解
  9. Android(安卓)读取资源文件实例详解

随机推荐

  1. 【Android】Android的快速开发框架Afinal
  2. Android导航栏资源总结,单纯防丢!
  3. 学习Android 必备 实例大集合
  4. 【Android游戏开发二十一】Android os设
  5. android 网络 post get
  6. Android消息处理系统
  7. android 界面应用锦集
  8. Android(安卓)学习笔记 Contacts Content
  9. Android中解决手机屏幕横竖屏切换问题
  10. android SDK与ADT版本更新问题