MySql 数据库基础概念,基本简单操作及数据类型介绍
文章目录
- 数据库基础
- 为什么需要数据库?
- 创建数据库
- mysql架构
- SQL语句分类
- 编码集
- 修改数据库属性
- 数据库备份
- 表的基本操作
- 存在时更新,不存在时插入
- 数据类型
- 日期类型
- enum和set
数据库基础
- 以特定的格式保存文件,叫做数据库,这是狭义上的概念
- 提供较为便捷的数据存取服务的软件集合,解决方案的事物,这是广义上的数据库
mysql 的本质是一个进程,client通过网络向目标机的守护进程mysqld(server)发送sql语句,目标机的守护进程执行sql操作,所以mysql是一个应用程序,其运行在操作系统之上
操作mysql内部的数据时,本质上是操作文件内容,操作文件内容需要通过cpu提供的指令。根据冯诺依曼体系,cpu只能与内存进行交互,所以文件必须被加载到内存中
那么mysqld启动时就需要对OS申请一块空间,以执行sql操作,数据库的数据远大于可以使用的空间时,mysql就需要拥有自己的内存管理策略,即数据的换入与换出
所以mysql也需要进行内存管理
为什么需要数据库?
使用文件保存数据即可,为什么需要数据库?
例子:大量的数据,如10000个IP地址,文件和数据库都能存储
问题:需要将这10000个IP中以120开头的IP修改为119,并统计修改的IP个数。
使用文件解决以上问题,需要人为的对数据进行管理
数据库的本质也是文件,其特别之处在于提供了对文件的特定操作,不需要手动管理文件中的数据。即,mysql为用户和磁盘文件之间的一层软件层,能够控制磁盘文件,以减少使用成本
特点:方便,安全,高效
只是用文件的缺点:
- 安全性问题
- 海量数据的存储与处理
- 不方便的数据控制
mysql的存储介质:
- 磁盘为主,内存为辅
连接:
mysql -h IP -P 端口 -u 用户 -p
mysql -h 127.0.0.1 -P 3306 -u root -p
-p表示输入密码
不指明IP与端口,默认都是本地与3306
mysql -u root p
在配置文件中添加port = 端口号
,修改mysql服务绑定的端口号,一般建议修改,防止他人恶意攻击。默认端口号为3306
mysql是一个网络服务!是一个关系型数据库,noSql不是关系型数据库,如redis
创建数据库
创建数据库在Linux中是在做什么?
本质是在指定目录下建立一个目录,默认目录是/var/lib/mysql/
。甚至可以用mkdir指令直接创建一个目录,此时在mysql中show databases
也能看到该目录
通过网络服务将创建指令发送给mysql服务端,服务端接收到指令后解析指令,进行特定的操作
在mysql中,system
可以执行系统命令,如system clear
创建数据库
create database 库名
删除数据库
drop databse 库名
该数据库下的文件都会被删除,谨慎操作
mysql大小写不敏感。一般数据库的命令使用大写(但是小写字母更好看懂,所以我都是使用小写)
数据库名字可以用但引号表示`库名`。加了引号,库名就能使用特殊字符
选择数据库,类比cd
目录
use 库名
查看当前选择的数据库
select database()
展示
show tables
展示表项,show databases
展示数据库
建表后添加了两个文件,所以建表的本质是创建文件
通过查询创建语句来了解该数据库的细节信息
mysql架构
mysql分为三层:
- 连接层:负责客户端的连接,mysql的本质是一个应用层软件,连接层识别请求连接的IP,用来保护数据库。即通过IP地址和同户名密码保护mysql
- 语法分析层:词法语法分析,性能调优,编译级别的性能优化
- 存储引擎层:通过系统调用与磁盘打交道,插件式的存储引擎。该层有多个存储引擎,通过先描述后组织的管理方案,将存储引擎进行抽象管理。需要添加存储引擎时就创建相关结构,不需要某个存储引擎时就释放调该存储结构
站在系统的角度,mysql就是一个应用进程
站在网络的角度,mysql就是应用层协议的一种
除了mysql的客户端,其他的模块基本都是在Linux环境上运行的
SQL语句分类
- DDL(data definition language):数据定义语言,属性操作。用来维护存储数据的结构,create,drop,alter
- DML(data manipulation language):数据操纵语言,内容操作。insert,delete,update
- DQL(data query language):数据查询语言:select
以上是数据库的基本功能,接着是数据库的安全功能(临界资源,网络攻击)
- DQL(data query language):数据查询语言:select
- DCL(Data Control Language):数据控制语言,整个mysql的系统安全与账户管理工作,使mysql在主动和被动的情况下都是可靠的。grant,revoke,commit
存储引擎的查看
show engines
编码集
mysql有两个编码集,一个是编码格式集,一个是校验格式集
存数据要用到编码格式,取数据需要校验格式
通过命令查看字符集/编码集
show variables like 'character_set_%';
show variables like 'collation_database';
有些类似环境变量的查看
show variables like 'character_set_%'
:编码字符集的查看
show variables like 'collation_database'
:校验集的查看
这些值都是在conf配置文件中设置好了的
show charset
:支持的字符集
show collation
:支持的校验集
每个字符集都有对应的校验集,必须匹配
编码集和校验集都是针对表使用的
配置文件不指明这两集合,那么mysql也有默认方案
db.opt
文件中保存的就是默认的字符集和校验集
create database 数据库名 charest=gbk collate=utf8_bin
:设置字符集为gbk,校验集为utf8_bin
若数据库需要备份到远端其他机器上,则最好指明字符集与校验集,其他情况下不需要指明
创建数据库时,设置编码和校验规则,本质上是影响数据库下的表,所对应的编码和校验规则
创建表时,也能设置编码和校验规则,若不设置则会采用数据库的编码和校验规则
就近原则
查看表的列属性
desc person
查找person表的内容
select * from person
查找person表中含有a字符的数据
select * from person where name='a'
当前连接mysql的用户
show processlist
命令可以忽略大小写,但是命令的参数需要根据数据库的编码要求进行严格的大小写
utf8_general_ci
:该校验集需要数据库遵守大小写
bin_db
:该校验集不需要数据库遵循大小写
select database();
查看当前所在的数据库,相当于pwd
修改数据库属性
修改数据库字符集
alter database 数据库名 charset=gbk
修改只是修改数据库的编码与校验集
mysql不支持修改库名,但可以用shell直接mv修改数据库名,拷贝也是同理,但这是违规的
数据库备份
查询mysqldump工具是否存在
which mysqldump
执行以下命令:
mysqldump -P 3306 -u root -p -B 库名 > db_name.sql
P标识数据库使用的端口号,u表示执行拷贝操作的用户,p表示要输入该用户的密码,B表示要拷贝的数据库名称
将数据库重定向到sql文件中,不重定向的话拷贝的数据将打印到屏幕
mysqldump -P 3306 -u root -p -B 数据库名 表名1 表名2 > db_name.sql
,只备份对应的表
以此说明:mysql会保存历史输入的指令,并对指令做优化合并处理
备份有两种方式:备份数据与备份执行语句,
恢复数据库:
source .sql的绝对/相对路径
表的基本操作
建表
create table 表名(属性, 属性);
圆括号后的三个属性,若没有指明则以mysql的默认配置为主,就近原则
若创建的表名已经存在,mysql将抛出错误
其中comment是一种类似备注的信息,这些信息将被忽略
show create table 表名\G
展示创建表时的语句,\G
是mysql的一种扩展语法,不需要加;
不同引擎创建的表的逻辑结构是相同的,但是底层的物理结构却是不同的,体现在文件数量的不同,如InnoDb会创建两个文件,而MyISAM会创建三个文件
.frm:为表的列属性
.ibd:innodb中,存储表数据和索引数据的文件
.MYD:MyISAM中,存储表数据的文件
.MYI:MyISAM中,存储索引数据的文件
故MyISAM为非聚簇索引
插入数据
insert into 表名 (属性, 属性) values(属性值, 属性值);
添加列属性
alter table 表名 add 属性名 属性类型 after 属性
调整列属性类型
alter table 表名 modify 属性名 要调整的数据类型
删除列属性
删除操作不应该经常使用,无论是表的删除还是库的删除
alter table 表名 drop 要删除的属性名
只剩最后一个属性时,该属性无法删除,只能使用删除表的指令进行删除
表属性的修改
alter table 表名 change 原属性名 新属性名 新属性的类型
其中image_path
为原属性名称,path
为新属性名称,varchar(128)
表示新属性的类型
同样,这也是覆盖式的
表名的修改
alter table 旧表名 rename 新表名
表的删除
drop table 表名
表记录的删除
delete from 表名 where 属性=值
存在时更新,不存在时插入
出现主键/唯一键冲突时,插入已经存在的主键/唯一键会导致失败
在insert语句最后加上on duplicate key update 属性=值, 属性=值
,表示若插入失败则更新
0 row affected:表中存在冲突数据,但冲突的数据与update数据一样,没有数据被更新
1 row affected:表中没有冲突数据,数据被插入
2 row affected:表中存在冲突数据,但数据被update更新
select row_count()可以查看最近一条插入语句的结果,-1表示失败,其他值与上述情况一样
在一般insert语句中,将insert换成replace也能达到同样的效果,推荐使用replace
只要存在唯一键或者主键冲突,产生冲突的记录都将被修改,可能是一条也可能是多条
数据类型
### 数值范围
mysql的数据类型除了满足不同的应用场景,还有一个特别重要的点:就是约束
tinyint
:类比c语言char类型,一个字节
若插入的数据超出了数据的表达范围,那么mysql将直接报错,因为不允许这样的操作
这就倒逼程序员插入数据时,必须遵守mysql的规范
有些数据类型可以带上unsigned修饰,表示无符号
bit类型后带上()
,表示该数据类型使用几个bit位,bit类型的数据以ASCII码的格式显示
可以用where这样的语句读取bit类型的数据
salary float(M, D),M表示显示长度,数字的总数,d表示小数位数
如:salary float(4,2)表示的范围是(-99.99, 99.99)
插入数据时遵守四舍五入规则
salary float(4,2) unsigned的范围是(0, 99.99)
,负数不允许存储
decimal(4,2),规则和float一样
decimal存储的数据精度更高,float的精度大约是7位
decimal的m最大为65,默认为10,d最大为30,默认为0
char(L):L表示字符串的长度,最多是255
mysql中的字符与字节不等价
高级语言中的字符表示一个字节,而mysql的长度不是字节的意思,而是字符的意思。一个汉字虽然是一个字符,但是汉字的大小通常不是一个字节。但是在mysql中,长度为2的char可以存储两个汉字
varchar(L)的使用和char一样,其中L表示的是varchar的长度,L和表的编码有密切关系
varchar需要用1~3个字节表示存储的字符串长度,varchar的最多能存储65535字节数据,因此varchar的有效存储字节数为65532
当编码是utf8时,L的最大值为65532/3=21844,因为utf8中一个字符占3个字节。编码是gbk时,L的最大值是65532/2=32766,因为gbk中一个字符占用2个字节
变长指的是在固定长度中变长,相比于char,varchar可以有效的提高磁盘空间的使用
当长度不固定时,尽量使用变长字符串
日期类型
date:yyyy-mm-dd
,占用三字节
datetime:yyyy-mm-dd HH:ii:ss
,占用8字节
timestamp:时间戳,格式和datetime一样,占用4字节
插入表时,无法对时间戳类型进行数据插入,时间戳的数据会在你插入(修改)的一瞬间进行更新
t1,t2,t3分别为data,datetime和timestamp类型的数据
enum和set
enum和set的约束性更强
enum多选一,set多选多
若enum为(‘男’, ‘女’),插入时可以用具体的数据,也可以用1,2,3代替具体的数据…注意从1开始
set是二进制结构的选择,因为是多选多
对于set,用where查询时,只能查询完全相同的set,比如爱好为’唱,跳’,只能查出爱好为’唱,跳’的人,'唱,跳,rap’的人则查不出
此时需要用函数find_in_set(sub, str_list):如果sub在str_list中,则返回其下标,不在返回0
select * from votes where find_in_set('rap', hobby));
select * from votes where find_in_set('rap', hobby) and find_in_set('唱', hobby));
select * from votes where find_in_set('rap', hobby) or find_in_set('唱', hobby));
相关文章:

