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

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映