MySQL核心知识之DDL数据定义语言

2023-10-18 13:58

本文主要是介绍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)用途
tinyint1Byte(-128,127)(0,255)小整数值
smallint2Byte(-32768,32767)(0,65535)大整数值
mediumint3Byte(-8388608,8388607)(0,16777215)大整数值
int4Byte(-2147483648,2147483647)(0,4294967295)大整数值
bigint8Byte()(0,2的64次方减1)极大整数值
浮点型
类型大小含义备注
float(m,d)4Byte单精度浮点型m代表总个数,d代表小数位个数
double(m,d)8Byte双精度浮点型m代表总个数,d代表小数位个数
定点型
类型含义备注
decimal(m,d)依赖于M和D的值m代表总个数,d代表小数位个数
字符串类型
类型大小用途
char0-255Byte定长字符串
varchar0-65535Byte变长字符串
tinyitext0-255Byte短文本字符串
text0-65535Byte长文本数据
mediumtext0-16777215Byte中等长度文本数据
longtext0-4294967295Byte极大文本数据

note:char的优缺点:存取速度比varchar更快,但是比varchar更占用空间

**varchar的优缺点:比char省空间。但是存取速度没有char快 **

时间型
数据类型字节数格式备注
date3yyyy-MM-dd存储时期值
time3HH:mm:ss存储时分秒
year1yyyy存储年
datetime8yyyy-MM-dd HH:mm:ss存储时间+日期
timestamp4yyyy-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数据定义语言的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/233005

相关文章

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

MySQL底层文件的查看和修改方法

《MySQL底层文件的查看和修改方法》MySQL底层文件分为文本类(可安全查看/修改)和二进制类(禁止手动操作),以下按「查看方法、修改方法、风险管控三部分详细说明,所有操作均以Linux环境为例,需... 目录引言一、mysql 底层文件的查看方法1. 先定位核心文件路径(基础前提)2. 文本类文件(可直

MySQL数据目录迁移的完整过程

《MySQL数据目录迁移的完整过程》文章详细介绍了将MySQL数据目录迁移到新硬盘的整个过程,包括新硬盘挂载、创建新的数据目录、迁移数据(推荐使用两遍rsync方案)、修改MySQL配置文件和重启验证... 目录1,新硬盘挂载(如果有的话)2,创建新的 mysql 数据目录3,迁移 MySQL 数据(推荐两

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

SQL Server中行转列方法详细讲解

《SQLServer中行转列方法详细讲解》SQL行转列、列转行可以帮助我们更方便地处理数据,生成需要的报表和结果集,:本文主要介绍SQLServer中行转列方法的相关资料,需要的朋友可以参考下... 目录前言一、为什么需要行转列二、行转列的基本概念三、使用PIVOT运算符进行行转列1.创建示例数据表并插入数

MySQL MHA集群详解(数据库高可用)

《MySQLMHA集群详解(数据库高可用)》MHA(MasterHighAvailability)是开源MySQL高可用管理工具,用于自动故障检测与转移,支持异步或半同步复制的MySQL主从架构,本... 目录mysql 高可用方案:MHA 详解与实战1. MHA 简介2. MHA 的组件组成(1)MHA