超详细的mysql总结(基本概念、DDL、DML)
哈喽!今天心血来潮给大家带来了《超详细的mysql总结(基本概念、DDL、DML)》,想必大家应该对数据库都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到MySQL,若是你正在学习数据库,千万别错过这篇文章~希望能帮助到你!
开发中存在着各种数据,比如用户的个人信息、商品详情、购买记录,这些数据都要以一定的方式储存,如果以文本的形式储存,每一次获取都要读取文件,如果信息有修改则需要直接修改文本,大量的数据会需要保存大量的文件,这样不仅不便于操作、维护,还给服务器带来巨大的负担,什么样的方式能够储存大量的数据并且便于修改?答案就是数据库。
关系型数据库以二维数组组成的表结构来储存数据,各表之间可以设置一对一,一对多,多对多的关系,比如用户个人信息的表中id为1的用户,她在xx商品购买记录的表中存在着一条购买商品的数据,通过各种对应关系,能够从不同的维度保存数据,当需要使用的时候,直接根据某些条件下操作数据。
而非关系型数据库,它的存储更为自由,使用 key-value 这样的形式去保存数据,比如在登陆状态后,保存某个用户的姓名、手机号、身份等信息,获取和写入都比较的简单。

关系型数据库包括mysql、oracle、sql server 等,非关系型数据库包括 MongoDB、Redis等,这里来聊聊mysql。
mysql的语句大致可以分为四类,分别是
DDL(Data Definition Language):数据定义语言,用来对数据库或者表进行:创建、删除、修改等操作,
DML(Data Manipulation Language):数据操作语言,用来对表进行:添加、删除、修改等操作,
DQL(Data Query Language):数据查询语言,用来从数据库中查询记录,
DCL(Data Control Language):数据控制语言 对数据库、表格的权限进行相关访问控制操作。
首先来看对数据库操作,这里有一个编写习惯,通常把sql语句部分大写,数据库名、表名、字段名小写
// 1、展示所有的数据库,即使没有创建任何一个数据库,系统默认也会有四个数据库 SHOW DATABASES; // 2、选择数据库 mysql USE mysql; // 3、显示当前所选择的数据库 SELECT DATABASE(); // 4、如果不存在数据库 studySql 则创建 CREATE DATABASE IF NOT EXISTS `studySql`; // 5、如果存在数据库 studySql 则删除 DROP DATABASE IF EXISTS `studySql`;

再来看看对表的操作,比如在项目里,我们需要保存用户的个人资料,那么此时要创建一个用户表,表里面存储着用户的姓名、手机号码、出生年月,以上的这三种字段对应的是不同的类型,姓名需要字符串类型,手机号码需要数字类型,而出生年月需要使用日期类型,通过数据类型来对保存的数据进行限制,那么常见的数据类型有以下几种。
1、字符串类型 char定义固定长度的字符串,长度在0-255之间,varchar定义可变长的字符串,长度在0到65535之间的值,text可存储更大的字符串 2、数字类型 数字分为整数、浮点数、精确到小数点的数 整数类型:INT, 浮点类型:FLOAT,DOUBLE, 精确数字:DECIMAL,NUMERIC 3、日期类型 (1) YEAR,格式如YYYY,只有年份,范围从 1901到2155,和 0000 (2) DATE,格式如YYYY-MM-DD,有年月日,范围从 '1000-01-01' 到 '9999-12-31' (3) DATATIME,格式如 YYYY-MM-DD hh:mm:ss,有年月日时分秒,范围从 '1970-01-01 00:00:01' 到'2038-01-19 03:14:07' (4) DATASTAMP / TIMESTAMP,比DATATIME还要精确6位,格式如 YYYY-MM-DD hh:mm:ss.xxxxxx,范围从'1000-01-01 00:00:00.000000'到'9999-12-31 23:59:59.999999'
以上的数据类型用于创建表时对字段进行补充,除了补充之外,还应该对字段有限制,比如用户的手机号码不可重复,用户要添加一个唯一的id值来表示其“身份”,这些限制就是表约束,我们通常有以下几种方式来对表进行约束
1、主键 主键代表唯一的值,如id,主键不可重复,也不可以为空,用字段 PRIMARY KEY 来表示 2、唯一键 不可重复,但允许为空,比如手机号码,用字段UNIQUE来表示 3、AUTO_INCREMENT 当我们没有给某一字段设置值的时候,希望它自动增长,需要数据类型为数字类型 4、NOT NULL 不允许为空 5、DEFAULT 设置默认值 6、外键在下一篇关于DQL的总结中具体说明~
有了以上的概念,我们就可以在数据库中创建一张“用户表”了
CREATE TABLE IF NOT EXISTS `person` ( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(20) , telephone VARCHAR(20) UNIQUE NOT NULL, birth TIMESTAMP )
在这张表里插入、删除、修改一些数据
// 给每一个字段一一对应设置值 INSERT INTO `person` VALUES (9, 'judy', '18877776666', '1998-08-08'); INSERT INTO `person` VALUES (10, 'kiki', '18012345678', '2000-08-10'); // id 可自增、birth设置默认参数 INSERT INTO `person` (name, telephone) VALUES ('alice', '15600000000'); // 修改数据 UPDATE `person` SET NAME = 'xiaoming' WHERE id = 10; // 删除元素 DELETE FROM `person` WHERE id = 9; // 清空表所有内容 DELETE FROM `person` // 查询表里所有数据 SELECT * FROM `person` // 删除表 DROP TABLE IF EXISTS `person`
部分sql语句执行的结果如下图所示

