【重学 MySQL】四十五、数据库的创建、修改与删除

【重学 MySQL】四十五、数据库的创建、修改与删除

  • 一条数据存储的过程
    • 数据输入
    • 数据验证
    • 数据处理
    • 数据存储
    • 数据持久化
    • 反馈与日志
    • 注意事项
  • 标识符命名规则
    • 基本规则
    • 长度限制
    • 保留字与特殊字符
    • 命名建议
    • 示例
  • MySQL 中的数据类型
  • 创建数据库
    • 创建数据库时指定字符集和排序规则
  • 查看数据库
  • 修改数据库
    • 修改数据库的字符集和排序规则
  • 删除数据库
  • 注意事项
  • 总结

在这里插入图片描述
在 MySQL 中,数据库(也称为 schema)是用于存储和组织数据的一种逻辑结构。数据库的创建、修改和删除是数据库管理的基本操作。

一条数据存储的过程

在数据库系统中,一条数据存储的过程通常涉及多个步骤,从数据的输入到其在数据库中的持久化存储。

数据输入

首先,用户或应用程序需要将数据输入到系统中。这可以通过多种方式实现,例如:

  • 用户界面(UI):用户通过图形界面(如网页表单、桌面应用程序窗口等)输入数据。
  • 应用程序接口(API):外部应用程序通过调用API将数据发送到数据库系统。
  • 批量导入:使用文件(如CSV、Excel等)批量导入数据。

数据验证

在数据被存储之前,通常需要进行验证以确保其准确性和完整性。这包括:

  • 数据类型检查:确保数据符合预期的格式和类型(如字符串、数字、日期等)。
  • 约束检查:验证数据是否满足数据库表定义的约束条件(如主键唯一性、外键关联、非空约束等)。
  • 业务逻辑验证:根据应用程序的业务逻辑检查数据的有效性(如年龄必须在0到120岁之间)。

数据处理

如果数据通过了验证,接下来可能需要进行一些处理,例如:

  • 数据转换:将数据转换为适合存储的格式(如日期格式转换、数据编码转换等)。
  • 数据清洗:去除或纠正数据中的错误、重复或不一致。
  • 数据标准化:将数据转换为统一的标准格式。

数据存储

处理后的数据将被存储到数据库中。这通常涉及以下步骤:

  • 数据库连接:建立与数据库的连接(如使用数据库驱动程序或ORM框架)。
  • SQL语句生成:根据要存储的数据生成相应的SQL语句(如INSERT、UPDATE等)。
  • 执行SQL语句:将SQL语句发送到数据库服务器执行。
  • 事务管理:确保数据存储操作的原子性、一致性、隔离性和持久性(ACID特性)。

数据持久化

一旦数据被成功存储到数据库中,它将被持久化,即即使数据库系统崩溃或重启,数据也不会丢失(假设使用了适当的备份和恢复策略)。

反馈与日志

最后,系统通常会向用户或应用程序提供反馈,表明数据存储操作的成功或失败。此外,还会记录相关的日志信息,以便进行审计、调试和故障排除。

注意事项

  • 安全性:在数据存储过程中,必须确保数据的安全性,包括防止未经授权的访问、篡改和泄露。
  • 性能:为了提高数据存储的效率,可以采取一些优化措施,如索引的使用、批量插入等。
  • 一致性:确保数据存储后与应用程序的其他部分保持一致,避免数据不一致导致的错误或冲突。

综上所述,数据存储是一个复杂而关键的过程,涉及多个步骤和考虑因素。通过仔细规划和实施这些步骤,可以确保数据的准确性、完整性和安全性。

标识符命名规则

MySQL中的标识符用于标识数据库、表、列等对象的名称。

基本规则

  1. 字符组成:标识符可以由字母(a-z、A-Z)、数字(0-9)、下划线(_)和美元符号($)组成。
  2. 首字符:标识符的第一个字符必须是字母或下划线,不能是数字。
  3. 大小写敏感性:MySQL对标识符的大小写敏感性取决于具体的存储引擎和操作系统。但在大多数情况下,MySQL在Windows系统上对标识符不区分大小写,而在Linux系统上则区分大小写。为了避免混淆,建议统一使用小写字母

长度限制

  • 数据库名、表名不得超过30个字符
  • 变量名不得超过29个字符

