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

相关文章

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

基于SpringBoot+Mybatis实现Mysql分表

《基于SpringBoot+Mybatis实现Mysql分表》这篇文章主要为大家详细介绍了基于SpringBoot+Mybatis实现Mysql分表的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录基本思路定义注解创建ThreadLocal创建拦截器业务处理基本思路1.根据创建时间字段按年进

Python3.6连接MySQL的详细步骤

《Python3.6连接MySQL的详细步骤》在现代Web开发和数据处理中,Python与数据库的交互是必不可少的一部分,MySQL作为最流行的开源关系型数据库管理系统之一,与Python的结合可以实... 目录环境准备安装python 3.6安装mysql安装pymysql库连接到MySQL建立连接执行S

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分