目录

字符编码与配置文件

\s查看MySQL相关信息

相关信息有:当前用户、版本、编码、端口号
MySQL5.6及之前的版本编码需要人为统一 之后的版本已经全部默认统一 如果想要永久修改编码配置 需要操作配置文件my-default.ini



注意事项:

  1. mysql默认端口号3306 当重复起mysql服务端时 记得查看端口号
  2. MySQL5.6版本及之前的版本 编码既有拉丁文 也有gbk 需要人为统一

    MySQL5.6版本之后的MySQL编码已经统一

修改配置文件my-default.ini

2.默认的配置文件是my-default.ini
拷贝上述文件并重命名为my.ini 直接拷贝字符编码相关配置即可无需记忆
[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_general_ci
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4
ps:
1.utf8mb4能够存储表情 功能更强大
2.utf8与utf-8是有区别的 MySQL中只有utf8 修改了配置文件中关于[mysqld]的配置 需要重启服务端 """
利用配置文件我们可以偷懒
将管理员登录的账号密码直接写在配置文件中 之后使用mysql登录即可
[mysql]
user='root'
password=123
"""

解决5.6版本字符编码问题

  1. 配置文件位置

  2. 查看配置文件介绍:

  3. 拷贝一份并重命名为my.ini这个名字不能随便取,放在旁边(注意打开文件扩展名)

  4. 在my.ini文件里修改配置信息

  5. 重启服务端(注意使用管理员cmd)

  6. 修改成功

补充说明:
1. mysql中'utf8'和'utf-8'这两个是有区别的:mysql中只允许有utf8.
2. [client]表示第三方的客户端 [mysql]表示自己写的客户端 [server]表示服务端.
3. 如果是8.0版本的mysql,则默认编码是utfmb4.

配置文件什么时候加载?

在mysqld的配置文件中加一串不明所以的代码



重启服务端,登录mysql:



会直接报错 连密码都输不进去了。所以说配置文件是在客户端启动之前加载的。

偷懒操作:输入mysql直接登录root账户

修改配置文件:



实现不输入密码直接登录,原来是账号密码写配置文件里了:

数据库存储引擎

存储引擎简介

数据库针对数据采取的多种存取方式

举例:
不同的引擎针对相同的数据 采取的方式不一样
给小勇,小红一份数据:
小勇 ---> 存电脑 取的时候:小勇乖乖拿过来
小红 ----> 存网盘 取的时候:小红叫我过来拿

查看引擎 show engines;

在mysql中使用show engines;命令查看引擎:



表格从左到右 ---> 引擎 模式 描述 事务 断点

事务:当两个不同的数据库交互时 例如小红转账时 银行瘫痪 只扣钱没加钱 事务可以让时间倒流

需要了解的四个存储引擎

  1. MyISAM

    MySQL5.5之前默认的存储引擎

    存取数据的速度快 但是功能较少 安全性较低

    myisam 不支持事务 行锁表锁

  2. InnoDB

    MySQL5.5之后默认的存储引擎

    支持事务、行锁、外键等操作 存取速度没有MyISAM快 但是安全性更高

  3. Memory

    基于内存存取数据 仅用于临时表数据存取

    基于hash 默认不持久保存

  4. BlackHole

    任何写入进去的数据都会立刻丢失

    备份时数据的处理

了解不同存储引擎底层文件个数

查看表的存储引擎:

了解不同存储引擎底层文件个数
create database db2;
use db2;
create table t1(id int) engine=innodb;
create table t2(id int) engine=myisam;
create table t3(id int) engine=memory;
create table t4(id int) engine=blackhole;
'''
1.innodb两个文件
.frm 表结构
.ibd 表数据(表索引)
2.myisam三个文件
.frm 表结构
.MYD 表数据
.MYI 表索引
3.memory一个文件
.frm 表结构
4.blackhole一个文件
.frm 表结构
'''
insert into t1 values(1);
insert into t2 values(1);
insert into t3 values(1);
insert into t4 values(1);
'''
表索引相当于书的目录 用于加快数据查询
memery 基于内存所以没有表数据 文件是操作系统暴露出来给用户操作硬盘的快捷方式'''
ps:MySQL默认忽略大小写
  1. 创建表:

  2. 查看文件:

验证memory\blackhole 数据消失

t3 重启服务数据消失:



t4 数据直接消失:

创建表的完整语法(重要)

'''
create table 表名(
字段名 字段类型(数字) 约束条件,
字段名 字段类型(数字) 约束条件,
字段名 字段类型(数字) 约束条件
);
'''
1.字段名和字段类型是必须的
2.数字和约束条件是可选的
3.约束条件也可以写多个 空格隔开即可
4.'''最后一行结尾不能加逗号''' ps:编写SQL语句报错之后不要慌 仔细查看提示 会很快解决
near ')' at line 7

字段类型之整型

tinyint			1bytes			正负号(占1bit)
smallint 2bytes 正负号(占1bit)
int 4bytes 正负号(占1bit)
bigint 8bytes 正负号(占1bit)

验证整型默认是否携带正负号

create table t5(id tinyint);

insert into t5 values(-129),(128);

  1. 创建表

  2. 插入值

结果是-128和127 也就意味着默认自带正负号

正负数也要占用一个bit位 故只能存128

手机号(13位)存储时,Int的位数不够(10位) 需要使用bigint、字符串。

取消正负号 unsigned

我们也可以取消正负号,使用约束条件unsigned.

create table t6(id tinyint unsigned);

insert into t6 values(-129),(128),(1000);

严格模式

当我们在使用数据库存储数据的时候 如果数据不符合规范

应该直接报错而不是擅自修改数据 这样会导致数据的失真(没有实际意义)

正常情况下是应该报错 但是我们之前修改了配置文件 将严格模式的配置代码给删掉了

查看当前数据库是否有严格模式

代码的意思是找出所有带mode的配置信息:

show variables like '%mode%';



这表示没有开启严格模式

临时修改

	set session sql_mode='strict_trans_tables';
在当前客户端有效 当前用户有效 用户退出之后重新登录无效
set global sql_mode='strict_trans_tables';
在当前服务端有效 只要服务器没重启 对所有用户都有效

永久修改

改配置文件:

sql mode = STRICT TRANS TABLES

字段类型之浮点型

语法:
float (存储数字的位数,小数点后面的数) float(20,10)
总共存储20位数 小数点后面占10
double(20,10)
总共存储20位数 小数点后面占10
decimal(20,10)
总共存储20位数 小数点后面占10 create table t7(id float(60,20));
create table t8(id double(60,20));
create table t9(id decimal(60,20));
insert into t7 values(1.11111111111111111111);
insert into t8 values(1.11111111111111111111);
insert into t9 values(1.11111111111111111111); 三者的核心区别在于精确度不同
float < double < decimal



验证三者精确度:

字段类型之字符类型(重要)

char
定长
char(4) 最多存储四个字符 超出就报错 不够四个空格填充至四个
varchar
变长
varchar(4) 最多存储四个字符 超出就报错 不够则有几位存几位 create table t10(id int, name char(4));
create table t11(id int, name varchar(4));
insert into t10 values(1, 'jason1');
insert into t11 values(1, 'jason2'); ps:char_length()获取字段存储的数据长度
默认情况下MySQL针对char的存储会自动填充空格和删除空格

数字限制存储的字符长度:

验证定长和变长

  1. 建立表:

  2. 使用char_length()查看字符长度

  3. 大失所望:char怎么没有填充空白?

    mysql存的时候真的是有空格 取出的时候会将空格去掉

    所以还是1 可以取消这个机制 但是没必要取消

取消mysql自动去掉空格的特性

输入:

set global sql_mode='strict_trans_tables,pad_char_to_full_length';

注意这修改的是服务端层面,重启服务端则失效。



重新登录:

char VS varchar

char
优势:整存整取 速度快
劣势:浪费存储空间
varchar
优势:节省存储空间
劣势:存取数据的速度较char慢
"""
char与varchar的使用需要结合具体应用场景 char(32)存中国人名字 劣势 因为大多数人名字都是两三个字 少部分人名字长
存姓名 用varchar
存手机号码 男女性别 用char
"""

为什么varchar的存取速度慢?

# 为什么varchar存取速度较慢?
char取固定位数 直接拿就好了
jasonjacktomjerry 不知道存的时候是几位
不知道要取几位的时候 使用报头
存数据时用1bytes作为报头
取的时候先取一个字节的报头 解析数据真实的长度:
1bytes+jack 1bytes+tony 1bytes+jason 1bytes+kevin 1bytes+tom 1bytes+jerry
报头1bytes不够用怎么办?

补充

int类型中数字的含义

数字在很多地方都是用来表示限制存储数据的长度

但是在整型中数字却不是用来限制存储长度

用零补全显示 zerofill

  1. 不是用来限制存储长度:

    create table t12(id int(3));

    insert into t12 values(12345);

  2. 而是用来控制展示的长度:

    create table t13(id int(5) zerofill);

    insert into t13 values(123),(123456789);

    create table t14(id int);



    3.以后写整型无需添加数字,会默认添加数字

字段类型之枚举与集合

枚举 enum

多选一
create table t15(
id int,
name varchar(32),
gender enum('male','female','others')
);
insert into t15 values(1,'tony','猛男');
insert into t15 values(2,'jason','male');
insert into t15 values(3,'kevin','others');
  1. 给表添加枚举类型

  2. 字段不对:

  3. 添加成功

集合 set

集合包括枚举!

多选多(多选一)
create table t16(
id int,
name varchar(16),
hobbies set('basketabll','football','doublecolorball')
);
insert into t16 values(1,'jason','study');
insert into t16 values(2,'tony','doublecolorball');
insert into t16 values(3,'kevin','doublecolorball,football');
  1. 给表添加集合类型

  2. 无法输入集合外的数据

字段类型之日期类型 datatime

datetime		年月日时分秒
date 年月日
time 时分秒
year 年 create table t17(
id int,
name varchar(32),
register_time datetime,
birthday date,
study_time time,
work_time year
);
insert into t17 values(1,'jason','2000-11-11 11:11:11','1998-01-21','11:11:11','2000');
ps:以后涉及到日期相关字段一般都是系统自动回去 无需我们可以操作
'''
以后所有的表都要用日期类型
datatime可以切割 想怎么切怎么切 用mysql内置函数 流程控制'''
  1. 添加时间类型

  2. 给时间类型添加值



    更多:



    关于 DATETIME 与 TIMESTAMP 两种类型如何选用,可以按照存储需求来,比如要求存储范围更广,则推荐使用 DATETIME ,如果只是存储当前时间戳,则可以使用 TIMESTAMP 类型。不过值得注意的是,TIMESTAMP 字段数据会随着系统时区而改变但 DATETIME 字段数据不会。总体来说 DATETIME 使用范围更广。

补充-MySQL存储引擎 DDL

MySQL语句处理逻辑, 其实就是一大堆函数执行和调用

连接层验证 >> 提供链接协议, 验证 >> 验证完成, 线程链接 >> 连接之后分配线程(线程池) >> 接收sql语句 >> 解析语义, 语法 >> 权限判断 >> 生成解析树 >> 优化器优化 >> 执行 >> 结果交给存储引擎 >> 拿到磁盘数据 >> 展示给用户

存储引擎相关:

MySQL所有管理操作都是以16进制的方式存储在磁盘上

主要是两大部分组成, 一部分内存结构In-Memory Structure, 一部分磁盘结构On-Disk Structure

1. 内存结构
Buffer Pool整体区域
Change Buffer索引相关
Log Buffer redo缓冲区
Adaptive Hash Index自适应hash索引
2. 磁盘结构
一系列表空间, system tablespace, undo, redo, file-per-table独立表空间, general, temporary
3. 线程结构
Main Thread: 核心后台进程, 负责全局数据管理和数据统一处理
IO Thread: 磁盘IO交互, 读写IO, inset buffer, log IO; 参数有inndb_read_io_threads...
Purge Thread: undo页回收
Page Cleaner: 脏页刷新线程, 默认1, 最大64
Other threads

DDL

Data Definition Language, 库表定义

库名, 库属性, 表名表属性, 列名, 列属性

  1. 库定义指定字符集, 如果不指定修改很麻烦
  2. 库名不要用大写, 不要数字开头, 不要超过18字符, 不要用内置字符串, 和业务相关
  3. 表定义和库定义一样
  4. 列名要有意义, 不要内置字符, 不要超过18字符, 数据类型合适精简完整
  5. 每个表需要有一个主键, 每一列尽量NOT NULL, 尽量不用外键
  6. 每列要有注释
  7. 存储引擎innodb, 字符集utfmb4

    作者:https://www.yuque.com/hupeirong/qmsye1/fcu8bgg5q8kudlag?#

额外:

https://www.cnblogs.com/ysging/articles/16915846.html

https://dev.mysql.com/doc/refman/8.0/en/faqs-storage-engines.html

配置文件 数据库存储引擎 严格模式 MySQL字段基本数据类型的更多相关文章

  1. 【转】MySQL 数据库存储引擎

    原文地址:http://blog.jobbole.com/94385/ 简单介绍 存储引擎就是指表的类型.数据库的存储引擎决定了表在计算机中的存储方式.存储引擎的概念是MySQl的特点,而且是一个插入 ...

  2. MySQL 数据库存储引擎

    简单介绍 存储引擎就是指表的类型.数据库的存储引擎决定了表在计算机中的存储方式.存储引擎的概念是MySQl的特点,而且是一个插入式的存储引擎概念.这就决定了MySQl数据库中的表可以使用不同的存储方式 ...

  3. (转)Mysql数据库存储引擎

    什么是MySql数据库 通常意义上,数据库也就是数据的集合,具体到计算机上数据库可以是存储器上一些文件的集合或者一些内存数据的集合.     我们通常说的MySql数据库,sql server数据库等 ...

  4. Mysql数据库存储引擎--转

    原文地址:http://pangge.blog.51cto.com/6013757/1303893 简单介绍 存储引擎就是指表的类型.数据库的存储引擎决定了表在计算机中的存储方式.存储引擎的概念是My ...

  5. MySQL - 常见的三种数据库存储引擎

    原文:MySQL - 常见的三种数据库存储引擎 数据库存储引擎:是数据库底层软件组织,数据库管理系统(DBMS)使用数据引擎进行创建.查询.更新和删除数据.不同的存储引擎提供不同的存储机制.索引技巧. ...

  6. MySQL - 常用三种数据库存储引擎

    数据库存储引擎:是数据库底层软件组织,数据库管理系统(DBMS)使用数据引擎进行创建.查询.更新和删除数据.不同的存储引擎提供不同的存储机制.索引技巧.锁定水平等功能,使用不同的存储引擎,还可以获得特 ...

  7. Linux环境下修改MySQL数据库存储引擎

    今天在执行Oracle数据库迁移至MySQL数据库时报出了一个错误信息: Specified key was too bytes 百度发现,原来需要更改MySQL数据库的存储引擎为InnoDB,查询目 ...

  8. 《面试经典系列》- MySQL数据库存储引擎

    一.MySQL有多少种存储引擎? 在MySQL5之后,支持的存储引擎有十多个,但是我们常用的就那么几种,而且,默认支持的也是 InnoDB. 通过命令:show engines \g,我们可以查看到当 ...

  9. MYSQL——数据库存储引擎!

    本人安装mysql版本为:mysql  Ver 14.14 Distrib 5.7.18, for Win64 (x86_64),查看mysql的版本号方式:cmd-->mysql --vers ...

  10. Atitit.数据库存储引擎的原理与attilax 总结

    Atitit.数据库存储引擎的原理与attilax 总结 1. 存储引擎是什么1 2. 其它数据库系统(包括大多数商业选择)仅支持一种类型的数据存储2 3. 表的存储有三个文件:结构+数据+索引2 4 ...

随机推荐

  1. MySQL集群搭建(5)-MHA高可用架构

    1 概述 1.1 MHA 简介 MHA - Master High Availability 是由 Perl 实现的一款高可用程序,出现故障时,MHA 以最小的停机时间(通常10-30秒)执行 mas ...

  2. Linux恢复误删除的文件或者目录

    文章转载自:https://www.jianshu.com/p/662293f12a47 linux不像windows有个回收站,使用rm -rf *基本上文件是找不回来的. 那么问题来了: 对于li ...

  3. CentOS系统一键部署jdk,maven,tomcat,mysql

    #!/bin/bash ####使用方法############### # chmod a+x JdTomK-Auto.sh # source JdTomK-Auto.sh ############# ...

  4. 使用Kuboard界面在k8s上部署SpringCloud项目

    先安装Ingress Controller 安装Ingress Controller后,其他服务设置Ingress后就可以通过设置的域名进行访问了,就不用通过代理的方式或者ip:port的方式进行访问 ...

  5. alertmanager配置文件详解

    global: smtp_smarthost: 'localhost:25' smtp_from: 'alertmanager@example.org' #用于邮件通知的P发件人 route: #每个 ...

  6. 使用Recoding Rules优化性能

    通过PromQL可以实时对Prometheus中采集到的样本数据进行查询,聚合以及其它各种运算操作.而在某些PromQL较为复杂且计算量较大时,直接使用PromQL可能会导致Prometheus响应超 ...

  7. mapboxgl加载tiff

    缘起 近期在项目中遇到这么一个需求,需要在地图上展示一组格网数据,格网大小为2m*2m,地图api用的mapboxgl.起初拿到这个需要感觉很easy,在地图上添加一个fill图层就好啦.把格网面数据 ...

  8. Node.js(一)基本node.js读取删除

    npm init -y(初始化项目) npm uninstall (xxx模块名称)=>(移除模块) var text2=require("./text2"); //解构 c ...

  9. SSM(Spring,SpringMVC,Mybatis)框架整合项目

    快速上手SSM(Spring,SpringMVC,Mybatis)框架整合项目 环境要求: IDEA MySQL 8.0.25 Tomcat 9 Maven 3.6 数据库环境: 创建一个存放书籍数据 ...

  10. JavaScript基本语法(函数与对象)

    3.函数 #①内置函数 内置函数:系统已经声明好了可以直接使用的函数. #[1]弹出警告框 alert("警告框内容");   #[2]弹出确认框 用户点击『确定』返回true,点 ...