java第二十六课

数据库多表
多表做到每个表的字段名称不一样
Mysql 关系数据库
结合到商城:
用户表 订单表 商品表 商品详情表
用户表:
字段:
用户 id:唯一标志用户
用户名称:name
用户性别:sex
用户年龄:age
用户地址:position
用户密码:password

删除标志位: is_delete
版本号:version
审核标志位:addcheck

注意:事务有 4 种隔离机制,读未提交,读已提交,可重复读,串行

默认:可重复读
商品表:(商品定位)酒
商品编号:唯一化,主键 字母+数字 varchar
商品名称 name
保质期: quality
厂址:area
食品添加剂:additives
生产许可证编号: permit
配料表: ingredients
品牌: brand
度数:alcohol
售价:(总价)total
秒杀价:(有秒杀活动时) seckill
打折价:(店庆,打折)Discount

是否删除:is_delete
版本:version
检查:addcheck

建立的关系表,商品表和用户表,在商品表不需要有用户,用户表不需要商品表
订单表(重点字段)
订单编号: 主键 id varcha
订单合价:total double
用户编号: user_id int(与用户表一致)
订单状态: order_status int(0,1,2,3) 数组(买家已付款,
卖家已发货,买家已收货,评价)
订单详情表(必须通过订单找到商品)
订单详情编号: 主键
订单编号: 关系主键(通过订单编号找订单)
商品编号: 关系主键(通过商品编号找商品)

小计: 只算每个详情中内容
如果甲表和乙表之间是一对一,乙表和甲表是一对多,两表的关系是一对多,一对多的关系把外键(关系主键)定在一的数据中,放在订单详情中.
用户表和订单表两表之间互相关系是一对一,一对多.把外键(主键关系)放在一的数据中,一个订单对应一个用户,订单表里有用户的外键.
表设计(元素):唯一性(记录唯一),原子性( 重复数据达到最小)
不建外键,数据表中存在冗余数据,造成数据乱了.

建立外键,使用 foreign key(本表中的需要外键指示的字段)
references 外面表的名称(外面表的外键字段)
create table 中做,不然就得修改.
删除表:
Drop table 表名
建立外键,订单的本表中的 user_id 指向外表 user 表中的 id
create table myorder(id varchar(20) primary key,total double(6,2),user_id int,order_status int, foreign key(user_id)
references user(id));
建表时带关系主键不能进行删除,把用户删除操作变成表中
的关联操作 ,有一个删除级联操作 on delete cascade
create table myorder(id varchar(20) primary key,total
double(6,2),user_id int,order_status int, foreign key(user_id)
references user(id) on delete cascade);
还有一个问题,如果更新是 id,建的表进行更新时也会报
错.
create table myorder(id varchar(20) primary key,total
double(6,2),user_id int,order_status int, foreign key(user_id)
references user(id) on delete cascade on update cascade);

建立外键完整语句,就是建立删除级联,更新级联,外键关
联全部包含在内.在开发,增删改就是单表.
create table myorder(id varchar(20) primary key,total

double(6,2),user_id int,order_status int, version int, is_delete
tinyint,foreign key(user_id) references user(id) on delete

cascade on update cascade);


多表联查
查询用户赵六购买的所有商品和订单.
分析:
(1) 查询涉及到几个表
用户―>订单 ——>订单详情―>商品
找到表后,先完成四个表的连接,
关联: 用户 订单,订单表中 user_id 指向 user id订单 订单详情 myorder id 指向 myorder_detail
order_id
订单详情 订单详情 myorder_detail goods_id 指向goods 中的 id
用 where 的条件把四个表连接在一起,from 后面是四个表
Select * from user a,myorder b,myorder_detail c,goods d
where
a. id=b.user_id and b.id=c.order_id and c.goods_id =d.id
(2)输出内容(找到表,找到字段)
要求输出商品和订单,还要注意条件中的用户名, 商品所有内容输出 d.* 订单表的所有内容 b.*
Select a.username,d.*,b.* from user a,myorder

b,myorder_detail c,goods d where
b. id=b.user_id and b.id=c.order_id and c.goods_id =d.id
(3)给定其他条件(有没有排序,order by,有没有分组 group by),这里用户等于赵六
Select a.username,d.*,b.* from user a,myorder
b,myorder_detail c,goods d where
c. id=b.user_id and b.id=c.order_id and c.goods_id =d.id and
a.username=”赵六”
当前测试环境初始化的数据,语句保留,使用 navigate 导出表格创建和初始化语句.现在需要把环境从测试环境到生产环境.
一个命令一粘贴,所有数据全部初始化结束.
Mysql –uroot –padmin <beifen.sql

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

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

相关文章

wyler水平仪维修WYLER倾角仪维修CH-8405

