MySQL 的基础操作

news2024/10/1 5:27:41

数据库的基础操作

  • 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 到 1
    status2 BIT(2),  -- 数字范围:00 到 11
    status3 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', '游泳', '女');

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

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

相关文章

为什么在镀膜时要测薄膜折射率?

在芯片制造中,镀膜工序(PVD,CVD)是必不可少的关键环节,薄膜的质量直接影响了芯片的性能。对这些薄膜的精细控制又离不开对其折射率的深入理解和精确测量。今天将对芯片制造中薄膜折射率的概念、测量方法,以及它在整个制…

Unmanaged PowerShell

简介 在渗透测试当中经常会使用到PowerShell来执行脚本, 但是直接使用PowerShell.exe是一个非常敏感的行为, EDR等产品对PowerShell.exe进程的创建监控的很密切, 并且随着PowerShell的渗透测试工具的普及, 越来越多的EDR会利用微软提供的AMSI接口对PS脚本进行扫描, 但是对于低…

力扣最热100题——56.合并区间

吾日三省吾身 还记得梦想吗 正在努力实现它吗 可以坚持下去吗 目录 吾日三省吾身 力扣题号:56. 合并区间 - 力扣(LeetCode) 题目描述 Java解法一:排序然后原地操作 具体代码如下 Java解法二:new一个list&#xf…

Pytorch学习 day04(Totensor、Normalize、Resize、Compose)

