当前位置: 首页 > news >正文

MySQL 的基础操作

数据库的基础操作

  • 1. 库操作
  • 2. 表的操作
  • 3. 数据类型

数据库是现代应用程序中至关重要的组成部分,通过数据库管理系统(DBMS)存储和管理数据。

1. 库操作

  1. 创建数据库
    创建数据库是开始使用数据库的第一步。下面是一些常见的创建数据库的示例:
-- 创建名为 db1 的数据库,使用 utf8 字符集
CREATE DATABASE db1 DEFAULT CHARACTER SET utf8;-- 创建名为 db2 的数据库,指定字符集为 utf8
CREATE DATABASE db2 CHARSET=utf8;-- 创建名为 db3 的数据库,指定字符集为 utf8,校验规则为 utf8_general_ci
CREATE DATABASE db3 CHARSET=utf8 COLLATE utf8_general_ci;
  1. 查看系统默认字符集和校验规则
    您可以使用以下命令查看系统默认字符集和校验规则:
SHOW VARIABLES LIKE 'character_set_database';
SHOW VARIABLES LIKE 'collation_database';
  1. 查看数据库支持的字符集和校验规则
    您可以使用以下命令查看数据库支持的字符集和校验规则:
SHOW CHARSET;
SHOW COLLATION;
  1. 查看数据库
    您可以使用以下命令查看当前数据库中的所有数据库:
SHOW DATABASES;
  1. 显示数据库创建语句
    您可以使用以下命令显示数据库的创建语句:
SHOW CREATE DATABASE database_name;
  1. 修改数据库
    您可以使用以下命令修改数据库的字符集和校验规则:
ALTER DATABASE database_name CHARACTER SET charset_name;
ALTER DATABASE database_name COLLATE collation_name;
  1. 删除数据库
    如果需要删除数据库,可以使用以下命令:
DROP DATABASE database_name;
  1. 备份数据
    您可以使用 mysqldump 命令将数据库备份到文件中:
mysqldump -u username -p database_name > backup_file.sql
  1. 恢复数据
    要恢复备份的数据,可以使用 source 命令:
source /path/to/backup_file.sql;
  1. 查看连接情况
    您可以使用以下命令查看当前数据库连接情况:
SHOW PROCESSLIST;

2. 表的操作

数据库表是组织和存储数据的关键。在数据库中,您可以通过创建、修改、删除表等操作来管理数据。

  1. 创建表
    表的创建是数据库设计的第一步,通过以下语法可以创建表:
CREATE TABLE table_name (
field1 datatype,
field2 datatype,
field3 datatype
) character set 字符集 collate 校验规则 engine 存储引擎;

field 表示列名
datatype 表示列的类型
character set 字符集,如果没有指定字符集,则以所在数据库的字符集为准
collate 校验规则,如果没有指定校验规则,则以所在数据库的校验规则为准

具体示例可以参考以下案例:

create table users (
id int,
name varchar(20) comment '用户名',
password char(32) comment '密码',
birthday date comment '生日'
) character set utf8 engine MyISAM;
  1. 查看表结构

使用 DESC 命令可以查看表的结构:

DESC users;

在这里插入图片描述

Field(字段):列名,分别是 id、name、password 和 birthday。
Type(类型):数据类型,分别是 int(11)、varchar(20)、char(32) 和 date。
Null(可为空):表示该列是否允许为空,这里都是YES,表示允许为空。
Key(键):表示该列是否为主键,这里为空。
Default(默认值):表示该列的默认值,这里都是NULL,表示没有默认值。
Extra(额外信息):包含了关于列的额外信息,这里都为空。

  1. 修改表

在项目实际开发中,我们经常需要修改表的结构,比如添加字段、修改字段属性、删除字段等。以下是一些常见的修改表的操作:

-- 在users表添加记录
INSERT INTO users VALUES (1, 'a', 'b', '1982-01-04'), (2, 'b', 'c', '1984-01-04');
-- 在users表添加一个字段,用于保存图片路径
ALTER TABLE users ADD assets VARCHAR(100) COMMENT '图片路径' AFTER birthday;
-- 修改name字段长度为60
ALTER TABLE users MODIFY name VARCHAR(60);
-- 删除password列
ALTER TABLE users DROP COLUMN password;
-- 修改表名为employee
ALTER TABLE users RENAME TO employee;
-- 将name列修改为xingming
ALTER TABLE employee CHANGE COLUMN name xingming VARCHAR(60);
  1. 删除表

