mysql多表内连接查询

在这里插入图片描述

-- 查询用户信息和对应的订单信息
SELECT * FROM USER INNER JOIN orderlist ON `orderlist`.`uid`=user.`id`;`user`-- 查询用户信息和对应的订单信息 起别名
SELECT * FROM `user` u INNER JOIN `orderlist` o ON o.uid=u.id;-- 查询用户 姓名 年龄, 订单编号SELECT u.`NAME`,  -- 用户姓名u.`age`,   -- 用户年龄o.`number` -- 订单编号
FROM USER u      -- 用户表
INNER JOIN `orderlist` o  -- 订单表 
ONo.`uid`=u.`id`;
-- 隐式内连接
SELECTu.`NAME`,  -- 用户姓名u.`age`,   -- 用户年龄o.`number` -- 订单编号
FROMUSER u,`orderlist` o
WHERE o.uid=u.`id`;

数据准备

-- 创建db6数据库
CREATE DATABASE db6;
-- 使用db6数据库
USE db6;-- 创建user表
CREATE TABLE USER(id INT PRIMARY KEY AUTO_INCREMENT,	-- 用户idNAME VARCHAR(20),			-- 用户姓名age INT                                 -- 用户年龄
);
-- 添加数据
INSERT INTO USER VALUES (1,'张三',23);
INSERT INTO USER VALUES (2,'李四',24);
INSERT INTO USER VALUES (3,'王五',25);
INSERT INTO USER VALUES (4,'赵六',26);-- 订单表
CREATE TABLE orderlist(id INT PRIMARY KEY AUTO_INCREMENT,	-- 订单idnumber VARCHAR(30),			-- 订单编号uid INT,    -- 外键字段CONSTRAINT ou_fk1 FOREIGN KEY (uid) REFERENCES USER(id)
);
-- 添加数据
INSERT INTO orderlist VALUES (1,'hm001',1);
INSERT INTO orderlist VALUES (2,'hm002',1);
INSERT INTO orderlist VALUES (3,'hm003',2);
INSERT INTO orderlist VALUES (4,'hm004',2);
INSERT INTO orderlist VALUES (5,'hm005',3);
INSERT INTO orderlist VALUES (6,'hm006',3);
INSERT INTO orderlist VALUES (7,'hm007',NULL);-- 商品分类表
CREATE TABLE category(id INT PRIMARY KEY AUTO_INCREMENT,  -- 商品分类idNAME VARCHAR(10)                    -- 商品分类名称
);
-- 添加数据
INSERT INTO category VALUES (1,'手机数码');
INSERT INTO category VALUES (2,'电脑办公');
INSERT INTO category VALUES (3,'烟酒茶糖');
INSERT INTO category VALUES (4,'鞋靴箱包');-- 商品表
CREATE TABLE product(id INT PRIMARY KEY AUTO_INCREMENT,   -- 商品idNAME VARCHAR(30),                    -- 商品名称cid INT, -- 外键字段CONSTRAINT cp_fk1 FOREIGN KEY (cid) REFERENCES category(id)
);
-- 添加数据
INSERT INTO product VALUES (1,'华为手机',1);
INSERT INTO product VALUES (2,'小米手机',1);
INSERT INTO product VALUES (3,'联想电脑',2);
INSERT INTO product VALUES (4,'苹果电脑',2);
INSERT INTO product VALUES (5,'中华香烟',3);
INSERT INTO product VALUES (6,'玉溪香烟',3);
INSERT INTO product VALUES (7,'计生用品',NULL);-- 中间表
CREATE TABLE us_pro(upid INT PRIMARY KEY AUTO_INCREMENT,  -- 中间表iduid INT, -- 外键字段。需要和用户表的主键产生关联pid INT, -- 外键字段。需要和商品表的主键产生关联CONSTRAINT up_fk1 FOREIGN KEY (uid) REFERENCES USER(id),CONSTRAINT up_fk2 FOREIGN KEY (pid) REFERENCES product(id)
);
-- 添加数据
INSERT INTO us_pro VALUES (NULL,1,1);
INSERT INTO us_pro VALUES (NULL,1,2);
INSERT INTO us_pro VALUES (NULL,1,3);
INSERT INTO us_pro VALUES (NULL,1,4);
INSERT INTO us_pro VALUES (NULL,1,5);
INSERT INTO us_pro VALUES (NULL,1,6);
INSERT INTO us_pro VALUES (NULL,1,7);
INSERT INTO us_pro VALUES (NULL,2,1);
INSERT INTO us_pro VALUES (NULL,2,2);
INSERT INTO us_pro VALUES (NULL,2,3);
INSERT INTO us_pro VALUES (NULL,2,4);
INSERT INTO us_pro VALUES (NULL,2,5);
INSERT INTO us_pro VALUES (NULL,2,6);
INSERT INTO us_pro VALUES (NULL,2,7);
INSERT INTO us_pro VALUES (NULL,3,1);
INSERT INTO us_pro VALUES (NULL,3,2);
INSERT INTO us_pro VALUES (NULL,3,3);
INSERT INTO us_pro VALUES (NULL,3,4);
INSERT INTO us_pro VALUES (NULL,3,5);
INSERT INTO us_pro VALUES (NULL,3,6);
INSERT INTO us_pro VALUES (NULL,3,7);
INSERT INTO us_pro VALUES (NULL,4,1);
INSERT INTO us_pro VALUES (NULL,4,2);
INSERT INTO us_pro VALUES (NULL,4,3);
INSERT INTO us_pro VALUES (NULL,4,4);
INSERT INTO us_pro VALUES (NULL,4,5);
INSERT INTO us_pro VALUES (NULL,4,6);
INSERT INTO us_pro VALUES (NULL,4,7);-- 笛卡尔积查询
SELECT * FROM USER,orderlist;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/442721.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql简单外连接查询

