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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C++和Python混合编程在数据采集程序中的应用

目录 一、引言 二、C和Python的特性及其在数据采集程序中的应用 1、C的特性及其在数据采集程序中的应用 2、Python的特性及其在数据采集程序中的应用 三、C和Python混合编程在数据采集程序中的实现方法 四、混合编程的优缺点以及未来发展趋势 五、代码示例 六、结论 一…

CAN网络出现错误帧从哪些方面去分析解决

标题&#xff1a;CAN网络出现错误帧从哪些方面去分析 实例1&#xff1a; 断电重启后&#xff0c;会有错误帧产生。 检查方案&#xff1a; 查看收发模块的初始化、使能是否在发送CAN报文之前完成&#xff1f; 实例2&#xff1a; 周期性报文&#xff0c;有时会冒出一帧错误帧&…

MySQL官网推荐书籍

MySQL官网推荐书籍 图片有防盗链csdn转存失败。有图版传送门MySQL官网推荐书籍 高效的MySQL性能&#xff1a;Daniel Nichter的最佳实践和技术 Daniel Nichter 向您展示了如何应用直接影响 MySQL 性能的最佳实践和技术。您将学习如何通过分析查询执行、为常见 SQL 子句和表联接…

【Linux】yum -- 软件包管理器

目录 一、Linux中是如何安装软件的 1.1 安装的方法 1.2 安装的本质(基本理解) 二、软件包 2.1 软件包的概念 2.2 为什么要有软件包 三、yum--软件包管理器 3.1 yum的概念 3.2 yum的使用 3.2.1 搜索一个软件 3.2.2 安装一个软件 3.2.3 卸载一个软件 3.3 yum源更新 …

2种方法,jmeter用一个正则提取器提取多个值!

jmeter中&#xff0c;用json提取器&#xff0c;一次提取多个值&#xff0c;这个很多人都会。但是&#xff0c;用正则提取器一次提取多个&#xff0c;是否可以呢&#xff1f; 肯定&#xff0c;很多人都自信满满的说&#xff0c;可以&#xff01;形如&#xff1a;token":“…

vuepress-----3、导航栏

3、导航栏 # 页面目录结构约定 . ├── docs │ ├── .vuepress (可选的) │ │ ├── components (可选的) │ │ ├── theme (可选的) │ │ │ └── Layout.vue │ │ ├── public (可选的) │ │ ├── styles (可选的) │ │ │…

python 交互模式和命令行模式的问题

python 模式的冲突 unexpected character after line continuation character 理论上 ide里&#xff0c;输入 python 文件路径\文件.py 就可以执行 但是有时候却报错 unexpected character after line continuation character 出现上述错误的原因是没有退出解释器&#x…

关注这两点 或能避开一些现货黄金交易的陷阱

在现货黄金投资中&#xff0c;交易机会是处处都有&#xff0c;但是亏损的情况也可能出现。投资者要在陷阱处处的市场中获得稳定盈利&#xff0c;就需要懂得如何规避现货黄金投资的陷阱。下面我们就来介绍两个很常用的避开陷阱的方法。 看交易的活跃度。交易越活跃&#xff0c;市…

人体是否有清除hpv病毒能力?北京劲松HPV诊疗中心提出观点

​HPV&#xff0c;全称人乳头瘤病毒&#xff0c;是一种常见的性传播疾病&#xff0c;其症状包括尖锐湿疣、皮肤疣等。那么&#xff0c;人体是否有清除HPV病毒的能力呢?答案是肯定的&#xff0c;人体确实具有清除HPV病毒的能力。 首先&#xff0c;我们要了解HPV病毒是如何感染…

1+X网络系统建设与运维练习题

1.OSPF的最优路由&#xff0c;会放到IP路由表中指导数据转发 &#xff08;x&#xff09; 2.当AP工作在2.4GHz频段的时候&#xff0c;AP工作的频率范围是2.4GHz~2.4835GHZ。在此频率范围内又划分出14个信道。每信道的中心频率相隔5MHz&#xff0c;每个信道可供占用的带宽为22MHz…

​在做接口测试的时候,如果接口还没有开发好,你这边应该怎么去介入测试?

