JavaWeb----MySQL

news2025/1/14 0:45:15

一:JavaWeb相关介绍

Web:全球广域网,也称为万维网(www),能够通过浏览器访问的网站

JavaWeb:是用Java技术来解决相关Web互联网领域的技术栈

JavaWeb流程

1.网页:展现数据

2.数据库:存储和管理数据

3.JavaWeb程序:逻辑处理

二:数据库相关介绍

1 数据库  

存储和管理数据的仓库,数据是有组织的进行存储。
数据库英文名是 DataBase ,简称 DB
数据库就是将数据存储在硬盘上,可以达到持久化存储的效果。那又是如何解决上述问题的?使用数据库管理系统。

2 数据库管理系统

管理数据库的大型软件
英文: DataBase Management System ,简称 DBMS
在电脑上安装了数据库管理系统后,就可以通过数据库管理系统创建数据库来存储数据,也可以通过该系统对数据库中的数
据进行数据的增删改查相关的操作。我们平时说的 MySQL 数据库其实是 MySQL 数据库管理系统。

3 常见的数据库管理系统

Oracle :收费的大型数据库, Oracle 公司的产品
MySQL : 开源免费的中小型数据库。后来 Sun 公司收购了 MySQL ,而 Sun 公司又被 Oracle 收购
SQL Server MicroSoft 公司收费的中型的数据库。 C# .net 等语言常使用
PostgreSQL :开源免费中小型的数据库
DB2 IBM 公司的大型收费数据库产品
SQLite :嵌入式的微型数据库。如:作为 Android 内置数据库
MariaDB :开源免费中小型的数据库

4 SQL

英文: Structured Query Language ,简称 SQL ,结构化查询语言
操作关系型数据库的编程语言
定义操作所有关系型数据库的统一标准,可以使用 SQL 操作所有的关系型数据库管理系统,以后工作中如果使用到了其
他的数据库管理系统,也同样的使用 SQL 来操作。

5 cmd登录,退出MySQL

右键开始菜单,选择 命令提示符 ,打开黑框。 在黑框中输入, mysql - uroot - p1234 ,回车,出现下图且左下角为
mysql> ,则登录成功。
退出 mysql exit   quit

6 MySQL数据模型

(1)关系型数据库:

关系型数据库是建立在关系模型基础上的数据库,简单说,关系型数据库是由多张能互相连接的 二维表 组成的数据库。
如   订单信息表 客户信息表 都是有行有列二维表我们将这样的称为关系型数据库。
优点:
都是使用表结构,格式一致,易于维护。
使用通用的 SQL 语言操作,使用方便,可用于复杂查询。
关系型数据库都可以通过 SQL 进行操作,所以使用方便。
复杂查询。现在需要查询 001 号订单数据,我们可以看到该订单是 1 号客户的订单,而 1 号订单是李聪这个客户。以
后也可以在一张表中进行统计分析等操作。
数据存储在磁盘中,安全。

(2)数据模型

如上图,我们通过客户端可以通过数据库管理系统创建数据库,在数据库中创建表,在表中添加数据。创建的每一个数据库 对应到磁盘上都是一个文件夹。

小结: MySQL 中可以创建多个数据库,每个数据库对应到磁盘上的一个文件夹
在每个数据库中可以创建多个表,每张都对应到磁盘上一个 frm 文件
每张表可以存储多条数据,数据会被存储到磁盘中 MYD 文件中

三:SQL概述

1 SQL简介

英文: Structured Query Language ,简称 SQL
结构化查询语言,一门操作关系型数据库的编程语言
定义操作所有关系型数据库的统一标准
对于同一个需求,每一种数据库操作的方式可能会存在一些不一样的地方,我们称为 方言

2 通用语法