MySql 数据库基础概念,基本简单操作及数据类型介绍
文章目录 数据库基础为什么需要数据库?创建数据库mysql架构SQL语句分类编码集修改数据库属性数据库备份 表的基本操作存在时更新,不存在时插入 数据类型日期类型enum和set 数据库基础 以特定的格式保存文件,叫做数据库,这是狭义上…...

异步加载 JavaScript
目录 编辑 前言:异步加载 JavaScript 的重要性 详解:异步加载 JavaScript 的方法 使用 使用动态创建标签: 使用模块引入(ES6模块): 解析:异步加载 JavaScript 的重要性和优势 实践和注…...

汽车屏类产品(四):仪表Cluster
###前言 仪表Cluster/仪表盘Dashboard,作为伴随汽车诞生就存在的一个主要零部件之一,从机械到电子到数字,可以说也是逐渐发展到现在的。 目前的主流框图如下,中间processor就是主控芯片,可能有buttons/switches,有display显示屏+backlight背光,有audio->speake…...

【GA-ELM】基于遗传算法优化极限学习机回归预测研究(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

DFT和ATE岗位前景薪资对比,手把手教你如何选择岗位?
ATE测试和DFT可测性设计,虽然二者都对芯片测试至关重要,但是两个岗位的区别还是很大的。 两个岗位应该如何做选择? 先讲产业环节 我们知道芯片设计、芯片制造、芯片封测每个环节都是大工程,且每个环节都关键且重要。测试是芯片诞…...

驱动day4作业
通过字符设备驱动的分步实现编写LED驱动,另外实现特备文件和设备的绑定 head.h #ifndef __HEAD_H__ #define __HEAD_H__ typedef struct{unsigned int MODER;unsigned int OTYPER;unsigned int OSPEEDR;unsigned int PUPDR;unsigned int IDR;unsigned int ODR; }…...
【Oracle】VC6.0使用 odbc 访问 Oracle 存储过程
环境说明 系统环境 系统:Windows XP IDE: Microsoft Visual C 6.0 使用的对象 msado15.tlh _ConnectionPtr m_pConnection; HRESULT hr m_pConnection.CreateInstance(“ADODB.Connection”); _RecordsetPtr m_pRecordset; m_pRecordset.CreateInstan…...

QWidget快速美化-圆形蓝色单选框
将代码复制进QRadioButton的样式表 效果: 代码: QRadioButton{font:75 9pt "Arial";background:transparent;color:white;border:none; }QRadioButton:disabled{color:gray; }QRadioButton::indicator{width:12px;height:12px;border-radius:8px; }QRadioButton::i…...
adb 获取当前界面元素
adb配置正确,直接看6,pull的位置是你执行pull的目录下。 --------------------------------------------------------------------------------------------------------------------------------- 使用adb命令获取当前应用的元素需要先连接到手机或模…...
SpringSecurity源码学习四:会话管理
目录 1. 什么是会话管理2. springSecurity中的session管理怎么做的3. springSecurity源码中的session管理4. 代码示例5. 源码5.1 不同策略的含义 6. 集群模式session管理7. 总结 1. 什么是会话管理 会话管理是指在Java应用程序中管理用户会话状态的过程。在Spring框架中&#…...
Kotlin笔记(七):协程
1. 协程的定义 协程属于Kotlin中非常有特色的一项技术,因为大部分编程语言中是没有协程这个概念的。 什么是协程呢?它其实和线程是有点类似的,可以简单地将它理解成一种轻量级的线程。要知道,线程是非常重量级的,它需要…...

存储优化知识复习二详细版解析
存储优化 知识复习二 一、 选择题 1、 对数据库调优的方法中,最困难但是最有成效的是( )。 A、优化表的架构设计 B、添加内存 C、索引优化 D、查询语句优化 【参考答案】A2、 防止与处理死锁的方法有( )。 A、尽量避免或尽快处理阻塞 B、访…...

《持续交付:发布可靠软件的系统方法》- 读书笔记(七)
持续交付:发布可靠软件的系统方法(七) 第 7 章 提交阶段7.1 引言7.2 提交阶段的原则和实践7.2.1 提供快速有用的反馈7.2.2 何时令提交阶段失败7.2.3 精心对待提交阶段7.2.4 让开发人员也拥有所有权7.2.5 在超大项目团队中指定一个构建负责人 …...
Go源码实现使用多线程并发下载大文件的功能
摘要:Go语言编码实现了使用多线程并发下载文件的功能。 1. 代码流程介绍 1. 获取系统的CPU核心数量,并将其作为线程数的参考值,并打印出来。 2. 定义要下载的文件的URL、线程数和输出文件名。 3. 使用getFileSize()函数获取文件大小…...

Python基础入门例程1-NP1 Hello World!
描述 将字符串 Hello World! 存储到变量str中,再使用print语句将其打印出来。 输入描述: 无 输出描述: 一行输出字符串Hello World! 解答: str "Hello World!" print(str) 解释说明: 赋值变量&…...
前端面试题10.23
解决的最复杂的前端问题,介绍一下 最复杂的前端问题之一是浏览器兼容性,不同浏览器对网页的渲染方式存在差异,需要针对不同浏览器做兼容性处理。此外,前端性能优化也是一个复杂的问题,需要综合考虑网页加载速度、渲染…...

DYC算法开发与测试(基于ModelBase实现)
ModelBase是经纬恒润开发的车辆仿真软件,包含两个大版本:动力学版本、智能驾驶版本。动力学版包含高精度动力学模型,能很好地复现车辆在实际道路中运行的各种状态变化,可用于乘用车、商用车动力底盘系统算法开发、控制器仿真测试&…...

第四章 路由基础
目录 4.1 路由器概述 4.1.1 路由器定义 4.1.2 路由器工作原理 4.1.3 路由表的生成方式 (1)直连路由 (2)静态路由 (3)动态路由 4.1.4 路由器的接口 (1)配置接口 ࿰…...

Java逻辑运算符(、||和!),Java关系运算符
逻辑运算符把各个运算的关系表达式连接起来组成一个复杂的逻辑表达式,以判断程序中的表达式是否成立,判断的结果是 true 或 false。 逻辑运算符是对布尔型变量进行运算,其结果也是布尔型,具体如表 1 所示。 表 1 逻辑运算符的用…...

三个设备文件
...

简易版抽奖活动的设计技术方案
1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...

Docker 运行 Kafka 带 SASL 认证教程
Docker 运行 Kafka 带 SASL 认证教程 Docker 运行 Kafka 带 SASL 认证教程一、说明二、环境准备三、编写 Docker Compose 和 jaas文件docker-compose.yml代码说明:server_jaas.conf 四、启动服务五、验证服务六、连接kafka服务七、总结 Docker 运行 Kafka 带 SASL 认…...

SCAU期末笔记 - 数据分析与数据挖掘题库解析
这门怎么题库答案不全啊日 来简单学一下子来 一、选择题(可多选) 将原始数据进行集成、变换、维度规约、数值规约是在以下哪个步骤的任务?(C) A. 频繁模式挖掘 B.分类和预测 C.数据预处理 D.数据流挖掘 A. 频繁模式挖掘:专注于发现数据中…...

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...
React Native在HarmonyOS 5.0阅读类应用开发中的实践
一、技术选型背景 随着HarmonyOS 5.0对Web兼容层的增强,React Native作为跨平台框架可通过重新编译ArkTS组件实现85%以上的代码复用率。阅读类应用具有UI复杂度低、数据流清晰的特点。 二、核心实现方案 1. 环境配置 (1)使用React Native…...

基于TurtleBot3在Gazebo地图实现机器人远程控制
1. TurtleBot3环境配置 # 下载TurtleBot3核心包 mkdir -p ~/catkin_ws/src cd ~/catkin_ws/src git clone -b noetic-devel https://github.com/ROBOTIS-GIT/turtlebot3.git git clone -b noetic https://github.com/ROBOTIS-GIT/turtlebot3_msgs.git git clone -b noetic-dev…...

云原生安全实战:API网关Kong的鉴权与限流详解
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 一、基础概念 1. API网关(API Gateway) API网关是微服务架构中的核心组件,负责统一管理所有API的流量入口。它像一座…...

TSN交换机正在重构工业网络,PROFINET和EtherCAT会被取代吗?
在工业自动化持续演进的今天,通信网络的角色正变得愈发关键。 2025年6月6日,为期三天的华南国际工业博览会在深圳国际会展中心(宝安)圆满落幕。作为国内工业通信领域的技术型企业,光路科技(Fiberroad&…...

关于easyexcel动态下拉选问题处理
前些日子突然碰到一个问题,说是客户的导入文件模版想支持部分导入内容的下拉选,于是我就找了easyexcel官网寻找解决方案,并没有找到合适的方案,没办法只能自己动手并分享出来,针对Java生成Excel下拉菜单时因选项过多导…...

Vue ③-生命周期 || 脚手架
生命周期 思考:什么时候可以发送初始化渲染请求?(越早越好) 什么时候可以开始操作dom?(至少dom得渲染出来) Vue生命周期: 一个Vue实例从 创建 到 销毁 的整个过程。 生命周期四个…...