如果需要删除表,可以使用以下命令:

DROP TABLE IF EXISTS table_name;

3. 数据类型

数值类型
BIT(M): 位类型,M指定位数,默认为1,范围为1-64。
TINYINT [UNSIGNED]: 字节最小值为 -128,最大值为127(有符号),范围为0~255(无符号)。
BOOL: 使用01表示真和假。
SMALLINT [UNSIGNED]: 带符号范围为 -3276832767,无符号范围为0~65535。
INT [UNSIGNED]: 带符号范围为 -21474836482147483647 ,无符号范围为0~4294967295
BIGINT [UNSIGNED]: 带符号范围为 -92233720368547758089223372036854775807 ,无符号范围为 0~18446744073709551615
FLOAT(M,D) [UNSIGNED]: 单精度浮点数,M指定显示长度,D指定小数位数,占用4字节。
DOUBLE(M,D) [UNSIGNED]: 双精度浮点数,M指定显示长度,D指定小数位数,占用8字节。
DECIMAL(M,D) [UNSIGNED]: 定点数,M指定长度,D表示小数位数。

二进制类型
BLOB: 二进制大对象,用于存储二进制数据。
BIT(M): 位类型,M指定位数,默认为1,范围为1-64

文本类型
TEXT: 大文本,不支持全文索引,不支持默认值。
CHAR(size): 固定长度字符串,最大255
VARCHAR(SIZE): 可变长度字符串,最大长度65535

时间日期类型
DATE: 日期类型,格式为yyyy-mm-dd
DATETIME: 日期时间类型,格式为yyyy-mm-dd hh:mm:ss
TIMESTAMP: 时间戳类型,从1970年开始的yyyy-mm-dd hh:mm:ss
TIME: 时间类型,格式为hh:mm:ss

String类型
ENUM类型: 枚举类型,表示一列值,每个值来自表创建时在列规定中显示的一列值。
SET类型: 集合类型,表示一列值,可以有零或多个值,值来自表创建时规定的允许的一列值。

  1. 整数类型

MySQL提供了多种整数类型,包括TINYINT、SMALLINT、INT、BIGINT等。这些类型可以是有符号的或无符号的,默认情况下是有符号的。对于存储范围更广泛的数据,可以考虑使用无符号整数类型,但需要注意越界插入的问题。

CREATE TABLE users (id INT UNSIGNED,age TINYINT
);

例子:

-- 正确的插入示例
INSERT INTO users (id, age) VALUES (1, 25);
-- 错误的插入示例(越界)
INSERT INTO users (id, age) VALUES (-1, 128);
  1. 位类型

bit[(M)] : 位字段类型。M表示每个值的位数,范围从1到64。如果M被忽略,默认为1

创建了一个名为 flags 的表,其中包含了三个名为 status 的列,分别指定了长度为 123 位的 BIT 数据类型,用于存储不同长度的比特位状态值,BIT 数据类型的最大长度为 64 位。

CREATE TABLE flags (status1 BIT(1),  -- 数字范围:0 到 1status2 BIT(2),  -- 数字范围:00 到 11status3 BIT(3)   -- 数字范围:000 到 111
);
  1. 浮点数

float[(m, d)] [unsigned] : M指定显示长度,d指定小数位数,占用空间4个字节

有符号浮点数范围
考虑一个有符号的float(6, 3)类型,它表示的范围是什么?float(6, 3)表示总共有6位数字,其中3位是小数部分。因此,剩余的3位是整数部分。对于有符号的浮点数,其中一位用于表示正负号。

因此,对于float(6, 3),可以表示的范围是从 -999.999999.999

无符号浮点数范围
如果我们将浮点数指定为无符号的,那么它的范围将从0开始。比如,对于float(6, 3) unsigned,范围将是从 0999.999

