MySQL之对数据库和表的操作

news2025/1/16 16:59:28

目录

一、创建数据库

二、字符集和校验规则

1、查看系统默认字符集

2、查看系统默认的校验规则

3、查看数据库支持的字符集

4、查看数据库支持的字符集校验规则

5、校验规则对数据库的影响

三、操作数据库

1、查看数据库

2、查看创建语句

​编辑

 3、修改数据库

4、数据库的删除

5、备份和恢复

数据库的备份和恢复

某个数据库中某张表的备份

同时备份多个数据库

6、查看目前所在数据库

7、查看数据库连接情况

四、对表的操作

1、创建表

2、查看表结构

3、修改表

4、删除表


一、创建数据库

语法:

CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [, create_specification] ...]
create_specification:
[DEFAULT] CHARACTER SET charset_name
[DEFAULT] COLLATE collation_name

说明:

1、大写的表示关键字。
2、[]是可选项。if not exists 表示如果数据库不存在就创建,如果存在,就不做任何事。
3、CHARACTER SET:指定数据库采用的字符集。
4、COLLATE:指定数据库字符集的校验规则。

演示:

创建数据库时,也可以开始就设置好数据库的字符集和校验规则。

create database db3 charset=utf8 collate utf8_general_ci;

二、字符集和校验规则

什么是字符集和校验规则?

创建数据库的时候,一般有两个编码集:

数据库编码集:数据库未来存储数据的编码方式。

数据库校验集:支持数据库进行字段比较使用的编码,本质也是一种读取数据库中数据采用的编码格式。

数据库无论对数据做任何操作,都必须保证操作和编码必须是编码一致的。存数据的时候用什么编码,取的时候就得用什么对应的编码去取。比如说,一本书是用中文写的,那么就必须要让会中文的人来读才能够读懂内容。

1、查看系统默认字符集

show variables like 'character_set_database';

2、查看系统默认的校验规则

show variables like 'collation_database';

 

3、查看数据库支持的字符集

字符集主要是控制用什么语言。比如utf8就可以使用中文。

show charset;

 

4、查看数据库支持的字符集校验规则

show collation;

 

5、校验规则对数据库的影响

~ 创建一个数据库,校验规则使用utf8_ general_ ci。

create database if not exists test1 collate utf8_general_ci;

然后我们查看一下其校验规则: 

接着在test1数据库中创建一张表:

create table person(name varchar(20));

 再插入一些数据,之后查看插入的结果:

使用下面的语句进行查询:

select * from person where name='a';

~ 创建一个数据库,校验规则使用utf8_ bin:

create database if not exists test2 collate utf8_bin;

使用下面的语句进行查询:

select * from person where name='a';

 从上面的结果中,我们可以发现,在select查询中,utf8_ general_ ci是不会区分大小写的,而utf8_ bin是会区分大小写的。

再来看看下面test2(使用utf8_ bin校验规则)数据库中的我们根据name的排序结果:因为其区分大小写且小写字母的ascii码大于大写字母,所以会得到下面的结果。

select * from person order by name;

再来看看下面test1(使用utf8_ general_ ci校验规则)数据库中的我们根据name的排序结果:

因为utf8_ general_ ci不会区分大小写,所以a和A就相当于同一个字符,会被放在一起。

三、操作数据库

1、查看数据库

show databases;

作用:可以查看当前MySQL客户端下已经存在的所有数据库。

2、查看创建语句

show create database test1;

 3、修改数据库

一般来说,我们对数据库的修改主要是修改数据库的字符集和校验规则。

用法:

ALTER DATABASE db_name
[alter_spacification] ,[alter_spacification]...

alter_spacification:
	[DEFAULT] CHARACTER SET charset_name
	[DEFAULT] COLLATE collation_name

4、数据库的删除

用法:

DROP DATABASE [IF EXISTS] db_name;

演示: 

注:对应的数据库文件夹被删除,里面的数据表全部被删。特别注意的是,除非特殊情况,不要随意删除数据库。

5、备份和恢复

数据库的备份和恢复

备份,语法:在Linux命令行下执行

mysqldump -P 端口号 -u root -p 密码 -B 数据库名 > 数据库备份存储的文件路径

恢复,语法:在登陆mysql客户端,执行下面语句:

source 备份文件所在路径;

先删除test2数据库:

然后从备份恢复数据库: 

 

某个数据库中某张表的备份

如果备份的不是整个数据库,而是其中的一张表:

mysqldump -u root -p 数据库名 表名1 表名2 > 数据库被备份后所在路径