Totensor 把一个PIL格式的图片,或者ndarray格式的图片转换为tensor格式使用方法,如下: from PIL import Image from torchvision import transforms from torch.utils.tensorboard import SummaryWriterimg Image.open("images/00130…

算法——滑动窗口之找到字符串中所有的字母异位词,串联所有单词的子串

6.找到字符串中所有的字母异位词 题目:. - 力扣(LeetCode) 6.1如何快速判断两个字符串是否是异位词 假设现在有s1 aabca,s2 abaca,那么这两个就是异位词,容易想到的判断方法就是将两个字符串按照字典序排序,再依次比较,但是时间复杂度很高;我们看看…

python并发编程:IO模型比较分析

blocking和non-blocking的区别在哪,synchronous IO和asynchronous IO的区别在哪。 blocking vs non-blocking:调用blocking IO会一直block住对应的进程直到操作完成,而non-blocking IO在kernel还准备数据的情况下会立刻返回。 synchronous …

【R语言爬虫实战】抓取省市级城市常务会议内容

🍉CSDN小墨&晓末:https://blog.csdn.net/jd1813346972 个人介绍: 研一|统计学|干货分享          擅长Python、Matlab、R等主流编程软件          累计十余项国家级比赛奖项,参与研究经费10w、40w级横向 文…

mysql如何开启手动提交事务

在mysql中,有一个变量autocommit,表示自动提交,默认为1,表示开启自动提交。通过以下命令查询 select autocommit;当autocommit为1时,任何一条sql语句都是一个事务,执行完由mysql自动提交。如果想自己决定什…

OS-Copilot:实现具有自我完善能力的通用计算机智能体

🍉 CSDN 叶庭云:https://yetingyun.blog.csdn.net/ AI 缩小了人类间的知识和技术差距 论文标题:OS-Copilot: Towards Generalist Computer Agents with Self-Improvement 论文链接:https://arxiv.org/abs/2402.07456 项目主页&a…

32单片机基础:输入捕获测频率

接线图如下图所示: 我们复制之前写过的代码6-3 PWM驱动LED呼吸灯 在PWM模块中,执行的逻辑是,初始化TIM2的通道1,产生一个PWM波形,输出引脚是PA0,通过SetCompare1的函数,可以调节CCR1寄存器的值…

Memcached的重要性,如果防范Memcached DDOS攻击

一、Memcached简要 Memcached是一个开源的、高性能的、分布式内存对象缓存系统。它的主要目的是通过降低对数据库的访问来加速动态Web应用程序。 Memcached的用途非常广泛,它主要用于动态Web应用以减轻数据库负载。通过在内存中缓存数据和对象,Memcach…

pytorch_神经网络构建6

文章目录 强化学习概念实现qLearning基于这个思路,那么解决这个问题的代码如下 强化学习概念 强化学习有一个非常直观的表现,就是从出发点到目标之间存在着一个连续的状态转换,比如说从状态一到状态456,而每一个状态都有多种的行为&#xff…

2024/3/10 P1601高精加法

起因是本人在一个为数不多空闲的下午刷题ing&#xff0c;看到了AB problem。“就这&#xff1f;”从而忽略了高精这俩字&#xff0c;然后喜提40分。 于是开始研究何为高精。 #include<iostream> #include<string.h> #include<cstring>using namespace std; c…

数据结构与算法:链式二叉树

上一篇文章我们结束了二叉树的顺序存储&#xff0c;本届内容我们来到二叉树的链式存储&#xff01; 链式二叉树 1.链式二叉树的遍历1.1二叉树的前序&#xff0c;中序&#xff0c;后序遍历1.2 三种遍历方法代码实现 2. 获取相关个数2.1获取节点个数2.2获取叶节点个数2.3 获取树的…

代码随想录算法训练营第day14|二叉树理论基础、二叉树递归遍历、二叉树迭代遍历

目录 a.二叉树理论基础 b.二叉树递归遍历 c.二叉树迭代遍历 迭代法前序遍历 迭代法中序遍历 # 迭代法后序遍历 a.二叉树理论基础 在我们解题过程中二叉树有两种主要的形式&#xff1a;满二叉树和完全二叉树 满二叉树&#xff1a;如果一棵二叉树只有度为0的结点和度为2的…

Mysql 死锁案例1-记录锁读写冲突

死锁复现 CREATE TABLE t (id int(11) NOT NULL,c int(11) DEFAULT NULL,d int(11) DEFAULT NULL,PRIMARY KEY (id),KEY c (c) ) ENGINEInnoDB DEFAULT CHARSETutf8;/*Data for the table t */insert into t(id,c,d) values (0,0,0),(5,5,5),(10,10,10) 事务1事务2T1 START…

Java学习笔记------拼图游戏

图形化界面GUI GUI&#xff1a;Graphical User Interface&#xff08;图像用户接口&#xff09;&#xff0c;指采用图形化的方式显示操作界面 两套体系&#xff1a;AWT包中和Swing包中 组件 JFrame&#xff1a;最外层的窗体 JMenuBar&#xff1a;最上层菜单 JLaber&#…

【软考】图的遍历

目录 1. 概念2. 深度优先搜索2.1 说明2.2 步骤 3. 深度优先搜索例子3.1 无向图3.2 代码示例3.3 结果示例3.4 过程 4. 广度优先搜索4.1 说明4.2 步骤 5. 广度优先搜索例子5.1 无向图5.2 代码示例5.3 结果示例5.4 过程5.5 例题5.5.1 题目1 1. 概念 1.图的遍历是指从某个顶点出发…

递增三元组 刷题笔记

题意为 若存在 a中的数小于b中的数&#xff0c;b中的数小于c中的数 则该数算一种方案 思路 暴力模拟优化 两层循环遍历即可 从b到c的过程我们发现 第三层并不需要循环 直接加上 大于b的数量即可 那么第一层和第三层是对称的 我们有没有可能再去掉一层循环 只做一次遍历 …

Spring boot2.7整合jetcache 本地linkedhashmap缓存方案

好 上文 Spring boot2.7整合jetcache 远程redis缓存方案 我们讲完了 远程实现方案 本文 我们来说说 本地 jetcache解决方案 首先是 application.yml 在jetcache下加上 local:default:type: linkedhashmapkeyConvertor: fastjson我们技术用的 本地缓存 linkedhashmap 这里 我们…