-- 创建表 tt7,其中 salary 是一个有符号的 float(6, 3) 类型的列
CREATE TABLE tt7 (id INT,salary FLOAT(6, 3)
);-- 向 tt7 表插入一条数据
INSERT INTO tt7 VALUES (1, -999.999);
-- 向 tt7 表插入一条数据
INSERT INTO tt7 VALUES (2, 999.999);
  1. char数据类型

char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255

示例:

-- 创建表 tt9,其中 name 是一个长度为 2 的固定长度字符串
CREATE TABLE tt9 (id INT,name CHAR(2)
);-- 向 tt9 表插入数据
INSERT INTO tt9 VALUES (100, 'ab');
INSERT INTO tt9 VALUES (101, '中国');-- 尝试向 char 类型的列插入超出长度的值
INSERT INTO tt9 VALUES (102, 'abc'); -- 错误:超出了指定的长度

错误示例:

-- 创建表 tt11,尝试使用超出最大长度的值
CREATE TABLE tt11 (name CHAR(256) -- 错误:超过了最大长度限制
);

char(L) 数据类型中,L 表示的是可以存储的字符长度,而不是字节长度。这一点与 C 语言中的字符长度概念略有不同C 语言中的字符长度通常是以字节为单位。因此,在使用 char 数据类型时,需要根据实际需求来确定合适的长度,并注意字符编码对存储空间的影响。

  1. varchar

varchar(L): 可变长度字符串,L表示字符长度,最大长度65535个字节

-- 创建表 tt10,其中 name 是一个可变长度字符串,最大长度为 6
CREATE TABLE tt10 (id INT,name VARCHAR(6)
);-- 向 tt10 表插入数据
INSERT INTO tt10 VALUES (100, 'hello');
INSERT INTO tt10 VALUES (101, '我爱你,中国');

注意事项

字符编码影响长度: varchar 类型的长度受字符编码影响。在 utf8 编码下,一个字符通常占用 3 个字节,而在 gbk编码下,一个字符通常占用 2 个字节。 最大长度限制: varchar 类型的最大长度为 65535个字节,但需要留出一部分字节用于记录数据大小,因此有效字节数是 65532。尝试超出最大长度限制会导致错误。

错误示例:

-- 尝试创建表时超出最大长度限制
CREATE TABLE tt11 (name VARCHAR(21845) CHARSET=utf8 -- 错误:超过了最大长度限制
);-- 尝试插入超出最大长度限制的数据
INSERT INTO tt11 VALUES ('a' REPEAT(21845)); -- 错误:超出了指定的长度
  1. char 和 varchar 比较

实际存储

char: 固定长度字符串,存储空间在创建表时分配,不受实际存储内容长度影响。
varchar:可变长度字符串,存储空间在插入数据时动态分配,根据实际存储内容长度调整。

存储空间分配:

char(4): 如果存储内容不足指定长度,会用空格填充至指定长度,因此实际占用的存储空间是固定的。
varchar(4): 根据实际存储内容长度动态分配存储空间,不会浪费空间。

假设有以下数据:

“abcd” 是 4 个字符长度
“A” 是 1 个字符长度
“Abcde” 是 5 个字符长度

在使用 char 和 varchar 存储这些数据时:

char(4) 存储方式

“abcd” 占用 4 * 3=12 个字节
“A” 占用 4 * 3=12 个字节,需要用空格填充至指定长度
“Abcde” 超过4个字符

varchar(4) 存储方式

“abcd” 占用 4 * 3+1=13 个字节(1 个字节用于记录存储内容长度)
“A” 占用 1 * 3+1=4 个字节
“Abcde” 超过4个字符

  1. 日期和时间类型

date 类型
date 类型表示日期,格式为 yyyy-mm-dd,占用三个字节。它用于存储不包含具体时间的日期信息。

datetime 类型
datetime 类型表示日期和时间,格式为 yyyy-mm-dd HH:ii:ss,范围从 1000 年到 9999 年,占用八个字节。它用于存储具体的日期和时间信息。

timestamp 类型
timestamp 类型也表示日期和时间,格式与 datetime 完全一致,但其范围从 1970 年开始,占用四个字节。它通常用于记录数据的更新时间或创建时间,在数据更新时自动更新为当前时间。

