IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> MySQL---DDL&DML语言 -> 正文阅读

[大数据]MySQL---DDL&DML语言

DDL

DDL的含义:数据定义语言,主要是对于库和表的管理

一、数据库的操作

数据库的操作主要有创建数据库、修改数据库、删除数据库等操作。
1.创建数据库

#创建数据库
create database 数据库名称;
#创建数据库,先判断不存在,再去创建
create database if not exists 数据库名称;
#创建数据库,并指定字符集
create database 数据库名称 character set 字符集名;

2.查询数据库

#使用数据库
use 数据库名称;
#查询所有数据库的名称:
show databases;
#查询某个数据库的字符集:查询某个数据库的创建语句
show create database 数据库名称;
#查询当前正在使用的数据库名称
select database();

3.修改数据库

#修改数据库的字符集
alter database 数据库名称 character set 字符集名称;

4.删除数据库

#判断数据库存在,再删除
drop database if exists 数据库名称;

二、数据表的操作

1.表的创建

 create table 表名(
				列名1 数据类型1 【字段约束】,
				列名2 数据类型2 【字段约束】,
				....
				列名n 数据类型n 【字段约束】
			);

注意: 最后一列不需要加逗号!
2.查询表

#查询当前数据库中所有的表
show tables;
#查询某个数据库中的所有表
show tables from 数据库名称;
#查询表结构
desc 表名;

3.表的修改

#修改表名
alter table 表名 rename to 新表名;
#修改表的字符集
alter table 表名 character set 字符集名称;
#添加一列
alter table 表名 add column 列名 数据类型;
#修改列的名称类型
alter table 表名 change column 列名 新列别 新数据类型;
alter table 表名 modify column 列名 新数据类型;
#删除列
alter table 表名 drop column 列名;

4.表的删除

#先判断表是否存在,在删除
drop table if exists 表名;

三、MySQL的常用数据类型

MySQL的常用数据类型主要分为三大类:数值型、字符型、日期型。
其中数字型又分为整数和小数,小数又分为浮点型和定点型。
1.数值型
整数:
在这里插入图片描述
特点

  • 如果不设置无符号还是有符号,默认是有符号,若想设置无符号需添加关键字 unsigned
  • 如果插入的数值超出了整型的范围,会报 out of range 异常,并且插入临界值
  • 如果不设置长度,会有默认的长度 长度代表了最大显示宽度,如果不够会用0在左边填充,但必须搭配zerofill使用

小数
在这里插入图片描述
特点

  • M代表整数部位+小数部位
  • D代表小数部位
  • 如果超过范围,则插入临界值
  • M和D都可以省略
  • 如果是decimal,则M默认为10,D默认为0
  • 如果是float和double,则会随着插入的数值精度来改变
  • 定点型的精度较高

2.字符型
较短的文本
在这里插入图片描述
char

  • 固定长度的字符,比较耗费空间,效率较高,M可以省略,默认为1

varchar

  • 可变长度的字符,比较节省空间,效率较低,M不可以省略

保存较长的文本
text、blob(较大的二进制)都是用来存储较长文本的

其他字符型

  • binary和varbinary用于保存较短的二进制
  • enum用于保存枚举
  • set用于保存集合

3.日期型
在这里插入图片描述
注意:

  • date只保存日期
  • time 只保存时间
  • year 只保存年
  • datetime 保存日期+时间
    范围1000-9999
    不受时区的影响
  • timestamp 保存日期+时间
    范围1970-2038
    受时区的影响

四、常见约束

概念: 对表中的数据进行限定,保证数据的正确性、有效性和完整性。
分类:
not null 非空约束,用于保证该字段的值不能为空
default 默认值约束,用于保证该字段有默认值
primary key 主键约束,用于保证该字段的值具有唯一性,并且为非空,一个表中只能有一个,允许组合
unique 唯一约束,用于保存该字段的值具有唯一性,可以为空,但空值只能有一个,一个表中可以有多个,允许组合
check 检查约束,判断字段的值是否在是指定规定的值

foreign key外键约束,用于限制两个表的关系,用于保证该字段的值必须来自于主表的关联列的值

  • 在从表添加外键约束,用于引用主表中某列的值
  • 要求在从表设置外键关系
  • 从表的外键列的类型和主表的关联列的类型要求一致或兼容
  • 主表的关联列必须是一个key(一般是主键或唯一)
  • 插入数据时,先插入主表,再插入从表
  • 删除数据时,先删除从表,在删除主表

约束的添加时机一般在我们创建表和修改表时。
约束添加的分类: 列级约束、表级约束
列级约束

  • 六大约束语法上都支持,但外键约束没有效果
  • 直接在字段名和类型后面追加约束即可
    表级约束
  • 除了非空、默认,其他的都支持
  • 在各个字段的最下面添加
  • 语法:
constraint 约束名 】约束类型(字段名)

查看表中的所有索引(主键、外键、唯一)

show index from 表名

添加列级约束

alter table 表名 modify column 字段名 字段类型 新约束;

添加表级约束

alter table 表名 addconstraint 约束名】 约束类型(字段名) 【外键的引用】;

DML

DML 数据操作语言 主要是对数据进行插入、修改、删除等操作
一、添加数据

insert into 表名(列名1,列名2,...列名n) values(1,2,...值n);

注意:
1. 列名和值要一一对应。
2. 如果表名后,不定义列名,则默认给所有列添加值
3. 除了数字类型,其他类型需要使用引号(单双都可以)引起来

二、删除数据

 delete from 表名 [where 条件]

注意:
1. 如果不加条件,则删除表中所有记录。
2. 如果要删除所有记录
delete from 表名; – 不推荐使用。有多少条记录就会执行多少次删除操作
TRUNCATE TABLE 表名; – 推荐使用,效率更高 先删除表,然后再创建一张一样的表。

常见面试题: delete与TRUNCATE区别?
1.truncate不能加where条件,而delete可以加where条件
2.truncate的效率高
3.truncate 删除带自增长的列的表后,如果再插入数据,数据从1开始
4.delete 删除带自增长列的表后,如果再插入数据,数据从上一次的断点处开始
5.truncate删除不能回滚,delete删除可以回滚

三、修改数据
修改单表:

update 表名 set 列名1 =1, 列名2 =2,... [where 条件];

修改多表:

update1 别名1,2 别名2 set 字段=新值,字段=新值 where 连接条件 and 筛选条件

注意: 如果不加任何条件,则会将表中所有记录全部修改

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-12-08 13:53:00  更:2021-12-08 13:53:36 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 9:48:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码