同时备份多个数据库

mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径

注:如果备份一个数据库时,没有带上-B参数, 在恢复数据库时,需要先创建一个数据库,然后使用数据库,再使用source来还原。

6、查看目前所在数据库

我们可以使用下面的语句查看目前所在的数据库。

select database();

7、查看数据库连接情况

show processlist;

使用该语句可以查看当前有多少个客户端连接这个服务器。

四、对表的操作

1、创建表

语法:

CREATE TABLE table_name (
field1 datatype,
field2 datatype,
field3 datatype
) character set 字符集 collate 校验规则 engine 存储引擎;

说明:

field:表示列名。

datatype:表示列的类型。

character set 字符集:如果没有指定字符集,则以所在数据库的默认字符集为准。

collate 校验规则:如果没有指定校验规则,则以所在数据库的默认校验规则为准。

engine 存储引擎:指定存储引擎,如果没有指定存储引擎,则使用默认存储引擎。

2、查看表结构

语法:

desc 表名;

 

说明:

field:字段名字        type:字段类型        Null:是否允许为空        key:索引类型

default:默认值        extra:扩充

3、修改表

先在上面的users表中插入一些数据:

添加字段:

ALTER TABLE tablename ADD (column datatype [DEFAULT expr][,column datatype]...);

在users表中添加一个字段,用于保存用户的生日。 

修改字段:

ALTER TABLE tablename MODIfy (column datatype [DEFAULT expr][,column datatype]...);

 删除字段:

ALTER TABLE tablename DROP (column);

注:删除字段一定要小心,删除字段及其对应的列数据都没了。

修改表名

alter table 原表名 rename to 新表名

修改字段名

alter table 表名 change 原列名称 新列名称
——新字段需要完整定义

4、删除表

DROP [TEMPORARY] TABLE [IF EXISTS] tbl_name [, tbl_name] ...

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

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

相关文章

从键入网址到显示页面全流程(超详细版)

