本文主要是介绍MySQL核心知识之DDL数据定义语言,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
MySQL核心知识之DDL数据定义语言
- MySQL核心知识之DDL数据定义语言
- Linux操作系统安装MySQL5.7数据库
- Linux操作系统安装MySQL5.7数据库
- MySQL数据库必备知识之创建、查看及使用/切换
- 直接创建数据库db1
- 查看当前在那个数据库
- 进入数据库的操作
- 判断数据库是否存在,如果不存在并创建数据库db2;
- 创建数据库并指定字符集为gbk;
- 查看某个数据库的字符集
- 查看当前MySQL使用的字符集
- MySQL创建表之常用数据类型
- 数据类型是什么
- MySQL常见数据类型
- 整数型
- 浮点型
- 定点型
- 字符串类型
- 时间型
- MySQL数据表必备知识之创建表
- 语法
- 约束条件
- 创建sql
- MySQL数据表必备之查看
- 查看数据库中的所有表
- 查看表结构
- 查看创建表的sql语句
- MySQL数据表必备知识之表结构维护与删除
- 修改表名
- 添加列
- 给表添加一列:alter table 表名 add 列名 类型;
- 给表最前面添加一列:alter table 表名 add 列名 类型 first;
- 给表的某字段后加一列:alter table 表名 add 列名 类型 after 字段名;
- 修改列类型
- 修改列名
- 删除列
- 修改字符集
- mysql表的删除
MySQL核心知识之DDL数据定义语言
Linux操作系统安装MySQL5.7数据库
Linux操作系统安装MySQL5.7数据库
- 网上方法较多,但容易踩坑
- 推荐参考博文https://blog.csdn.net/qq_37598011/article/details/93489404
- 亲测有效,一次成功!
MySQL数据库必备知识之创建、查看及使用/切换
直接创建数据库db1
- create database 库名;
- create batabase db1;
查看当前在那个数据库
- select database();
进入数据库的操作
- usr 库名;
- use db1;
判断数据库是否存在,如果不存在并创建数据库db2;
- create database if not exists 库名;
- create database if not exists db2;
创建数据库并指定字符集为gbk;
- create database 库名 default character set 字符集;
- create database db3 default character set gbk;
查看某个数据库的字符集
- show create database 库名;
- show create database db3;
查看当前MySQL使用的字符集
- show variables like ‘character%’;
MySQL创建表之常用数据类型
数据类型是什么
- 数据类型是指列、存储过程参数、表达式和局部变量的数据特征,它决定了数据的存储格式,代表了不同的信息类型。有一些数据是要存储为数字的,数字当中有些是要存储为整数、小数、日期型等…
MySQL常见数据类型
整数型
类型 | 大小 | 范围(有符号) | 范围(无符号unsigned) | 用途 |
---|---|---|---|---|
tinyint | 1Byte | (-128,127) | (0,255) | 小整数值 |
smallint | 2Byte | (-32768,32767) | (0,65535) | 大整数值 |
mediumint | 3Byte | (-8388608,8388607) | (0,16777215) | 大整数值 |
int | 4Byte | (-2147483648,2147483647) | (0,4294967295) | 大整数值 |
bigint | 8Byte | () | (0,2的64次方减1) | 极大整数值 |
浮点型
类型 | 大小 | 含义 | 备注 |
---|---|---|---|
float(m,d) | 4Byte | 单精度浮点型 | m代表总个数,d代表小数位个数 |
double(m,d) | 8Byte | 双精度浮点型 | m代表总个数,d代表小数位个数 |
定点型
类型 | 含义 | 备注 |
---|---|---|
decimal(m,d) | 依赖于M和D的值 | m代表总个数,d代表小数位个数 |
字符串类型
类型 | 大小 | 用途 |
---|---|---|
char | 0-255Byte | 定长字符串 |
varchar | 0-65535Byte | 变长字符串 |
tinyitext | 0-255Byte | 短文本字符串 |
text | 0-65535Byte | 长文本数据 |
mediumtext | 0-16777215Byte | 中等长度文本数据 |
longtext | 0-4294967295Byte | 极大文本数据 |
note:char的优缺点:存取速度比varchar更快,但是比varchar更占用空间
**varchar的优缺点:比char省空间。但是存取速度没有char快 **
时间型
数据类型 | 字节数 | 格式 | 备注 |
---|---|---|---|
date | 3 | yyyy-MM-dd | 存储时期值 |
time | 3 | HH:mm:ss | 存储时分秒 |
year | 1 | yyyy | 存储年 |
datetime | 8 | yyyy-MM-dd HH:mm:ss | 存储时间+日期 |
timestamp | 4 | yyyy-MM-dd HH:mm:ss | 存储日期+时间,可作时间戳 |
create table test_time (date_value date,time_value time,year_value year,datetime_value datetime,timestamp_value timestamp
) engine=innodb charset=utf8;insert into test_time values(now(),now(),now(),now(),now());
MySQL数据表必备知识之创建表
语法
create table 表名(字段名1 字段类型1 约束条件1 说明1,字段名2 字段类型2 约束条件2 说明2,字段名3 字段类型3 约束条件3 说明3
);create table 新表名 as select * from 旧表名 where 1=2;(注意议这种创建表的方式用于日常测试,因为可能索引什么的会复制不过来)create table 新表名 like 旧表名;
约束条件
comment ----说明解释
not null ----不为空
default ----默认值
unsigned ----无符号(正数)
auto_increment ----自增
zerofill ----自动填充
unique key ----唯一值
创建sql
create table student(id tinyint(5) zerofill auto_increment not null comment '学生学号',name varchar(20) default null comment '学生姓名',age tinyint default null comment '学生年龄',class varchar(20) default null comment '学生班级',sex char(5) not null comment '学生性别',unique key (id)
)engine=innodb charset=utf8;;
MySQL数据表必备之查看
查看数据库中的所有表
- show tables;
查看表结构
- desc 表名;
查看创建表的sql语句
- show create table 表名;
- \G :有结束sql语句的作用,还有把显示的数据纵向旋转90度
- \g :有结束sql语句的作用
MySQL数据表必备知识之表结构维护与删除
修改表名
- rename table 旧表明 to 新表名;
- rename table student to user;
添加列
给表添加一列:alter table 表名 add 列名 类型;
- alter table user add addr varchar(50);
- alter table 表名 add 列名 类型 comment ‘说明’;
- alter table user add famliy varchar (50) comment ‘家庭信息’;
给表最前面添加一列:alter table 表名 add 列名 类型 first;
- alter table user add job varcher(10) first;
给表的某字段后加一列:alter table 表名 add 列名 类型 after 字段名;
- alter table user add servnumber int(11) after id;
**note:没有给表某个字段前添加一列的说法。 **
修改列类型
- alter table 表名 modify 列名 新类型
- alter table user modify servnumber varcher(20);
修改列名
- alter table 表名 change 旧列名 新列名 类型;
- alter table user change servmunber telephone varchar(20);
删除列
- alter table 表名 drop 列名;
- alter table user drop family;
修改字符集
- alter table 表名 character set 字符集;
- alter table user character set GBK;
mysql表的删除
- drop table 表名;
- drop table user;
- 看表是否存在,若存在则删除表:drop table if exists 表名;
- drop table if exists teacher;
这篇关于MySQL核心知识之DDL数据定义语言的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!