保留字与特殊字符

  1. 保留字:MySQL保留了一些关键字作为内部命令或函数的名称。当使用这些保留字作为标识符时,需要使用反引号(`)将其括起来,以避免冲突。
  2. 特殊字符:除了字母、数字、下划线和美元符号外,其他特殊字符通常不允许出现在标识符中。如果需要使用特殊字符,可以考虑使用反引号将其括起来(但请注意,这并不是一种推荐的做法,因为它可能会降低代码的可读性)。

命名建议

  1. 简洁明了:标识符应该简洁明了,能够清晰地表达出对象的含义。避免使用过长或含糊不清的名称。
  2. 避免保留字:尽量避免使用MySQL的保留字作为标识符,以减少潜在的冲突和混淆。
  3. 一致性:在命名时保持一致性,例如使用相同的命名风格(如驼峰命名法、下划线分隔法等)来命名数据库、表和列等对象。

示例

以下是一些符合MySQL标识符命名规则的示例:

  • 正确的表名:userorder_itemscustomer_details
  • 正确的列名:idnameemailbirth_date
  • 使用反引号括起来的保留字作为标识符:SELECT(注意:这里只是为了演示,实际上不建议这样做)

请注意,虽然MySQL允许在必要时使用反引号来避免与保留字的冲突,但过度使用反引号可能会降低代码的可读性和可维护性。因此,在命名时应尽量避免使用保留字,并遵循MySQL的标识符命名规则。

MySQL 中的数据类型

在MySQL中,数据类型用于指定表中列可以存储数据的种类。MySQL支持多种数据类型,包括数值类型、日期和时间类型以及字符串(文本)。

数据类型描述示例
数值类型
TINYINT非常小的整数127, -128(有符号);0~255, 0~-1(无符号)
SMALLINT小的整数32,767, -32,768(有符号);0~65,535, 0~-1(无符号)
MEDIUMINT中等大小的整数8,388,607, -8,388,608(有符号);0~16,777,215, 0~-1(无符号)
INT(或INTEGER)标准整数2,147,483,647, -2,147,483,648(有符号);0~4,294,967,295, 0~-1(无符号)
BIGINT大的整数9,223,372,036,854,775,807, -9,223,372,036,854,775,808(有符号);0~18,446,744,073,709,551,615, 0~-1(无符号)
FLOAT单精度浮点数3.14159
DOUBLE双精度浮点数3.141592653589793
DECIMAL定点数,用于存储精确的小数123.456
日期和时间类型
DATE日期值‘2023-10-01’
TIME时间值‘12:34:56’
DATETIME日期和时间值‘2023-10-01 12:34:56’
TIMESTAMP时间戳,通常用于记录行的创建或更新时间CURRENT_TIMESTAMP
YEAR年份值2023
字符串(文本)类型
CHAR定长字符串‘hello’
VARCHAR可变长字符串‘hello’
TINYTEXT非常小的文本字符串‘This is a tiny text.’
TEXT小文本字符串‘This is a text.’
MEDIUMTEXT中等大小的文本字符串‘This is a medium text.’
LONGTEXT大的文本字符串‘This is a very long text.’
ENUM枚举类型,允许你指定一个值的集合ENUM(‘small’, ‘medium’, ‘large’)
SET集合类型,允许你指定一个字符串对象的集合SET(‘apple’, ‘banana’, ‘cherry’)
BINARY二进制字符串b’010101’
VARBINARY可变长的二进制字符串b’010101’
TINYBLOB非常小的BLOBBLOB数据
BLOB小BLOBBLOB数据
MEDIUMBLOB中等大小的BLOBBLOB数据
LONGBLOB大的BLOBBLOB数据
JSON用于存储JSON格式的数据‘{“name”: “John”, “age”: 30}’

请注意,上述表格中的示例数据仅用于说明数据类型,实际存储的数据将取决于列的定义和插入的数据值。此外,MySQL还允许在定义数据类型时指定额外的属性,如字符集、排序规则、是否允许为空以及默认值等。

创建数据库

要创建一个新的数据库,可以使用 CREATE DATABASE 语句。基本语法如下:

CREATE DATABASE [IF NOT EXISTS] database_name;

示例

CREATE DATABASE IF NOT EXISTS my_database;

创建数据库时指定字符集和排序规则

你也可以在创建数据库时指定字符集和排序规则。例如:

CREATE DATABASE my_database
CHARACTER SET utf8mb4
COLLATE utf8mb4_general_ci;

查看数据库

要查看当前服务器上的所有数据库,可以使用 SHOW DATABASES 语句:

SHOW DATABASES;

修改数据库

MySQL 不提供直接修改数据库名称的语句。但是,你可以通过以下步骤间接地修改数据库名称:

  1. 创建一个新的数据库。
  2. 将旧数据库中的所有表和数据复制到新数据库中。
  3. 删除旧数据库(可选)。

修改数据库的字符集和排序规则

你可以使用 ALTER DATABASE 语句来修改数据库的字符集和排序规则:

ALTER DATABASE database_name
CHARACTER SET new_character_set
COLLATE new_collation;

示例

ALTER DATABASE my_database
CHARACTER SET utf8mb4
COLLATE utf8mb4_unicode_ci;

删除数据库

要删除一个数据库,可以使用 DROP DATABASE 语句。删除数据库将永久删除该数据库中的所有表和数据。基本语法如下:

DROP DATABASE [IF EXISTS] database_name;

示例

DROP DATABASE IF EXISTS my_database;

注意事项

  1. 权限:创建、修改和删除数据库需要相应的权限。通常,这些操作只能由具有管理员权限的用户(如 root 用户)执行。
  2. 数据备份:在删除数据库之前,确保已经备份了重要数据。删除数据库是不可逆的操作,数据将无法恢复。
  3. 数据库名称:数据库名称在 MySQL 服务器上必须是唯一的,并且符合命名规则(例如,不能使用保留字)。

总结

  • 使用 CREATE DATABASE 语句创建数据库。
  • 使用 SHOW DATABASES 语句查看所有数据库。
  • 使用 ALTER DATABASE 语句修改数据库的字符集和排序规则(但无法直接修改数据库名称)。
  • 使用 DROP DATABASE 语句删除数据库。

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

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

相关文章

影刀---实现我的第一个抓取数据的机器人

你们要的csdn自动回复机器人在这里文末哦! 这个上传的资源要vip下载,如果想了解影刀这个软件的话可以私聊我,我发你 目录 1.网页对象2.网页元素3.相似元素组4.元素操作设置下拉框复选框滚动条获取元素的信息 5.变量6.数据的表达字符串变量列…

github项目--crawl4ai

github项目--crawl4ai 输出html输出markdown格式输出结构化数据与BeautifulSoup的对比 crawl4ai github上这个项目,没记错的话,昨天涨了3000多的star,今天又新增2000star。一款抓取和解析工具,简单写个demo感受下 这里我们使用cra…

另外知识与网络总结

一、重谈NAT(工作在网络层) 为什么会有NAT 为了解决ipv4地址太少问题,到了公网的末端就会有运营商路由器来构建私网,在不同私网中私有IP可以重复,这就可以缓解IP地址太少问题,但是这就导致私有IP是重复的…

车辆重识别(2021ICML改进的去噪扩散概率模型)论文阅读2024/9/29

所谓改进的去噪扩散概率模型主要改进在哪些方面: ①对数似然值的改进 通过对噪声的那个方差和T进行调参,来实现改进。 ②学习 这个参数也就是后验概率的方差。通过数据分析,发现在T非常大的情况下对样本质量几乎没有影响,也就是说…

酒店新科技,飞睿智能毫米波雷达人体存在感应器,智能照明创新节能新风尚

在这个日新月异的时代,科技正以未有的速度改变着我们的生活。从智能手机到智能家居,每一个细微之处都渗透着科技的魅力。而今,这股科技浪潮已经席卷到了酒店行业,为传统的住宿体验带来了翻天覆地的变化。其中,引人注目…

什么是托管安全信息和事件管理 SIEM?

什么是 SIEM? 安全信息和事件管理 ( SIEM ) 解决方案最初是一种集中式日志聚合解决方案。SIEM 解决方案会从整个组织网络中的系统收集日志数据,使组织能够从单一集中位置监控其网络。 随着时间的推移,SIEM解决方案已发展成为一个完整的威胁…

曲线图异常波形检测系统源码分享

曲线图异常波形检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Comput…

(最新已验证)stm32 + 新版 onenet +dht11+esp8266/01s + mqtt物联网(含微信小程序)上报温湿度和控制单片机(保姆级教程)

物联网实践教程:微信小程序结合OneNET平台MQTT实现STM32单片机远程智能控制 远程上报和接收数据——汇总 前言 之前在学校获得了一个新玩意:ESP-01sWIFI模块,去搜了一下这个小东西很有玩点,远程控制LED啥的,然后我就想…

StopWath,apache commons lang3 包下的一个任务执行时间监视器的使用

StopWath是 apache commons lang3 包下的一个任务执行时间监视器&#xff0c;与我们平时常用的秒表的行为比较类似&#xff0c;我们先看一下其中的一些重要方法&#xff1a; <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 --> <dependen…

C++容器之list基本使用

目录 前言 一、list的介绍&#xff1f; 二、使用 1.list的构造 2.list iterator的使用 3.list capacity &#x1f947; empty &#x1f947;size 4.list element access &#x1f947; front &#x1f947; back 5.list modifiers &#x1f947; push_front &#x1f947; po…

一次实践:给自己的手机摄像头进行相机标定

文章目录 1. 问题引入2. 准备工作2.1 标定场2.2 相机拍摄 3. 基本原理3.1 成像原理3.2 畸变校正 4. 标定解算4.1 代码实现4.2 详细解析4.2.1 解算实现4.2.2 提取点位 4.3 解算结果 5. 问题补充 1. 问题引入 不得不说&#xff0c;现在的计算机视觉技术已经发展到足够成熟的阶段…

数造科技入选中国信通院《高质量数字化转型产品及服务全景图》三大板块

9月24日&#xff0c;2024大模型数字生态发展大会暨“铸基计划”年中会议在北京召开。会上&#xff0c;中国信通院发布了2024年《高质量数字化转型产品及服务全景图&#xff08;上半年度&#xff09;》和《高质量数字化转型技术解决方案&#xff08;上半年度&#xff09;》等多项…

Cell子刊被on hold,SCI 选刊投稿时该如何避开可能爆雷的期刊?

我是娜姐 迪娜学姐 &#xff0c;一个SCI医学期刊编辑&#xff0c;探索用AI工具提效论文写作和发表。 Cell Press旗下的Heliyon&#xff0c;前两天刚被WOS宣布on hold预警了。 这本创刊于2015年的综合性OA期刊&#xff0c;发文范围广泛&#xff0c;包括生物、化学、物理、工程等…

OpenCV 形态学相关函数详解及用法示例

OpenCV形态学相关的运算包含腐蚀(MORPH_ERODE)&#xff0c;膨胀(MORPH_DILATE)&#xff0c;开运算(MORPH_OPEN)&#xff0c;闭运算(MORPH_CLOSE)&#xff0c;梯度运算(MORPH_GRADIENT)&#xff0c;顶帽运算(MORPH_TOPHAT)&#xff0c;黑帽运算(MORPH_BLACKHAT)&#xff0c;击中…

Qt界面优化——绘图API

文章目录 绘图核心API绘制各种形状绘制线段绘制矩形绘制圆形绘制文本设置画笔设置画刷 绘制图片 绘图核心API Qt的各种控件&#xff0c;本质上都是画出来的&#xff0c;这不过这些都是提前画好了&#xff0c;我们拿过来直接使用即可。 实际开发中&#xff0c;可能现有控件无法…

锂电池SOC估计 | Matlab基于BP神经网络的锂电池SOC估计

锂电池SOC估计 | Matlab基于BP神经网络的锂电池SOC估计 目录 锂电池SOC估计 | Matlab基于BP神经网络的锂电池SOC估计预测效果基本描述程序设计参考资料 预测效果 基本描述 锂电池SOC估计 | Matlab基于BP神经网络的锂电池SOC估计 运行环境Matlab2023b及以上。 要实现基于BP神…

AI驱动TDSQL-C Serverless 数据库技术实战营-与AI的碰撞

目录 一、简介 二、实验介绍 三、结果展示 四、实操指导 4.1 系统设计 4.2 环境搭建&#xff08;手把手教程&#xff09; 4.3 应用构建 4.4 效果展示 4.5 踩坑避雷总结 五、清理资源 5.1 删除TDSQL-C Serverless 5.2 删除 HAI 算力 六、实验总结归纳 一、简介 本…

基于RPA+BERT的文档辅助“悦读”系统 | OPENAIGC开发者大赛高校组AI创作力奖

在第二届拯救者杯OPENAIGC开发者大赛中&#xff0c;涌现出一批技术突出、创意卓越的作品。为了让这些优秀项目被更多人看到&#xff0c;我们特意开设了优秀作品报道专栏&#xff0c;旨在展示其独特之处和开发者的精彩故事。 无论您是技术专家还是爱好者&#xff0c;希望能带给…

利用【通义灵码】代码补全增强使用实践

通义灵码提供了企业代码补全增强的能力&#xff0c;在开发者使用通义灵码 IDE 插件的行间代码生成时&#xff0c;可以结合企业上传的代码库作为上下文进行行间代码补全&#xff0c;使代码补全更加贴合企业代码规范、业务特点。本文将分享如何构建高质量的企业代码库&#xff0c…

【MySQL】-- 数据库基础

文章目录 1. 数据库简介1.1 什么是数据库1.2 什么是关系型数据库 2. 客户端与服务器的通讯方式2.1 CS架构 3. MySQL架构 1. 数据库简介 1.1 什么是数据库 什么是数据库&#xff1f; 组织和保存数据的应用程序。数据库和之前学的数据结构有什么关系&#xff1f; 数据结构是组织数…