&#x1f4e2;专注于分享软件测试干货内容&#xff0c;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;交流讨论&#xff1a;欢迎加入我们一起学习&#xff01;&#x1f4e2;资源分享&#xff1a;耗时200小时精选的「软件测试」资…

从功能测试到自动化测试,我总结了一些工作经验分享给大家

&#x1f4e2;专注于分享软件测试干货内容&#xff0c;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;交流讨论&#xff1a;欢迎加入我们一起学习&#xff01;&#x1f4e2;资源分享&#xff1a;耗时200小时精选的「软件测试」资…

由于找不到steam_api64.dll如何修复?steam_api64.dll丢失多种解决方法

steam_api64.dll文件介绍 steam_api64.dll是Steam平台的一个关键组件&#xff0c;主要用于支持Steam客户端和相关游戏的应用程序。这个文件缺失或损坏会导致Steam及相关游戏无法正常运行。它位于Steam安装目录的bin子文件夹中。 steam_api64.dll丢失的原因 系统误删&#xf…

TiDB专题---2、TiDB整体架构和应用场景

上个章节我们讲解了TiDB的发展和特性&#xff0c;这节我们讲下TiDB具体的架构和应用场景。首先我们回顾下TiDB的优势。 TiDB的优势 与传统的单机数据库相比&#xff0c;TiDB 具有以下优势&#xff1a; 纯分布式架构&#xff0c;拥有良好的扩展性&#xff0c;支持弹性的扩缩容…

1.网络编程基础知识 - 基础概念、TCP网络通信、UDP网络通信

网络编程 文章目录 网络编程一、概念1.1 网络1.2 IP地址1.2.1 IPv4 介绍1.2.2 IPv6 介绍1.2.3 查看IP地址 1.3 域名和端口1.4 网络协议1.5 TCP与UDP1.6 InetAddress类1.7 Socket 二、TCP网络通信编程2.1 介绍2.2 案例2.2.1 字节流编程案例12.2.2 字节流编程案例22.2.3 字符流编…

防火墙之iptables

iptables概述 1.Linux 系统的防火墙 &#xff1a;IP信息包过滤系统&#xff0c;它实际上由两个组件netfilter 和 iptables组成。 2.主要工作在网络层&#xff0c;针对IP数据包。体现在对包内的IP地址、端口、协议等信息的处理上。 -netfilter/iptables关系&#xff1a; netfil…

docker-compose;私有镜像仓库harbor搭建;镜像推送到私有仓库harbor

docker-compose&#xff1b;私有镜像仓库harbor搭建&#xff1b;镜像推送到私有仓库harbor 文章目录 docker-compose&#xff1b;私有镜像仓库harbor搭建&#xff1b;镜像推送到私有仓库harbordocker-compose私有镜像仓库harbor搭建镜像推送到私有仓库harbor docker-compose D…

IC卡卡号,UID卡CUID卡物理卡号修改

普通M1卡的卡号是锁死的&#xff0c;不能修改&#xff0c;考勤工作证等使用的就是IC卡的物理卡号&#xff0c;读卡器读取后转换成10进制输出&#xff0c;出厂就固化了&#xff0c;因此用户拿到手的卡片卡号是不连续的&#xff0c;也是没有规律的&#xff0c;比如物理卡号8602A2…

Appium+python+unittest搭建UI自动化框架

阅读本小节&#xff0c;需要读者具备如下前提条件&#xff1a; 1. 掌握一种编程语言基础&#xff0c;如java、python等。 2. 掌握一种单元测试框架&#xff0c;如java语言的testng框架、python的unittest框架。 3. 掌握目前主流的UI测试框架&#xff0c;移动端APP测试框架…

【路径规划】move_base、路径规划算法、局部避障算法介绍

资料整理供个人学习使用。 文章目录 一、move_base1、move_base 包内容2、move_base 参数解析1. move_base 参数2. 全局代价地图参数3. 局部代价地图参数4. 全局规划器参数5. 局部规划器参数 二、路径规划1、Dijkstra2、最佳优先搜索3、A*4、A* 和 Dijkstra 比较 三、局部避障1…