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', '游泳', '女');

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python从0到100(三):Python中的变量介绍

前言: 零基础学Python:Python从0到100最新最全教程。 想做这件事情很久了,这次我更新了自己所写过的所有博客,汇集成了Python从0到100,共一百节课,帮助大家一个月时间里从零基础到学习Python基础语法、Pyth…

Day6 java 常用API

文章目录 1、Calendar1.1 Calendar日历对象 2、JDK8 之后新增的时间类2.1 LocalDate、LocalTime 、LocalDateTime2.2 ZoneId 、ZoneIdTime2.3 Instant2.4 DateTimeFormatter2.5 Period2.6 Duration 1、Calendar 在了解calendar之前,先用SimpleDateFormat 写一个小例…

Linux快速入门学习-2 Linux安装环境准备

文章目录 Linux发展前景及就业形势Windows操作系统简介硬盘分区简介Linux安装环境准备Linux系统安装图解 Linux发展前景及就业形势 权威部门统计,未来几年内我国软件行业的从业机会十分庞大,中国每年对IT软件人才的需求将达到200万人左右。而对于Linux专…

Docker进阶:深入理解 Dockerfile

Docker进阶:深入理解 Dockerfile 一、Dockerfile 概述二、为什么要学习Dockerfile三、Dockerfile 编写规则四、Dockerfile 中常用的指令1、FROM2、LABEL3、RUN4、CMD5、ENTRYPOINT6、COPY7、ADD8、WORKDIR9、 ENV10、EXPOSE11、VOLUME12、USER13、注释14、ONBUILD 命…

Java面试题之JVM

JVM整体架构 堆 minor gc:回收年轻代的垃圾对象 full GC:回收整个堆的垃圾对象 当full GC也回收不了就会OOM STW运行时会停掉所有用户线程 JVM调优的真正目的就是为了减少STW的次数 为什么会有STW:避免非垃圾对象发生变化,暂…

【深度学习笔记】优化算法——Adam算法

Adam算法 🏷sec_adam 本章我们已经学习了许多有效优化的技术。 在本节讨论之前,我们先详细回顾一下这些技术: 在 :numref:sec_sgd中,我们学习了:随机梯度下降在解决优化问题时比梯度下降更有效。在 :numref:sec_min…

Linux-socket套接字

前言 在当今数字化时代,网络通信作为连接世界的桥梁,成为计算机科学领域中至关重要的一部分。理解网络编程是每一位程序员必备的技能之一,而掌握套接字编程则是深入了解网络通信的关键。本博客将深入讨论套接字编程中的基本概念、常见API以及…

GitOps实践之Argo CD (2)

argocd 【-1】argocd可以解决什么问题? helm 部署是手动的?依赖流水线。而有时候仅仅更新一个小东西,流水线跑好久,CD真的不应该和CI耦合。不同环境的helm配置不同,手动修改问题多,可以用git管理起来,例如分不同环境用目录区分。argocd创建应用可以不通环境部署到不同集…

Langchain-Chatchat本地搭建ChatGLM3模型和提取PDF内容

文章目录 1、软件要求2、安装CUDA2.1、安装gcc2.2、安装CUDA 3、安装Anaconda33.1、下载Anaconda33.2、创建python虚拟环境 4、部署系统4.1、下载源码4.2、安装依赖4.3、下载模型4.4、初始化配置和知识库4.4.1、初始化配置4.4.2、初始化知识库 4.5、运行4.6、运行4.6.1、启动4.…

C语言编译成库文件的要求

keil编译成库文件 在Keil中,将C语言源文件编译成库文件通常需要进行以下步骤: 创建一个新的Keil项目,并将所需的C语言源文件添加到该项目中。 在项目设置中配置编译选项,确保生成的目标文件符合库文件的标准格式。 编译项目&…

基于PHP的餐厅管理系统APP设计与实现

目 录 摘 要 I Abstract II 引 言 1 1 相关技术 3 1.1 MVC 3 1.2 ThinkPHP 3 1.3 MySQL数据库 3 1.4 uni-app 4 1.5 本章小结 4 2 系统分析 5 2.1 功能需求 5 2.2 用例分析 7 2.3 非功能需求 8 2.4 本章小结 8 3 系统设计 9 3.1 系统总体设计 9 3.2 系统详细设计 10 3.3 本章小…

基于Java+springboot+VUE+redis实现的前后端分类版网上商城项目

基于Java springbootVUEredis实现的前后端分类版网上商城项目 博主介绍:多年java开发经验,专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 央顺技术团队 Java毕设项目精品实战案例《1000套》 欢迎点赞 收藏 ⭐留言…

Ajax、Axios、Vue、Element与其案例

目录 一.Ajax 二.Axios 三.Vue 四.Element 五.增删改查案例 一.依赖:数据库,mybatis,servlet,json-对象转换器 二.资源:elementvueaxios 三.pojo 四.mapper.xml与mapper接口 五.service 六.servlet 七.html页…

css flex 布局换行

默认使用display: flex;是不换行的,只需要加上flex-wrap: wrap;就行了,效果图 .app-center {display: flex;flex-wrap: wrap;justify-content:flex-start; } 通过上面我们发现虽然时间换行了,但是每行的边距不一样 加上这个就行了&#xff…

微信小程序-分包

分包 1.什么是分包 分包指的是把一个完整的小程序项目,按照需求划分为不同的子包,在构建时打包成不同的分包,用户在使用时按需进行加载。 2.分包的好处 对小程序进行分包的好处主要有以下两点: 可以优化小程序首次启动的下载时间…

二维码图案样式怎么改?二维码改样式的简单方法

怎么修改二维码图案的样式呢?一般情况下生成的二维码图案大多是黑白的普通样式,那么很多人会为了提高展现效果或者增加辨识度,需要修改二维码的图案样式、添加logo、文字等其他内容,那么面对这样的需求该如何解决呢?下…

docker学习(十四)docker搭建私服

docker私服搭建,配置域名访问,设置访问密码 启动registry docker run -d \-p 5000:5000 \-v /opt/data/registry:/var/lib/registry \registrydocker pull hello-world docker tag hello-world 127.0.0.1:5000/hello-world docker push 127.0.0.1:5000…

SQL中如何添加数据

SQL中如何添加数据 一、SQL中如何添加数据(方法汇总)二、SQL中如何添加数据(方法详细解说)1. 使用SQL脚本(推荐)1.1 在表中插入1.1.1 **第一种形式**1.1.2 **第二种形式**SQL INSERT INTO 语法示例SQL INSE…

Keepalived+LVS构建高可用集群

目录 一、Keepalive基础介绍 1. Keepalive与VRRP 2. VRRP相关技术 3. 工作原理 4. 模块 5. 架构 6. 安装 7. Keepalived 相关文件 7.1 配置组成 7.2 全局配置 7.3 VRRP实例配置(lvs调度器) 7.4 虚拟服务器与真实服务器配置 二、Keepalived…

IDEA管理Git + Gitee 常用操作

文章目录 IDEA管理Git Gitee 常用操作1.Gitee创建代码仓库1.创建仓库1.点击新建仓库2.完成仓库信息填写3.创建成功4.管理菜单可以修改这个项目的设置 2.设置SSH公钥免密登录基本介绍1.找到.ssh目录2.执行指令 ssh-keygen3.将公钥信息添加到码云账户1.点击设置2.ssh公钥3.复制.…