java学习笔记之mysql3

mysql学习笔记之多表查询和子查询

 1 #--------------多表的查询-------------------
 2   # 交叉连接查询
 3   # 内连接查询
 4     #显式内连接
 5     #隐式内连接
 6   # 外链接查询
 7     #左外连接
 8     #右外连接
 9
10 #-----------交叉连接(了解)-------------------------
11    # select * from A, B;  ----> A * B --->笛卡尔集合(冗余)
12    # 后边的查询基本上都是在笛卡尔集的基础上进行条件判断
13    #查询每一个分类都有哪些商品:电子 --->商品  服装--->商品
14    SELECT * FROM category,products;
15    FOR(){
16     FOR(){
17         行 * 行
18     }
19    }
20
21
22 #---------内连接(重要)  隐式内连接----------------------------------
23  #内连接求的是两张表的交集 ,如果多张表没有交集,则什么都不显示
24  #隐式内连接在判断条件之前会产生笛卡尔集
25  #显式内连接在判断条件之前不会产生笛卡尔集
26  FOR(){
27     FOR(){
28         IF(cid == category_id){
29          行 * 行
30          }
31     }
32    }
33
34  SELECT * FROM category,products WHERE cid = category_id;
35  SELECT * FROM products,category WHERE cid = category_id;
36
37  #为了避免多个表出现同名的列,则在查询时,一般要用表来访问列
38  SELECT * FROM category,products WHERE category.cid = products.category_id;
39
40  #给表起别名:不能加引号,要字段起别名,加引号
41  SELECT * FROM category c,products p WHERE c.cid = p.category_id;
42
43  SELECT c.cname,p.pname FROM category c,products p WHERE c.cid = p.category_id;
44
45  #查询省表和市表(一对多)
46   SELECT * FROM province p, city c WHERE p.pid = c.province_id;
47  #只显示河南省的市
48   SELECT * FROM province p, city c WHERE p.pid = c.province_id AND p.pname=‘河南省‘;
49   SELECT * FROM province p, city c WHERE p.pid = c.province_id AND p.pname IN(‘河南省‘,‘山东省‘);
50   SELECT * FROM province p, city c WHERE p.pid = c.province_id AND (p.pname =‘河南省‘ OR p.pname=‘山东省‘);
51
52  #查询用户表和角色表(多对多)
53  SELECT  * FROM USER u, user_role ur , role r WHERE u.uid = ur.uid AND ur.rid = r.rid;
54  SELECT  * FROM USER u, user_role ur , role r,role_privilege rp, privilege p WHERE
55  u.uid = ur.uid AND ur.rid = r.rid AND r.rid = rp.rid AND rp.pid = p.pid;
56
57  #---------内连接(重要)  显式内连接----------------------------------
58   SELECT * FROM category c INNER JOIN products p ON c.cid = p.category_id WHERE c.cname=‘家电‘;
59
60
61  #--------外连接(左外连接)------
62  #左外连接以左表为主,将左表的数据全部显式,如果右表没有对应的数据,则默认为NULL
63  SELECT * FROM category c INNER JOIN products p ON c.cid = p.category_id
64  SELECT * FROM category c LEFT OUTER JOIN products p ON c.cid = p.category_id
65  #--------外连接(右外连接)------
66  #右外连接以右表为主,右表的数据全部显式,左表没有的数据默认为NULL
67  SELECT * FROM category c RIGHT OUTER JOIN products p ON c.cid = p.category_id
68
69  #---------------子查询(重要)-----------
70   #子查询就是select的嵌套
71   #在市表中查询哪些市属于河南省
72     #1 先在省表中查询河南省的pid
73     SELECT pid FROM province WHERE pname = ‘河南省‘;
74     #2 在市表中查询:province_id = pid
75     SELECT * FROM city WHERE province_id = (SELECT pid FROM province WHERE pname = ‘河南省‘);
76
77     #查询河南省和山东省的市
78      SELECT * FROM city WHERE province_id IN (SELECT pid FROM province WHERE pname = ‘河南省‘ OR pname=‘山东省‘);
79    SELECT * FROM city WHERE (province_id =
80    (SELECT pid FROM province WHERE pname = ‘河南省‘)) OR (province_id =  (SELECT pid FROM province WHERE pname = ‘山东省‘));
81
82    #将select的查询结果当成一个张表
83    #select查询的结果是一张临时表,存在内存中
84    SELECT * FROM city c , (SELECT * FROM province  WHERE pname = ‘河南省‘) t WHERE c.province_id = t.pid;
85
86
87  

原文地址:https://www.cnblogs.com/xuzhaocai/p/8158516.html

时间: 2024-10-17 15:33:41

java学习笔记之mysql3的相关文章