-- 查询所有用户信息 以及用户对应的订单信息 SELECTu.*, //用户所有信息o.number //订单 FROMUSER u LEFT OUTER JOIN orderlist o //订单表 ON o.uidu.id; //用户表-- 查询所有的订单信息 以及订单所属的用户信息 SELECTo.*, //订单表u.NAME FROMUSER u RIGHT OUTER JO…

基于element-ui,vue的html随机点名器

点击开始点名,进入循环,点击停止,会禁用按钮 在500毫秒之后,将点到的人名字放到上面,在下面表体会消失这个人, 点名之后可以刷新。暂时还没有做将点到的人还回来。(1.0) 用到的资料…

elementui vue的html随机点名器软件网页版源码1.1

**在之前基础上新增了点击开始点名之后,判断姓名池的数量的判断,如果数量为零给出提示。 按钮的双击, 如果是在姓名池,在会进入上面的被点名状态, 如果是在上面卡片中的点名状态,则会重新回到姓名池 ** HTM…

elementuiDemo1.1

1.1版本 ,大概完成浏览器的整体适配, tab的增删,选中 处理中心 item,的新增。动态获取名称 src路径。 JS let vue new Vue({el: "#main",data: {/* tab */editableTabsValue: 1,/* 默认选中,如果有新增则会…

html css简单form表单源码

<!DOCTYPE html> <html><head><meta charset"utf-8"><title>用户注册</title></head><style>body {background-color: #F0F9EB;margin: 0;position: absolute;top: 50%;left: 50%;-ms-transform: translate(-50%, -…

好看的a标签按钮样式

<a class"a1" href"#">返回首页</a><a class"a2" href"#">返回首页</a><style>.a1 {color: #000000;padding: 10px;text-decoration: none;font-size: 16px;background-color: #dce1e6;}.a1:active {ba…

java连接mysql数据库C3P0入门

这里使用的是phpstudy软件&#xff0c;会自带mysql&#xff0c;这里启动数据库。 **sqlyong 可视化建立对数据库的连接&#xff0c;地址&#xff0c;我这里是本地所以用的是localhost&#xff0c; 用户名&#xff1a; 密码&#xff1a; 在phpstury 可以建立修改&#xff0c; 然…

java的druid连接

导入jar包 将druid配置文件放到src目录下 import cn.silence2.domain.Student; import com.alibaba.druid.pool.DruidDataSourceFactory;import javax.sql.DataSource; import java.io.InputStream; import java.sql.Connection; import java.sql.Date; import java.sql.Prepar…

java ==号比较String字符串的地址

/*** java 号比较String字符串的地址* <p>* String类代表字符串。 Java程序中的所有字符串文字&#xff08;例如"abc" &#xff09;都被实现为此类的实例。* 字符串不变; 它们的值在创建后不能被更改。 字符串缓冲区支持可变字符串。* 因为String对象是不可变的…

javaweb jsp页面无法解析${message}

我遇到的问题是jsp 页面无法解析/${ } 标签&#xff0c; 后台和页面都没有报错。 原因时web.xml <?xml version"1.0" encoding"UTF-8"?> <web-app xmlns"http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi"http://www.w3.org/2001…

vue element-ui 无法渲染表格数据解决

页面无报错 ajax请求数据。数据正常到达。 但是无法渲染。 换成 axios.get("/user/findAll").then(resp > {this.tableData resp.data;});问题解决。 虽然不知道为啥。但是问题解决了。哈哈&#xff01;

java数组及Arrays创建一个int 类型数组 数组元素由键盘录入,每次打印插入排序的结果(数组扩容,数组排序,键盘录入)

author silence丶你的名字 java数组及Arrays创建一个int 类型数组 数组元素由键盘录入&#xff0c;每次打印插入排序的结果 初始数组元素1 for死循环 获取用户录入的数据&#xff0c;如果为9527 程序结束&#xff0c;否则拷贝一个新数组&#xff0c;进行排序 避免原始数组被排…

三个球A,B,C大小形状相同,且其中有一个球与其他球的重量不同,要求找出这个不一样的球

import java.util.Arrays; import java.util.Scanner;/*** author silence丶黎明* 三个球A,B,C大小形状相同&#xff0c;且其中有一个球与其他球的重量不同&#xff0c;要求找出这个不一样的球* 输入格式&#xff1a;* 输入在一行中给出3个正整数 顺序对应球 A,B,C 的重量* 输出…

编写程序,随机产生20个0到1之间的数,将这20个数写入文本文件中,要求每行5个数

import java.io.File; import java.io.FileOutputStream; import java.io.FileWriter; import java.io.IOException; import java.util.Arrays; import java.util.Random;/*** author silence丶黎明* 编写程序,随机产生20个0到1之间的数,将这20个数写入文本文件中&#xff0c;要…

调用SMS腾讯云短信验证码API的几个坑,及详细使用流程

前言 首先说下&#xff0c;几个坑已解决。准备说一下。使用的一些步骤 因为项目有一个短信验证码登录注册的&#xff0c;首先注册的是阿里的。但是审核没有审核通过&#xff0c;所以有注册了腾讯的 本来向截图一下阿里的&#xff0c;结果登录出错了&#xff0c;这里就不说了。…

腾讯云COS对象存储图片文件API的详细步骤过程

首先创建一个桶。相当于你存储图片的容器。我这里是存储图片。 我选则是共有读&#xff0c;私有写。因为不选择共有读的话&#xff0c;以后别的地方没办法访问 注意&#xff1a; 公有读权限可以通过匿名身份直接读取您存储桶中的数据&#xff0c;存在一定的安全风险&#xff0c…

java PageUtil + stream 手动计算List 分页

交代一下前言&#xff0c;数据是redis中查询 140,193,88,117 格式大概是这样。 需要切割为long类型的list数组。需要手动计算分页&#xff0c;去mongodb中查询数据。这里我用的手动计算分页的是 hutool 工具包 import cn.hutool.core.util.PageUtil; 里面挺多实用的工具 <…

Redis 缓存 Key

/*** controller 缓存key 自定义前缀 url param token* 生成redis key&#xff1a;SERVER_CACHE_DATA rul 参数&#xff08;param&#xff09; token** param request HttpServletRequest* return createRedisKey*/public static String createRedisKey(HttpServletReques…

UserThreadLocal 用户线程Token拦截验证

注册拦截器 package com.tanhua.server.config;import com.tanhua.server.interceptor.RedisCacheInterceptor; import com.tanhua.server.interceptor.UserTokenInterceptor; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.co…

jsonwebtoken jwt token 简单加密

<dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt</artifactId><version>0.9.1</version> </dependency> //生成tokenMap<String, Object> claims new HashMap<String, Object>();claims.put(&q…