SQL 语句可以单行或多行书写,以分号结尾,以分号结尾才是一个完整的 sql 语句。
MySQL 数据库的 SQL 语句不区分大小写,关键字建议使用大写
注释:
单行注释 : -- 注释内容 或 # 注释内容 (MySQL 特有 )
注意:使用 -- 添加单行注释时, -- 后面一定要加空格,而 # 没有要求。
多行注释 : /* 注释 */

3 SQL分类

DDL(Data Definition Language) : 数据定义语言,用来定义数据库对象:数据库,表,列等
DDL 简单理解就是用来操作数据库,表等
DML(Data Manipulation Language) 数据操作语言,用来对数据库中表的数据进行增删改
DML 简单理解就对表中数据进行增删改
DQL(Data Query Language) 数据查询语言,用来查询数据库中表的记录 ( 数据 )
DQL 简单理解就是对数据进行查询操作。从数据库表中查询到我们想要的数据。
DCL(Data Control Language) 数据控制语言,用来定义数据库的访问权限和安全级别,及创建用户
DCL 简单理解就是对数据库进行权限控制。比如我让某一个数据库表只能让某一个用户进行操作等。
注意: 以后我们最常操作的是 DML DQL ,因为我们开发中最常操作的就是数据

四:DDL:用来操作数据库

1.操作数据库

(1)查询数据库:

show databases;

(2)创建数据库

create database ;
create database if not exists;

(3)删除数据库

drop database;
drop database if exists;

(4)使用数据库

use 数据库名称

(5)查看当前使用的数据库名称

select database();

2.操作表

(1)查询表

<1>查询当前数据库下所有表名称
show tables;
<2>查询表结构
desc 表名称

(2)创建表

(3)数据类型

(4)删除表

drop tables 表名;
drop tables if exists 表名;

(5)修改表

五:DML:对表中数据进行增删改

1 添加数据

2 修改数据

3 删除数据

六:DQL:对数据进行查询操作

1 基础查询

2 条件查询

(1)清晰

条件列表可以使用以下运算符

(2)模糊查询(like关键字)

3 排序查询

4 聚合函数

将一列数据作为一个整体,进行纵向计算

(1)分类

(2)语法

5 分组查询

where having 区别:
执行时机不一样: where 是分组之前进行限定,不满足 where 条件,则不参与分组,而 having 是分组之后对结果进行过
滤。
可判断的条件不一样: where 不能对聚合函数进行判断, having 可以。

6 分页查询

七:约束

1.概念

约束是作用于表中列上的规则,用于限制加入表的数据
例如:我们可以给 id 列加约束,让其值不能重复,不能为 null 值。
约束的存在保证了数据库中数据的正确性、有效性和完整性;添加约束可以在添加数据的时候就限制不正确的数据,年龄是3000 ,数学成绩是 -5 分这样无效的数据,继而保障数据的完整性。

2.分类

非空约束: 关键字是 NOT NULL
保证列中所有的数据不能有 null
唯一约束:关键字是 UNIQUE
保证列中所有数据各不相同
主键约束: 关键字是 PRIMARY KEY
主键是一行数据的唯一标识,要求非空且唯一。一般我们都会给没张表添加一个主键列用来唯一标识数据
检查约束: 关键字是 CHECK
保证列中的值满足某一条件
注意: MySQL 不支持检查约束。 这样是不是就没办法保证年龄在指定的范围内了?从数据库层面不能保证,以后可以在 java 代码中进行限制,一样也
可以实现要求。
默认约束: 关键字是 DEFAULT
保存数据时,未指定值则采用默认值
外键约束: 关键字是 FOREIGN KEY
外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性

3.非空约束

(1)概念

非空约束用于保证列中所有数据不能有 NULL

(2)语法

4.唯一约束

(1)概念

唯一约束用于保证列中所有数据各不相同

(2)语法

5.主键约束

(1)概念

主键是一行数据的唯一标识,要求非空且唯一 ;一张表只能有一个主键

(2)语法

6.默认约束

(1)概念

保存数据时,未指定值则采用默认值

(2)语法