-- 创建表
CREATE TABLE birthday (t1 DATE,t2 DATETIME,t3 TIMESTAMP
);-- 插入数据
INSERT INTO birthday(t1, t2) VALUES ('1997-07-01', '2008-08-08 12:01:01');

以上插入了两种时间数据,日期和时间都被正确存储在对应的列中。此时 timestamp 列会自动填入当前时间作为默认值。

  1. Enum 和 Set 类型

Enum 类型
语法:ENUM(‘选项1’, ‘选项2’, ‘选项3’, …)
枚举类型提供了若干个选项的值,但实际上只存储其中一个值。
出于效率考虑,枚举值实际上存储的是相应选项值的数字索引,从1开始,最多65535个。

Set 类型
语法:SET(‘选项值1’, ‘选项值2’, ‘选项值3’, …)
集合类型提供了若干个选项的值,但实际上可存储其中任意多个值。
Enum 类型类似,出于效率考虑,集合值实际上存储的是相应选项值的数字索引,但索引值是通过二进制位来表示的。

CREATE TABLE votes (username VARCHAR(30),hobby SET('登山', '游泳', '篮球', '武术'),gender ENUM('男', '女')
);-- 插入数据
INSERT INTO votes VALUES ('雷锋', '登山,武术', '男');
INSERT INTO votes VALUES ('Juse', '登山,武术', '男');
INSERT INTO votes VALUES ('LiLei', '登山', '男');
INSERT INTO votes VALUES ('HanMeiMei', '游泳', '女');

相关文章:

MySQL 的基础操作

数据库的基础操作 1. 库操作2. 表的操作3. 数据类型 数据库是现代应用程序中至关重要的组成部分,通过数据库管理系统(DBMS)存储和管理数据。 1. 库操作 创建数据库 创建数据库是开始使用数据库的第一步。下面是一些常见的创建数据库的示例&a…...

【python进阶篇】面向对象编程(1)

面向对象编程——Object Oriented Programming,简称OOP,是一种程序设计思想。OOP把对象作为程序的基本单元,一个对象包含了数据和操作数据的函数。 在Python中,所有数据类型都可以视为对象,当然也可以自定义对象。自定…...

力扣面试经典150 —— 6-10题

力扣面试经典150题在 VScode 中安装 LeetCode 插件即可使用 VScode 刷题,安装 Debug LeetCode 插件可以免费 debug本文使用 python 语言解题,文中 “数组” 通常指 python 列表;文中 “指针” 通常指 python 列表索引 文章目录 6. [中等] 轮转…...

[密码学]入门篇——加密方式

一、概述 加密方法主要分为两大类: 单钥加密(private key cryptography):加密和解密过程都用同一套密码双钥加密(public key cryptography):加密和解密过程用的是两套密码 历史上&#xff0c…...

构建前后端分离项目常用的代码

构建前后端分离项目常用的代码 1.代码生成器 import com.baomidou.mybatisplus.generator.FastAutoGenerator;import com.baomidou.mybatisplus.generator.config.OutputFile;import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;​import java.util.…...

2575. 找出字符串的可整除数组(Go语言)

https://leetcode.cn/problems/find-the-divisibility-array-of-a-string/ 在看题解之前,我的代码是以下这样: package mainimport ("fmt" )func main() {fmt.Println(divisibilityArray("998244353", 3)) }func divisibilityArray…...

Redis与 Memcache区别

Redis与 Memcache区别 1 , Redis 和 Memcache 都是将数据存放在内存中,都是内存数据库。不过 Memcache 还可用于缓存 其他东西,例如图片、视频等等。 2 , Memcache 仅支持key-value结构的数据类型,Redis不仅仅支持简单的key-value类型的数据&…...

#QT(智能家居界面-界面切换)

1.IDE:QTCreator 2.实验 3.记录 (1)创建一个新界面(UI界面) (2)可以看到新加入一个ui文件,双击打开,设置窗口大小与登录界面一致 (3)加入几个PUS…...

js拓展-内置对象

目录 1. 数组对象 1.1 数组的四种方式 1.2 JS中数组的特点 1.3 常用方法 2. 日期对象 2.1 日期对象的创建 2.2 日期对象的方法 2.3 案例:输出现在的时间 3. 全局对象 3.1 字符串转换成数字类型 3.2 编码解码函数 1. 数组对象 注:数组在JS中是一…...