网络 👨‍🏫 小林coding 键入网址到网页显示,期间发生了什么 HTTP【端口:80】 解析URL 协议Web服务器地址目录 文件名 生成请求报文 请求行 请求方法(get、post …)请求路径协议的版本(HTTP/1…

品读 Java 经典巨著《Effective Java》90条编程法则,第4条:通过私有构造器强化不可实例化的能力

文章目录 【前言】欢迎订阅【品读《Effective Java》】系列专栏java.lang.Math 类的设计经验总结 【前言】欢迎订阅【品读《Effective Java》】系列专栏 《Effective Java》是 Java 开发领域的经典著作,作者 Joshua Bloch 以丰富的经验和深入的知识,全面…

主数据管理系统:KPaaS 集成平台助力企业数据治理

在数字化转型的浪潮中,企业面临着日益复杂的信息技术环境。多系统并存、数据分散的现象普遍存在,这对企业的数据管理和业务协同提出了严峻挑战。主数据管理(Master Data Management, MDM)作为确保企业核心业务数据准确、一致、完整…

Vite - public目录的图片也会被处理?(public目录的特点)

目录 1,问题描述2,解决3,问题分析3.1,public 目录特点3.2,原因 1,问题描述 复现步骤: 项目为 vite5.0.8 创建的 Vue3 TS 项目。 将图片(10kb)放到了 public 目录下&a…

设计表时的三大范式(MySQL)

设计表时的三大范式 什么是范式第一范式第二范式不满足第二范式的缺点数据冗余插入异常更新异常删除异常 第三范式 什么是范式 在表的设计中,范式是一种设计规范,用于更好的组织和管理数据。 设计数据表时的范式有第一范式1NF、第二范式2NF、第三范式3…

linux-L8.linux更改文件的拥有者

L8.更改文件的拥有者 Chown root 123.txt xxx_你的用户名_xxxlinux 查看文件的所有者 在Linux中,可以使用ls命令的-l选项来查看文件的详细信息,包括文件的所有者。如下: ls -l

【828华为云征文|轻松搭建蝌蚪聊天室:华为云Flexus X实例实战教程】

文章目录 华为云Flexus X实例概述部署【蝌蚪聊天室】项目准备工作具体操作指南服务器相关环境确认用git拉取项目安装相关依赖运行项目查看效果 总结 华为云Flexus X实例概述 华为云Flexus云服务是一款专为中小企业和开发者设计的高级云产品,提供即开即用的体验&…

动手学习RAG: moka-ai/m3e 模型微调deepspeed与对比学习

动手学习RAG: 向量模型动手学习RAG:迟交互模型colbert微调实践 bge-m3 1. 环境准备 pip install open-retrievals2. 使用M3E模型 from retrievals import AutoModelForEmbeddingembedder AutoModelForEmbedding.from_pretrained(moka-ai/m3e-base, pooling_meth…

【Windows】获取进程缓解策略设置情况

目录 一、前言 二、主要概念 三、实现步骤 四、总结 原文出处链接:[https://blog.csdn.net/qq_59075481/article/details/142234952] 一、前言 在现代操作系统中,进程缓解策略(Process Mitigation Policy)提供了一种防御机制…

谷歌创始人谢尔盖·布林回归一线:承认错失先机,每天都在写代码

在科技界,有些名字永远闪耀着创新的光芒,谢尔盖布林就是其中之一。作为谷歌的联合创始人,布林在经历了一段时间的隐退后,宣布重返一线,投身于人工智能(AI)技术的研发。本周,在洛杉矶…

F12抓包10:UI自动化 - Elements(元素)定位页面元素

​课程大纲 1、前端基础 1.1 元素 元素是构成HTML文档的基本组成部分之一,定义了文档的结构和内容,比如段落、标题、链接等。 元素大致分为3种:基本结构、自闭合元素(self-closing element)、嵌套元素。 1、基本结构&…

Docker 常用命令(未完待续...)

Docker 常用命令(未完待续...) 命令的完整名称和别名帮助登录和搜索命令 (Login and Search Commands)其他管理命令 (Other Management Commands)镜像命令 (Image Commands)容器命令 (Container Commands)docker run 从镜像创建并运行一个新的容器docker…

Midjourney中秋特典-12张图附魔咒

第一张 魔咒 A Mid-Autumn Festival poster, a round bright moon, a Chinese-style pavilion with a scene of a reunion from Dream of the Red Chamber, a new Chinese style --ar 3:4 --v 6.1第二张 魔咒 The bright full moon hung in the night sky,clear in outline a…

【疑难杂症2024-005】docker-compose中设置容器的ip为固定ip后,服务无法启动

本文由Markdown语法编辑器编辑完成。 1.背景: 我们的产品是通过docker image的方式发布,并且编排在docker-compose.yml中发布。在同一个docker-compose.yml中的服务,相互之间,可以通过对方的服务名和端口,来直接访问…

动态规划算法---04.斐波那契数列模型_解码方法_C++

题目链接:91. 解码方法 - 力扣(LeetCode)https://leetcode.cn/problems/decode-ways/description/ 一、题目解析 题目: 题目大意:从题目中我们可以知道,解码就是在字符串s中由‘1’到‘26’的字符可以转化…

echarts饼图让部分数据显示在图外,部分显示在图内

echarts饼图让部分数据显示在图外,部分显示在图内 var dataList [{ value: 10, name: 商户 },{ value: 20, name: 充电桩 },{ value: 30, name: 业主 } ] option {series: [{type: pie,radius: 70%,data: dataList,labelLine: {show: true,position: outside,len…

JavaSE:4、流程控制

1、代码块与作用域 变量的使用范围,仅限于其定义时所处的代码块,也就是他的作用域。 目前所说的变量均为局部变量 public class Main {public static void main(String [] argv){int a10;{int b10;System.out.println(a);System.out.println(b);}Sys…

计算机网络八股总结

这里写目录标题 网络模型划分(五层和七层)及每一层的功能五层网络模型七层网络模型(OSI模型) 三次握手和四次挥手具体过程及原因三次握手四次挥手 TCP/IP协议组成UDP协议与TCP/IP协议的区别Http协议相关知识网络地址,子…

前端——标签二(超链接)

标签二 超链接标签:a 超链接,实现页面间的跳转和数据传输 a标签的属性 href:跳转路径(url)必须具备,表示点击后会跳转到哪个页面 target:页面打开方式。默认是 _self 如果是 _blank则用新的…

[基于 Vue CLI 5 + Vue 3 + Ant Design Vue 4 搭建项目] 02 配置 nodejs 淘宝镜像仓库

文章目录 为什么要配置淘宝镜像仓库呢如何查看镜像仓库如何配置镜像仓库 为什么要配置淘宝镜像仓库呢 主要是因为默认的镜像仓库是国外的,当我们使用 npm 安装依赖的时候会很慢或者失败,我们配置国内的镜像仓库这样就可以加速我们安装镜像的过程&#x…