注意:默认约束只有在不给值时才会采用默认值。如果给了 null ,那值就是 null 值。

7.外键约束

(1)概念

外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性

(2)语法

八:数据库设计

1 .数据库设计简介

(1)软件的研发步骤

(2)数据库设计概念

数据库设计就是根据业务系统的具体需求,结合我们所选用的 DBMS ,为这个业务系统构造出最优的数据存储模 型。
建立数据库中的 表结构 以及 表与表之间的关联关系 的过程。
有哪些表?表里有哪些字段?表和表之间有什么关系?

(3)数据库设计的步骤

需求分析(数据是什么 ? 数据具有哪些属性 ? 数据与属性的特点是什么)
逻辑分析(通过 ER 图对数据库进行逻辑建模,不需要考虑我们所选用的数据库管理系统)
物理设计(根据数据库自身的特点把逻辑设计转换为物理设计)
维护设计( 1. 对新的需求进行建表; 2. 表优化)

2.表关系 :一对一

如:用户 和 用户详情
一对一关系多用于表拆分,将一个实体中经常使用的字段放一张表,不经常使用的字段放另一张表,用于提升查询性
实现方式 : 在任意一方加入外键,关联另一方主键,并且设置外键为唯一 (UNIQUE)
create table tb_user_desc (
id int primary key auto_increment,
city varchar(20),
edu varchar(10),
income int,
status char(2),
des varchar(100)
);

create table tb_user (
id int primary key auto_increment,
photo varchar(100),
nickname varchar(50),
age int,
gender char(1),
desc_id int unique,

-- 添加外键
CONSTRAINT fk_user_desc FOREIGN KEY(desc_id) REFERENCES tb_user_desc(id)
);

3.表关系 :一对多

如:部门 和 员工
一个部门对应多个员工,一个员工对应一个部门。
实现方式: 在多的一方建立外键,指向一的一方的主键
-- 部门表
CREATE TABLE tb_dept(
id int primary key auto_increment,
dep_name varchar(20),
addr varchar(20)
);

-- 员工表
CREATE TABLE tb_emp(
id int primary key auto_increment,
name varchar(20),
age int,
dep_id int,

-- 添加外键 dep_id,关联 dept 表的id主键
CONSTRAINT fk_emp_dept FOREIGN KEY(dep_id) REFERENCES tb_dept(id)
);

4.表关系 :多对多

如:商品 和 订单
一个商品对应多个订单,一个订单包含多个商品。
实现方式 : 建立第三张中间表,中间表至少包含两个外键,分别关联两方主键
-- 订单表
CREATE TABLE tb_order(
id int primary key auto_increment,
payment double(10,2),
payment_type TINYINT,
status TINYINT
);

-- 商品表
CREATE TABLE tb_goods(
id int primary key auto_increment,
title varchar(100),
price double(10,2)
);

-- 订单商品中间表
CREATE TABLE tb_order_goods(
id int primary key auto_increment,
order_id int,
goods_id int,
count int
);

-- 建完表后,添加外键
alter table tb_order_goods add CONSTRAINT fk_order_id FOREIGN key(order_id) REFERENCES
tb_order(id);
alter table tb_order_goods add CONSTRAINT fk_goods_id FOREIGN key(goods_id) REFERENCES
tb_goods(id);

九:多表查询

1.介绍

多表查询顾名思义就是从多张表中一次性的查询出我们想要的数据。
连接查询:
        内连接查询:相当于查询 AB 交集数据
        外连接查询:
               左外连接查询 :相当于查询 A 表所有数据和交集部门数据
               右外连接查询 : 相当于查询 B 表所有数据和交集部分数据
子查询

2.内连接查询

-- 隐式内连接
SELECT 字段列表 FROM 表1,表2… WHERE 条件;

-- 显示内连接
SELECT 字段列表 FROM 表1 [INNER] JOIN 表2 ON 条件;
内连接相当于查询 A B 交集数据
-- 隐式内连接
SELECT * FROM emp,dept WHERE emp.dep_id = dept.did;