瑞士WYLER电子水平仪维修&#xff1b;BIueCLINO倾斜度测量仪维修&#xff1b;wyler电子倾角仪维修。 水平仪常见故障及处理方法 1、 仪表通电不工作。 A、检查仪表220V电源端子接线是否正确 B、检查仪表电容是否熔断&#xff1b; C、拧下仪表后的固定螺钉&#xff0c;将表…

五、Linux基础软件安装

目录 1、安装JDK 2、安装Mysql 接下来&#xff0c;我们来学习如何在linux上安装JDK和Mysql&#xff0c;安装之前需要在Linux上提前创建三个目录: mkdir -p /export/software #软件包存放目录 mkdir -p /export/server #安装目录 mkdir -p /export/data #数据存放目录…

机器人AGV小车避障传感器测距

一、A22超声波传感器 该模块是基于机器人自动控制应用而设计的超声波避障传感器&#xff0c;针对目前市场上对于超声波传感器模组盲区大、测量角度大、响应时间长、安装适配性差等问题而着重设计。 具备了盲区小、测量角度小、响应时间短、过滤同频干扰、体积小、安装适配性高…

10-微信小程序 图片 相机 二维码 动画相关API(实现选择相册、拍照、录像、动画)

10-微信小程序 图片 相机 二维码 动画相关API(实现选择相册、拍照、录像、动画) 文章目录 10.1选择图片wx.chooseImage(Object object)object.success 回调函数代码效果 10.2 预览图片wx.previewImage(Object object)代码效果 10.3 相机APICameraContext wx.createCameraContex…

网站提示不安全?

随着互联网的普及和发展&#xff0c;网络安全问题日益严重。黑客攻击、数据泄露、恶意软件等问题层出不穷&#xff0c;给企业和个人带来了巨大的损失。在这个背景下&#xff0c;确保网站安全显得尤为重要&#xff0c;而使用SSL证书是解决这些问题的有效措施。 什么是SSL证书&am…

mockito加junit gd 单元测试 笔记

目录 一、简介1.1 单元测试的特点1.2 mock类框架使用场景1.3 常用mock类框架1.3.1 mockito1.3.2 easymock1.3.3 powermock1.3.4 JMockit 二、mockito的单独使用2.1 mock对象与spy对象2.2 初始化mock/spy对象的方式2.3 参数匹配2.4 方法插桩2.5 InjectMocks注解的使用断言工具 三…

SSM校园学习助手系统开发mysql数据库web结构java编程计算机网页源码eclipse项目

一、源码特点 SSM 校园学习助手系统是一套完善的信息系统&#xff0c;结合springMVC框架完成本系统&#xff0c;对理解JSP java编程开发语言有帮助系统采用SSM框架&#xff08;MVC模式开发&#xff09;&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模…

三、shell - 变量

目录 1、简介 1.1 变量的定义语法: 1.2 变量的定义需遵循的规则 1.3 变量的作用域 2、用户变量 2.1 定义变量 2.2 访问变量 2.3 变量的其他赋值方式 2.4 只读变量 2.5 删除变量 ​​​​​​​3、环境变量 ​​​​​​​3.1 常见的环境变量 ​​​​​​​3.2 自…

Logstash使用指南

介绍 Logstash是一个开源数据收集引擎&#xff0c;具有实时管道功能。它可以动态地将来自不同数据源的数据统一起来&#xff0c;并将数据标准化到你所选择的目的地。尽管Logstash的早期目标是搜集日志&#xff0c;现在它的功能已完全不只于此。任何事件类型都可以加入分析&…

【机器视觉技术栈】- 机器视觉基础

1.1 为什么采用机器视觉 人眼与机器视觉对比 人眼机器视觉精确性差&#xff0c;64灰度级&#xff0c;不能分辨小于100微米的目标强&#xff0c;256灰度级&#xff0c;可检测微米级目标速度慢&#xff0c;无法看清间隔小于40毫秒的运动目标快&#xff0c;快门时间可达10微秒适…

7.23 SpringBoot项目实战【评论】

文章目录 前言一、编写控制器二、编写服务层三、Postman测试前言 我们在 7.4 和 7.20 都曾实现过 评论列表,本文我们继续SpringBoot项目实战 评论 功能。逻辑实际相当Easy:一个学生 对 任意书 都可以 多次评论,但需要经过审核! 回顾一下 4.2 的数据库设计,学生图书评论表…

每日一练2023.11.30——验证身份【PTA】

题目链接 &#xff1a;验证身份 题目要求&#xff1a; 一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下&#xff1a; 首先对前17位数字加权求和&#xff0c;权重分配为&#xff1a;{7&#xff0c;9&#xff0c;10&#xff0c;5&a…