【李沐精读系列】GPT、GPT-2和GPT-3论文精读

论文: GPT:Improving Language Understanding by Generative Pre-Training GTP-2:Language Models are Unsupervised Multitask Learners GPT-3:Language Models are Few-Shot Learners 参考:GPT、GPT-2、GPT-3论文精读…...

Libevent的使用及reactor模型

Libevent 是一个用C语言编写的、轻量级的开源高性能事件通知库,主要有以下几个亮点:事件驱动( event-driven),高性能;轻量级,专注于网络,不如 ACE 那么臃肿庞大;源代码相当精炼、易读…...

查看Linux服务器配置

# chkconfig --list # 列出所有系统服务 # chkconfig --list | grep on # 列出所有启动的系统服务 # ifconfig # 查看所有网络接口的属性 # iptables -L # 查看防火墙设置 # route -n # 查看路由表 # netstat -lntp # 查看所有监听端口 # netstat -antp # 查看所有已经建立的连…...

【机器学习】包裹式特征选择之递归特征添加法

🎈个人主页:豌豆射手^ 🎉欢迎 👍点赞✍评论⭐收藏 🤗收录专栏:机器学习 🤝希望本文对您有所裨益,如有不足之处,欢迎在评论区提出指正,让我们共同学习、交流进…...

解决cs不能生成Linux木马的问题

要解决的问题:众所周知,msf上面的shell或者是其他的shell想反弹给cs默认情况下是只支持windows的,因为cs的监听模块默认没有linux的,但是有些主机就是用linux搭建的,这可怎么办呢。就要用到一个插件CrossC2。 下载插件…...

vue3组件通信方式

不管是vue2还是vue3,组件通信方式很重要,不管是项目还是面试都是经常用到的知识点。 vue2组件通信方式 props:可以实现父子组件、子父组件、甚至兄弟组件通信 自定义事件:可以实现子父组件通信 全局事件总线$bus:可以实现任意组件通信 pubsub:发布订阅模式实现任意组件通信…...

前端实现生成图片并批量下载,下载成果物是zip包

简介 项目上有个需求,需要根据表单填写一些信息,来生成定制的二维码图片,并且支持批量下载二维码图片。 之前的实现方式是直接后端生成二维码图片,点击下载时后端直接返回一个zip包即可。但是项目经理说后端实现方式每次改个东西…...

android 快速实现 圆角矩形控件 及 圆形控件

1.自定义RoundImageView package com.examle.widget;import android.content.Context; import android.content.res.TypedArray; import android.graphics.Bitmap; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import an…...

【Python】外网远程登录访问jupyter notebook+pycharm使用ipython

第一步:创建python虚拟环境 conda create -n py3610 python3.6.10第二步:安装ipython pip install ipython pip install ipython notebook第三步:创建 IPython Notebook 服务器配置文件 # 进入python交互shell,设置密码 >&…...

error:0308010C:digital envelope routines::unsupported

error:0308010C:digital envelope routines::unsupported 报错原因解决方案方案一:降低node版本在17以下指定node版本 mac node版本降级 mac切换node版本 方案二:启用legacy OpenSSL provider方案三:配置package.json文件拓展:pac…...

Vue前端的工作需求

加油&#xff0c;新时代打工人&#xff01; 需求&#xff1a; 实现带树形结构的表格&#xff0c;父数据显示新增下级&#xff0c;和父子都显示编辑。 技术&#xff1a; Vue3 Element Plus <template><div><el-table:data"tableData"style"width…...

华硕Z10PA-D8主板+E5-2696V4实战:手把手教你用IPMI远程安装ESXi 8.0(附BIOS设置避坑指南)

华硕Z10PA-D8主板与E5-2696V4实战&#xff1a;IPMI远程部署ESXi 8.0全流程解析 当企业级硬件遇上最新虚拟化平台&#xff0c;总有些隐藏的默契等待发掘。华硕Z10PA-D8这款基于C612芯片组的双路主板&#xff0c;搭配英特尔至强E5-2696V4处理器&#xff0c;至今仍在许多数据中心和…...