-- 显示内连接
select * from emp inner join dept on emp.dep_id = dept.did;
-- 上面语句中的inner可以省略,可以书写为如下语句
select * from emp join dept on emp.dep_id = dept.did;

 

3.外连接查询

-- 左外连接
SELECT 字段列表 FROM 表1 LEFT [OUTER] JOIN 表2 ON 条件;
-- 右外连接
SELECT 字段列表 FROM 表1 RIGHT [OUTER] JOIN 表2 ON 条件;
左外连接:相当于查询 A 表所有数据和交集部分数据
右外连接:相当于查询B表所有数据和交集部分数据

查询 dept 表所有数据和对应的员工信息(右外连接)

4.子查询

查询中嵌套查询,称嵌套查询为子查询。

子查询根据查询结果不同,作用不同
-- 查询 '财务部' 或者 '市场部' 所有的员工的部门did
select did from dept where dname = '财务部' or dname = '市场部';

select * from emp where dep_id in (select did from dept where dname = '财务部' or dname =
'市场部');



-- 查询入职日期是 '2011-11-11' 之后的员工信息
select * from emp where join_date > '2011-11-11' ;
-- 将上面语句的结果作为虚拟表和dept表进行内连接查询
select * from (select * from emp where join_date > '2011-11-11' ) t1, dept where
t1.dep_id = dept.did;

十:事务

1 概述

数据库的事务( Transaction )是一种机制、一个操作序列,包含了 一组数据库操作命令
事务把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这一组数据库命令 要么同时成功,要么同时失败
事务是一个不可分割的工作逻辑单元。

2 语法

-- 开启事务
start transaction;  或   begin;


-- 提交事务
commit;


-- 回滚事务
rollback;

3 代码验证

-- 创建账户表
CREATE TABLE account(
id int PRIMARY KEY auto_increment,
name varchar(10),
money double(10,2)
);

-- 添加数据
INSERT INTO account(name,money) values('张三',1000),('李四',1000);


--不加事务演示问题
-- 转账操作
-- 1. 查询李四账户金额是否大于500

-- 2. 李四账户 -500
UPDATE account set money = money - 500 where name = '李四';

-- 3. 张三账户 +500
UPDATE account set money = money + 500 where name = '张三';

添加事务 sql 如下
-- 开启事务
BEGIN;

-- 转账操作
-- 1. 查询李四账户金额是否大于500

-- 2. 李四账户 -500
UPDATE account set money = money - 500 where name = '李四';

-- 3. 张三账户 +500
UPDATE account set money = money + 500 where name = '张三';

-- 提交事务
COMMIT;

-- 回滚事务
ROLLBACK;
上面 sql 中的执行成功进选择执行提交事务,而出现问题则执行回滚事务的语句。以后我们肯定不可能这样操作,而是在 java中进行操作,在 java 中可以抓取异常,没出现异常提交事务,出现异常回滚事务。

4 事务的四大特征