Java学习笔记3-操作符

Java基本操作符:+.-.*./.%.=.==.!=.+=.-=. 优先级:先乘除后加减,如果是连接符+号会优先往前匹配,比如 a+++++b,会被解释称 a++ ++ +b,所以会报错,需要自行使用括号隔离为 (a++) + (++b). 对象的引用如果赋值给了对象的引用后,2 个对象将指向同一个引用,有一个对象的引用重新赋值后将同时影响到另一个对象,比如 ClassName classA = new ClassName(); ClassName classB = new ClassName

java学习笔记10--泛型总结

java学习笔记系列: java学习笔记9--内部类总结 java学习笔记8--接口总结 java学习笔记7--抽象类与抽象方法 java学习笔记6--类的继承.Object类 java学习笔记5--类的方法 java学习笔记4--对象的初始化与回收 java学习笔记3--类与对象的基础 java学习笔记2--数据类型.数组 java学习笔记1--开发环境平台总结 本文地址:http://www.cnblogs.com/archimedes/p/java-study-note10.html,转载

Java学习笔记_25_Collections类

25.Collections类: Collections类是一个工具类,用来对集合进行操作,它主要是提供一些排序算法,包括随机排序.反相排序等. Collections类提供了一些静态方法,实现了基于List容器的一些常用算法. Collections的一些方法列表: · void sort(List): 对List内的元素进行排序. · void shuffle(List): 对List内的元素随机排序. · void reverse(List): 对List内的元素进行逆序排列. · voi

Java学习笔记心得——初识Java

初识Java 拿到这本厚厚的<Java学习笔记>,翻开目录:Java平台概论.从JDK到TDE.认识对象.封装.继承与多态...看着这些似懂非懂的术语名词,心里怀着些好奇与担忧,就这样我开始走进Java的世界.  Java产生的历史 Java来自于Sun公司的一个叫Green Project中撰写的程序语言,全球信息网(World Wide Web)兴起,Java Applet成为网页互动技术的代表,特别适合于Internet应用程序开发. Java语言的特点 1.面向对象 这是Java最重要

java学习笔记8--接口总结

接着前面的学习: java学习笔记7--抽象类与抽象方法 java学习笔记6--类的继承.Object类 java学习笔记5--类的方法 java学习笔记4--对象的初始化与回收 java学习笔记3--类与对象的基础 java学习笔记2--数据类型.数组 java学习笔记1--开发环境平台总结 本文地址:http://www.cnblogs.com/archimedes/p/java-study-note8.html,转载请注明源地址. 生活中的接口: 什么是接口? 一个Java接口是一些方法特

java学习笔记3——java关键字

java学习笔记3——java关键字 虽然老师说不用刻意的去记忆,但是我还是在网上找到了非常详细的注解,再次收藏 关键字的类型表: 各个关键字的详细注解和实例,按首字母排序: 1.abstract abstract 关键字可以修改类或方法. abstract 类可以扩展(增加子类),但不能直接实例化. abstract 方法不在声明它的类中实现,但必须在某个子类中重写. -示例- public abstract class MyClass{ } public abstract String my

java学习笔记一

只记录一些我认为比较必要,容易出错的地方.(不断更新中) 内存:分为四段,代码段code segment,数据段data segment,栈stack, 堆heap.记住如下图 数据类型: 1.java整形常量默认为int类型,当使用long类型时,因此需要添加“l”或“L”,一般用大写,小写像1.如long i = 888888888888L 2.浮点数时会默认为double类型,因此使用float时需要添加f.如 float i = 0.123f 3.java支持大数运算. 强制转换 flo

java学习笔记(三)java中的修饰符abstract、static与final

一.四种访问级别的访问范围 访问级别 访问修饰符 同类 同包 子类 不同的包 公开 public 受保护 protected 默认 没有访问修饰符 私有的 private 二.使用abstract修饰符需要遵守的语法规则 1.抽象类中可以没有抽象方法,但是包含抽象方法的类必须定义为抽象类,即用abstract修饰: 2.抽象类跟抽象方法不能被final修饰符修饰: 3.抽象类中可以有非抽象方法,因为继承抽象类的子类必须重写父类中所有的抽象方法,因此抽象类中不能有抽象构造方法和抽象静态方法: 4.

Java学习笔记day_01

Java学习笔记(复习整理) 虽然不知道该怎么写,但是不起步就永远不知道该怎么做..刚开始可能会写的很差劲,但会一点一点变好的. 本笔记是以我按照传智播客的视频和Java核心思想来学习,前面的基础部分主要是用于个人的复习使用的. 第一段代码:HelloWorld public class HelloWorld { public static void main(String[] args) { System.out.println("Hello World"); } }