SAP MIRO批量发票校验后,应付科目行项目金额怎么按暂估比例拆分?一个FMRESERV增强实例

SAP MIRO批量发票校验中应付科目行项目金额的智能拆分方案 每到月末关账时&#xff0c;财务部门的王经理总要面对堆积如山的采购发票。这些通过MIRO批量处理的发票中&#xff0c;经常出现暂估科目与应付科目金额不匹配的情况。最让他头疼的是&#xff0c;系统默认生成的会计凭证…...

嵌入式C代码如何喂饱轻量级大模型?:揭秘ARM Cortex-M7上LLM推理延迟从2800ms压至197ms的7个关键编译器指令级优化

第一章&#xff1a;嵌入式C语言与轻量级大模型适配性能调优指南在资源受限的嵌入式设备&#xff08;如 Cortex-M7、ESP32-S3 或 RISC-V MCU&#xff09;上部署轻量级大模型&#xff08;如 TinyLlama、Phi-3-mini、TinyBERT&#xff09;时&#xff0c;C语言仍是底层推理引擎的核…...

6本必读集成学习书籍:从理论到实战全解析

1. 集成学习入门&#xff1a;为什么这6本书值得放在你的书架上&#xff1f;集成学习作为机器学习领域的重要分支&#xff0c;已经彻底改变了我们构建预测模型的方式。记得我第一次在Kaggle比赛中尝试使用随机森林时&#xff0c;那种"原来预测可以这么准"的震撼感至今…...

10N80-ASEMI大功率场景的能效王者10N80

编辑&#xff1a;ll10N80-ASEMI大功率场景的能效王者10N80型号&#xff1a;10N80沟道&#xff1a;NPN品牌&#xff1a;ASEMI封装&#xff1a;TO-220F批号&#xff1a;最新导通内阻&#xff1a;0.9Ω漏源电流&#xff1a;10A漏源电压&#xff1a;800V引脚数量&#xff1a;3特性&…...

从动态规划到DTW:一个Python可视化教程,带你亲手画出时间规整路径图

从动态规划到DTW&#xff1a;一个Python可视化教程&#xff0c;带你亲手画出时间规整路径图 在信号处理和机器学习领域&#xff0c;时间序列的相似性比较是一个基础但极具挑战性的问题。想象一下&#xff0c;当你需要比较两段语音、心电图或股票走势时&#xff0c;简单的逐点对…...

CKEditor如何实现Word图片自动转存并保留原始分辨率?

Word图片转存功能开发全记录 技术选型与架构设计 作为项目技术负责人&#xff0c;针对政府文档系统的特殊需求&#xff0c;设计以下技术方案&#xff1a; #mermaid-svg-1ckRoBKZywqZgpdw{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill…...

SQL如何实现按自定义排序进行分组汇总_ORDERBY与聚合函数

GROUP BY 结果顺序未定义&#xff0c;ORDER BY 仅排序最终结果&#xff1b;需用 CASE WHEN 或 FIELD() 构造有序分组键&#xff0c;再 GROUP BY 该键与原始字段&#xff0c;最后 ORDER BY 控制输出。ORDER BY 不能直接用在 GROUP BY 后做自定义排序分组汇总SQL 标准里&#xff…...

告别Keil,用STVP给STM32烧录程序,保姆级图文教程(附常见错误排查)

STVP实战指南&#xff1a;脱离IDE高效烧录STM32的完整解决方案 为什么选择STVP作为你的独立烧录工具&#xff1f; 在嵌入式开发领域&#xff0c;Keil和IAR这类集成开发环境&#xff08;IDE&#xff09;确实提供了便捷的一站式解决方案。但当我们需要进行批量生产烧录、现场固件…...

CSS如何处理SSR中CSS引入_在服务端渲染时提取关键CSS

服务端渲染时import的CSS未内联&#xff0c;因Webpack/Vite默认不提取&#xff1b;需用mini-css-extract-plugin&#xff08;Webpack&#xff09;或vite-plugin-css-injected-by-js&#xff08;Vite&#xff09;配合服务端收集并注入CSS字符串到HTML的<head>中。服务端渲…...