原子性( Atomicity : 事务是不可分割的最小操作单位,要么同时成功,要么同时失败
一致性( Consistency : 事务完成时,必须使所有的数据都保持一致状态
隔离性( Isolation : 多个事务之间,操作的可见性
持久性( Durability : 事务一旦提交或回滚,它对数据库中的数据的改变就是永久的

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

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

相关文章

postman只读模式的解决办法

我大概是多次复制参数&#xff08;或是别的操作&#xff09;&#xff0c;进入了postman的只读模式。这时无法修改页面的传参&#xff0c;而且右上角的save按钮是灰色&#xff08;不可选&#xff09; 下面分享我的2种解决办法 第一种方法 在任务栏右键选中接口&#xff0c;选…

RUST 每日一省:发布到crates.io

github是开源代码分享的地方&#xff0c;rust的开源项目除了github&#xff0c;我们还可以将其发布到 crates.io 上&#xff0c;然后其它用户就可以使用cargo进行安装使用了。其实步骤很简单&#xff0c;只有三条命令了&#xff0c;我们一次来看一下。 1、cargo package 首先&a…

使用Navicat连接阿里云服务器上的MySQL数据库

打开navicat&#xff0c;连接如下&#xff1a; 服务器的默认密码是 root 连接时出现 使用 ls 查找 /etc/my.cnf ls /etc/my.cnf 用vi打开my.cnf&#xff1a; vi /etc/my.cnf看看是否有绑定本地回环地址的配置&#xff0c;如果有&#xff0c;注释掉下面这段文字&#xff1a;…

GitHub Desktop的常用操作【图形化】

文章目录 【1】仓库的创建和删除【2】文件操作【3】分支原理与分支操作1.分支创建2.分支合并 【4】标签 【1】仓库的创建和删除 在本地创建一个新的仓库&#xff1a; 然后输入仓库的名称&#xff0c;描述&#xff0c;并选择路径&#xff1a; 点击完后就发现我们的仓库创建好…

Anaconda的使用及spyder相关设置

Anaconda Anaconda是一个Python发行版&#xff0c;主要用于数据科学和机器学习领域。Anaconda集成了许多常用的数据科学工具和库&#xff0c;如NumPy、Pandas、Scikit-learn等&#xff0c;同时还包含了一个强大的包管理器conda和一个集成开发环境Spyder。Anaconda的目标是提供一…

鼠标光标选取文本、获取文本索引

1.效果图 这是在做一个字段分割的需求 2.思路 步骤一&#xff1a;通过document添加mouseup事件&#xff1b; 步骤二&#xff1a;通过window的getSelection()函数获取文本值&#xff1b; 步骤三&#xff1a;通过mouseup事件的event 类名来限制可截取元素的范围&#xff1b;…

论文解读:Meta-Baseline: Exploring Simple Meta-Learning for Few-Shot Learning

文章汇总 总体问题 通过对整体分类的训练(文章结构图中ClassifierBaseline)&#xff0c;即在整个标签集上进行分类&#xff0c;它可以得到与许多元学习算法相当甚至更好的嵌入。这两种工作之间的界限尚未得到充分的探索&#xff0c;元学习在少样本学习中的有效性仍然不清楚。…

【CSP】201403-3-命令行选项

CSP-201403-3-命令行选项 关键点&#xff1a;将整行字符串按空格分割 在解析命令行时&#xff0c;一个常见的需求是将整个命令行字符串分割成多个部分&#xff0c;通常以空格为分隔符。这些部分包括命令行工具的名称、选项&#xff08;可能带有前缀-或--&#xff09;和这些选项…

【Simulink系列】——控制系统仿真基础

声明&#xff1a;本系列博客参考有关专业书籍&#xff0c;截图均为自己实操&#xff0c;仅供交流学习&#xff01; 一、控制系统基本概念 这里就不再介绍类似于开环系统、闭环系统等基本概念了&#xff01; 1、数学模型 控制系统的数学模型是指动态数学模型&#xff0c;大致…

CGAL 5.6.1 - Algebraic Foundations

1. 引言 CGAL 的目标是精确计算非线性对象&#xff0c;特别是定义在代数曲线和曲面上的对象。因此&#xff0c;表示多项式、代数扩展和有限域的类型在相关的实现中扮演着更加重要的角色。为了跟上这些变化&#xff0c;我们引入了这个软件包。由于引入的框架必须特别支持多项式…

基于云效构建部署Springboot项目到ACK

介绍 为了提高项目迭代的速度加速交付产品给客户&#xff0c;我们通常会选择CICD工具来减少人力投入产生的成本&#xff0c;开源的工具比如有成熟的Jenkins&#xff0c;但是本文讲的是阿里云提高的解决方案云效平台&#xff0c;通过配置流水线的形式实现项目的快速部署到服务器…

PostgreSQL开发与实战(6.2)体系结构2

作者&#xff1a;太阳 二、逻辑架构 graph TD A[database] -->B(schema) B -->C[表] B -->D[视图] B -->E[触发器] C -->F[索引] tablespace 三、内存结构 Postgres内存结构主要分为 共享内存 与 本地内存 两部分。共享内存为所有的 background process提供内…

【Python】5. 基础语法(3) -- 函数篇

函数 函数是什么 编程中的函数和数学中的函数有一定的相似之处. 数学上的函数, 比如 y sin x , x 取不同的值, y 就会得到不同的结果. 编程中的函数, 是一段可以被重复使用的代码片段 . # 代码示例: 求数列的和 # 1. 求 1 - 100 的和 sum 0 for i in range(1, 101):sum i…

Debian篇——系统安装在SD卡上如何调整系统分区大小

背景&#xff1a;我的SD卡是128G的&#xff0c;开发商安装好系统后&#xff0c;我发现SD的系统分区才8.9G空间&#xff08;剩下的108G未分区&#xff09;&#xff0c;不够使用&#xff0c;于是需要调整系统分区的大小。 1.查看系统盘挂载情况 df -h 2.查看系统盘在哪个分区 …

Windows系统搭建VisualSVN并结合内网穿透实现远程访问本地服务

文章目录 前言1. VisualSVN安装与配置2. VisualSVN Server管理界面配置3. 安装cpolar内网穿透3.1 注册账号3.2 下载cpolar客户端3.3 登录cpolar web ui管理界面3.4 创建公网地址 4. 固定公网地址访问 前言 SVN 是 subversion 的缩写&#xff0c;是一个开放源代码的版本控制系统…

如何在Win系统部署Tomcat服务并实现远程访问内网站点

文章目录 前言1.本地Tomcat网页搭建1.1 Tomcat安装1.2 配置环境变量1.3 环境配置1.4 Tomcat运行测试1.5 Cpolar安装和注册 2.本地网页发布2.1.Cpolar云端设置2.2 Cpolar本地设置 3.公网访问测试4.结语 正文开始前给大家推荐个网站&#xff0c;前些天发现了一个巨牛的人工智能学…

基于梯度提升树实现波士顿房价预测

基于梯度提升树实现波士顿房价预测 将波士顿房价数据集拆分成训练集和测试集&#xff0c;搭建gbdt_1、gbdt_2和gbdt_3三个梯度提升树模型&#xff0c;分布设置超参数n_estimators为50、100、150。各自对训练集进行训练&#xff0c;然后分别对训练集和测试集进行预测。输出以下…

力扣新思路:改变字符串进行返回操作

我们在对字符串进行判断操作和返回操作时&#xff0c;可以增加\0来简化返回操作 char* longestCommonPrefix(char** strs, int strsSize) {if(strsSize0){return"";}for(int i0;i<strlen(strs[0]);i){for(int j1;j<strsSize;j){if(strs[0][i]!strs[j][i]) {s…

掀桌子了!20万左右的混动SUV,千万别乱选

文 | AUTO芯球 作者 | 雷歌 又掀桌子了&#xff01; 比亚迪秦PLUS掀翻了混动轿车圈的桌子后&#xff0c;又来掀混动SUV的桌子了。 而且掀桌子的还不只一家&#xff0c;比亚迪掀完奇瑞掀。 比亚迪唐DM-i以17.98万起售的价格&#xff0c;掀掉了中型混动SUV的桌子&#xff0c;…

springboot247人事管理系统

人事管理系统的设计与实现 摘 要 传统信息的管理大部分依赖于管理人员的手工登记与管理&#xff0c;然而&#xff0c;随着近些年信息技术的迅猛发展&#xff0c;让许多比较老套的信息管理模式进行了更新迭代&#xff0c;问卷信息因为其管理内容繁杂&#xff0c;管理数量繁多导…