以上sql语句操作的是表中的数据,如果对于表字段要进行操作,那么可以使用以下方式
// 修改表名(将表名person改为users) ALTER TABLE `person` RENAME TO `users`; // 修改表字段(将telephone修改为phone,数据类型为varchar) ALTER TABLE `users` CHANGE telephone phone VARCHAR(20); // 修改表数据类型(将birth的类型修改为Data,默认值为当前时间) ALTER TABLE `users` MODIFY DATATIME DEFAULT CURRENT_TIMESTAMP; // 增加列 gender ALTER TABLE `users` ADD gender varchar(10); ALTER TABLE `user` ADD updateTime TIMESTAMP; // 删除列 ALTER TABLE `user` DELETE updateTime; // 查看表结构 DESC `users`

还有一些sql有可能也会被用到
// 根据表结构创建另外一个表(复制) CREATE TABLE `user1` LIKE `users` // 根据另外一个表中的所有内容(不包括表结构), 创建新的表 CREATE TABLE `user3` AS (SELECT * FROM `user`) // 查看创建表的sql语句 SHOW CREATE TABLE `users`
今天关于《超详细的mysql总结(基本概念、DDL、DML)》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于mysql的内容请关注golang学习网公众号!

- 上一篇
- Rust简化版MybatisPlus - 让你一天从Java转业Rust

- 下一篇
- 一个非常实用的php数据库pdo操作类(curd操作类)
-
- 威武的春天
- 这篇文章太及时了,好细啊,很棒,收藏了,关注作者了!希望作者能多写数据库相关的文章。
- 2023-04-25 21:24:21
-
- 孤独的麦片
- 很有用,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢up主分享文章内容!
- 2023-04-04 18:35:47
-
- 娇气的老师
- 好细啊,收藏了,感谢师傅的这篇技术文章,我会继续支持!
- 2023-03-29 23:46:21
-
- 爱听歌的小馒头
- 这篇技术文章真是及时雨啊,博主加油!
- 2023-03-29 22:38:27
-
- 数据库 · MySQL | 2小时前 |
- MySQL多表连接优化技巧与实战策略
- 221浏览 收藏
-
- 数据库 · MySQL | 13小时前 |
- MySQL排序优化与性能提升技巧
- 153浏览 收藏
-
- 数据库 · MySQL | 15小时前 |
- MySQL中WHERE与HAVING的区别详解
- 340浏览 收藏
-
- 数据库 · MySQL | 20小时前 |
- MySQL排序优化与性能提升技巧
- 368浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL连接池配置与优化方法
- 297浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQLGROUPBY使用技巧与常见问题
- 306浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL缓存优化技巧分享
- 392浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL安装到D盘教程及路径设置详解
- 279浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL缓存设置及查询作用解析
- 470浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQLcount优化技巧及性能提升方法
- 371浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQLUPDATE替换字段值方法详解
- 292浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 95次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 89次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 106次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 98次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 98次使用
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览