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常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

SQL Server 中的 WITH (NOLOCK) 示例详解

《SQLServer中的WITH(NOLOCK)示例详解》SQLServer中的WITH(NOLOCK)是一种表提示,等同于READUNCOMMITTED隔离级别,允许查询在不获取共享锁的情... 目录SQL Server 中的 WITH (NOLOCK) 详解一、WITH (NOLOCK) 的本质二、工作

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也