【澳门葡京备用网址】储存引擎,第八三章

mysql简介

  数据库(Database)是依据数据结构来组织、存储和治本数据的库房。各种数据库都有三个或多少个例外的API用于创立,访问,管理,搜索和复制所保存的多少。

  关系型数据库是创设在关乎模型基础上的数据库,借助于会集代数等数学概念和措施来管理数据库中的数据。

  Mysql是2个关系型数据库管理系列,在WEB应用方面Mysql是最棒的奥迪Q五DBMS(Relational
Database Management System,关全面据管理连串)APP之一。

一、库操作

第八3章 Mysql,第九3章mysql

1.mysql简介

  数据库(Database)是依照数据结构来组织、存款和储蓄和保管数据的仓库。种种数据库都有多少个或多个例外的API用于创制,访问,管理,寻找和复制所保存的多寡。

  关系型数据库是赤手空拳在论及模型基础上的数据库,借助于集结代数等数学概念和方法来拍卖数据库中的数据。

  Mysql是多少个关系型数据库管理种类,在WEB应用方面Mysql是最佳的奇骏DBMS(Relational
Database Management System,关全面据管理种类)应用软件之壹。

2.mysql安装

  Mysql是跨平台的,选用相应的阳台下载安装文件安装就可以。

#mysql Windows版安装
#1.下载
MySQL Community Server 5.7.16(http://dev.mysql.com/downloads/mysql/)
#2.解压
解压到指定目录
#3.添加环境变量
将MySQL的bin目录路径追加到变值值中
#4.初始化
mysqld --initialize-insecure
#5.启动mysql服务
mysqld
#6.启动mysql客户端并连接mysql服务
mysql -u root -p

澳门葡京备用网址 1

#制作mysql的windows服务(以管理员身份运行cmd)
F:\mysql-5.6.39-winx64\bin\mysqld --install
#移除mysql的windows服务
F:\mysql-5.6.39-winx64\bin\mysqld --remove
#注册成服务后,可以直接执行命令启动和关闭mysql服务
net start mysql
net stop mysql

将mysql服务构建成windows服务

三.mysql软件基本管理

  登陆,设置密码

澳门葡京备用网址 2

初始状态下,管理员root,密码为空,默认只允许从本机登录localhost
设置密码
[[email protected] ~]# mysqladmin -uroot password "123"        设置初始密码 由于原密码为空,因此-p可以不用
[[email protected] ~]# mysqladmin -uroot -p"123" password "456"        修改mysql密码,因为已经有密码了,所以必须输入原密码才能设置新密码

命令格式:
[[email protected] ~]# mysql -h172.31.0.2 -uroot -p456
[[email protected] ~]# mysql -uroot -p
[[email protected] ~]# mysql                    以root用户登录本机,密码为空

View Code

  忘记密码

澳门葡京备用网址 3

#windows平台下,5.7版本mysql,破解密码的两种方式:
#方式一

#1 关闭mysql
#2 在cmd中执行:mysqld --skip-grant-tables
#3 在cmd中执行:mysql
#4 执行如下sql:
update mysql.user set authentication_string=password('') where user = 'root';
flush privileges;
#5 tskill mysqld #或taskkill -f /PID 7832
#6 重新启动mysql

#方式二
#1. 关闭mysql,可以用tskill mysqld将其杀死
#2. 在解压目录下,新建mysql配置文件my.ini
#3. my.ini内容,指定
[mysqld]
skip-grant-tables
#4.启动mysqld
#5.在cmd里直接输入mysql登录,然后操作
update mysql.user set authentication_string=password('') where user='root and host='localhost';
flush privileges;
#6.注释my.ini中的skip-grant-tables,然后启动myqsld,然后就可以以新密码登录了

View Code

 在windows下,为mysql服务指虞诩插文件

#配置文件中的注释可以有中文,但是配置项中不能出现中文
#在mysql的解压目录下,新建my.ini,然后配置
#1. 在执行mysqld命令时,下列配置会生效,即mysql服务启动时生效
[mysqld]
;skip-grant-tables
port=3306
character_set_server=utf8
default-storage-engine=innodb
innodb_file_per_table=1
#解压的目录
basedir=E:\mysql-5.7.19-winx64
#data目录
datadir=E:\my_data #在mysqld --initialize时,就会将初始数据存入此处指定的目录,在初始化之后,启动mysql时,就会去这个目录里找数据


#2. 针对客户端命令的全局配置,当mysql客户端命令执行时,下列配置生效
[client]
port=3306
default-character-set=utf8
user=root
password=123

#3. 只针对mysql这个客户端的配置,2中的是全局配置,而此处的则是只针对mysql这个命令的局部配置
[mysql]
;port=3306
;default-character-set=utf8
user=egon
password=4573

#如果没有[mysql],则用户在执行mysql命令时的配置以[client]为准

   统一字符编码

澳门葡京备用网址 4

#1. 修改配置文件
[mysqld]
default-character-set=utf8 
[client]
default-character-set=utf8 
[mysql]
default-character-set=utf8

#mysql5.5以上:修改方式有所改动
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

#2. 重启服务
#3. 查看修改结果:
\s
show variables like '%char%'

View Code

4.sql语句

  Sql语句主要用于存取数据,查询数据,更新数据和管理数据库系统。

#Sql语句分为3种类型
#1.DDL语句:数据库定义语言: 数据库、表、视图、索引、存储过程,例如CREATE DROP ALTER
#2.DML语句:数据库操纵语言: 插入数据INSERT、删除数据DELETE、更新数据UPDATE、查询数据SELECT
#3.DCL语句:数据库控制语言: 例如控制用户的访问权限GRANT、REVOKE

 5.库操作

  安装并登录mysql后,查看数据库,开掘有如下数据库:

  澳门葡京备用网址 5

#information_schema:虚拟库,不占用磁盘空间,存储的是数据库启动后的一些参数,如用户表信息、列信息、权限信息、字符信息等
#performance_schema:Mysql5.5开始新增一个数据库:主要用于收集数据库服务器性能参数,记录处理查询请求时发生的各种事件、锁等现象
#mysql:授权库,主要存储系统用户的权限信息
#test:Mysql数据库系统自动创建的测试数据库

  创造数据库

#数据库命名规则
#可以由字母、数字、下划线、@、#、$组成
#区分大小写
#唯一性
#不能使用关键字如select、create
#不能单独使用数字
#最长128位

#数据库相关操作

#创建数据库
create database db1 charset utf8;
#查看数据库
show databases;
show create database db1;
select database();
#选择数据库
use database db1;
#修改数据库
alter database db1 charset utf8;
#删除数据库
drop database db1;

6.表操作

  表相关操作

#先切换到库下
use db1;
#创建表
#create table 表名(
字段名1 类型[(宽度) 约束条件],
字段名2 类型[(宽度)约束条件]
);
#在同一张表中,字段名不能相同;宽度和约束条件可选;字段名和类型是必须的;表中的最后一个字段不要加逗号
create table t1(id int,name char);

#查看表
show tables;  #查看表
describe t1;   #查看表结构,可简写为 desc t1
show create table t1\G  #查看表详细结构

#修改表
alter table t1 modify name char(3);
alter table t1 change name name1 char(2);

澳门葡京备用网址 6

1. 修改表名
      ALTER TABLE 表名 
                          RENAME 新表名;

2. 增加字段
      ALTER TABLE 表名
                          ADD 字段名  数据类型 [完整性约束条件…],
                          ADD 字段名  数据类型 [完整性约束条件…];
      ALTER TABLE 表名
                          ADD 字段名  数据类型 [完整性约束条件…]  FIRST;
      ALTER TABLE 表名
                          ADD 字段名  数据类型 [完整性约束条件…]  AFTER 字段名;

3. 删除字段
      ALTER TABLE 表名 
                          DROP 字段名;

4. 修改字段
      ALTER TABLE 表名 
                          MODIFY  字段名 数据类型 [完整性约束条件…];
      ALTER TABLE 表名 
                          CHANGE 旧字段名 新字段名 旧数据类型 [完整性约束条件…];
      ALTER TABLE 表名 
                          CHANGE 旧字段名 新字段名 新数据类型 [完整性约束条件…];

修改表语法
澳门葡京备用网址 7

#1. 修改存储引擎
alter table service engine=innodb;

#2. 添加字段
alter table t1  add name varchar(20) not null;

alter table t1 add stu_num varchar(10) not null after name;  //添加name字段之后

alter table t1 add sex enum('male','female') default 'male' first; //添加到最前面

#3. 删除字段
 alter table t1 drop sex;

alter table service drop mac;

#4. 修改字段类型modify
alter table t1 modify age int(3);
alter table t1 modify id int(11) not null primary key auto_increment;    //修改为主键

#5. 增加约束(针对已有的主键增加auto_increment)
alter table student10 modify id int(11) not null primary key auto_increment;
#ERROR 1068 (42000): Multiple primary key defined

alter table student10 modify id int(11) not null auto_increment;
#Query OK, 0 rows affected (0.01 sec)

#6. 对已经存在的表增加复合主键
alter table service2 add primary key(host_ip,port);        

#7. 增加主键
alter table student1 modify name varchar(10) not null primary key;

#8. 增加主键和自动增长
alter table student1 modify id int not null primary key auto_increment;

#9. 删除主键
#a. 删除自增约束
alter table student10 modify id int(11) not null; 

#b. 删除主键
alter table student10 drop primary key;

示例

#复制表
#复制表结构+记录
create table new_service select * from service;
#只复制表结构
create table new1_service select * from service where 1=2;
create table t4 like employees;

#删除表
drop table t1;

   数据类型:表内部存款和储蓄器放的多少有不相同的品种,各样数据类型都有温馨的上升的幅度,但增长幅度是可选的

数值类型

  整数类型:TINYINT SMALLINT MEDIUMINT INT BIGINT

为该品种钦点宽度时,仅仅只是钦赐询问结果的显得升幅,与积存范围非亲非故,默许的来得上涨的幅度都以在最大值的基础上加壹

澳门葡京备用网址 8

  浮点型

  定点数类型:DEC等同于DECamaroL,浮点类型:FLOAT DOUBLE

  位类型

  BIT(M)能够用来存放多位二进制数,M范围从壹~64,如若不写默感觉1人

#对于位字段需要使用函数读取
bin()显示为二进制
hex()显示为十六进制

日子类型:DATE TIME DATETIME TIMESTAMP YEAOdyssey

澳门葡京备用网址 9

YEAR
            YYYY(1901/2155)

DATE
            YYYY-MM-DD(1000-01-01/9999-12-31)

TIME
            HH:MM:SS('-838:59:59'/'838:59:59')

DATETIME

            YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59    Y)

TIMESTAMP

            YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)

View Code

字符串类型:char,varchar,

澳门葡京备用网址 10

1.CHAR 和 VARCHAR 是最常使用的两种字符串类型。
2.一般来说CHAR(N)用来保存固定长度的字符串,对于 CHAR 类型,N 的范围 为 0 ~ 255
VARCHAR(N)用来保存变长字符类型,对于 VARCHAR 类型,N 的范围为 0 ~ 65 535
CHAR(N)和 VARCHAR(N) 中的 N 都代表字符长度,而非字节长度。
3. char填充空格来满足固定长度,但是在查询时却会很不要脸地删除尾部的空格(装作自己好像没有浪费过空间一样),然后修改sql_mode让其现出原形
4.虽然 CHAR 和 VARCHAR 的存储方式不太相同,但是对于两个字符串的比较,都只比 较其值,忽略 CHAR 值存在的右填充,即使将 SQL _MODE 设置为 PAD_CHAR_TO_FULL_ LENGTH 也一样,,但这不适用于like
5.虽然varchar使用起来较为灵活,但是从整个系统的性能角度来说,char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡
6.#其他字符串系列(效率:char>varchar>text)
TEXT系列 TINYTEXT TEXT MEDIUMTEXT LONGTEXT
BLOB 系列    TINYBLOB BLOB MEDIUMBLOB LONGBLOB 
BINARY系列 BINARY VARBINARY
text:text数据类型用于保存变长的大字符串,可以组多到65535 (2**16 − 1)个字符。
mediumtext:A TEXT column with a maximum length of 16,777,215 (2**24 − 1) characters.
longtext:A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 − 1) characters.

View Code

枚举类型与集中类型

  字段值只可以在给定的限制内选三个值,eum(单选)只可以在加以的限量内选2个值,set(多选)在给定的限定内得以采用叁个或多少个值

Mysql,第八3章mysql 一.mysql简要介绍数据库(Database)是依据数据结构来组织、存款和储蓄和保管数据的库房。每种数据库都有贰个或多少个不一致…

库操作


sql语言:

SQL(Structured Query
Language 即结构化查询语言)
SQL语言主要用来存取数据、查询数据、更新数据和保管关周到据库系统,SQL语言由IBM开辟。SQL语言分为三种档期的顺序:
DDL语句 数据库定义语言:
数据库、表、视图、索引、存款和储蓄进程,比如CREATE DROP ALTE中华V
DML语句 数据库垄断语言:
插入数据INSERT、删除数据DELETE、更新数据UPDATE、查询数据SELECT
DCL语句 数据库控制语言:
比如调节用户的造访权限GRANT、REVOKE

系统数据库:

information_schema
虚拟库,不占用磁盘空间,存款和储蓄的是数据库运转后的一些参数,如用户表消息、列新闻、权限消息、字符新闻等
performance_schema: MySQL
伍.5从头新添3个数据库:重要用以收集数据库服务器品质参数,记录管理查询请求时产生的各样风浪、锁等情景 
mysql: 授权库,首要囤积系统用户的权柄消息
test: MySQL数据库系统活动创立的测试数据库

创建:

  • 语法(help create database)
  • CREATE DATABASE 数据库名 charset utf8; 

  • 数据库命名规则

  • 能够由字母、数字、下划线、@、#、$
    区分大小写
    唯一性
    不能使用关键字如 create select
    不能单独使用数字
    最长128位
    

数据库相关操作:

查看数据库
show databases;
show create database db1;
select database();
选择数据库
USE 数据库名
删除数据库
DORP DATABASE 数据库名;
修改数据库
alter database db1 charset utf8;

mysql安装

  Mysql是跨平台的,选拔相应的阳台下载安装文件安装就能够。

#mysql Windows版安装
#1.下载
MySQL Community Server 5.7.16(http://dev.mysql.com/downloads/mysql/)
#2.解压
解压到指定目录
#3.添加环境变量
将MySQL的bin目录路径追加到变值值中
#4.初始化
mysqld --initialize-insecure
#5.启动mysql服务
mysqld
#6.启动mysql客户端并连接mysql服务
mysql -u root -p

澳门葡京备用网址 11澳门葡京备用网址 12

#制作mysql的windows服务(以管理员身份运行cmd)
F:\mysql-5.6.39-winx64\bin\mysqld --install
#移除mysql的windows服务
F:\mysql-5.6.39-winx64\bin\mysqld --remove
#注册成服务后,可以直接执行命令启动和关闭mysql服务
net start mysql
net stop mysql

将mysql服务构建成windows服务

壹、数据库命名规则:

表操作


 

表也正是文件,表中的一条记下就也正是文件的壹行内容,不一致的是,表中的一条记下有相应的标题,称为表的字段

创建:

语法:
create table 表名(
字段名1 类型[(宽度) 约束条件],
字段名2 类型[(宽度) 约束条件],
字段名3 类型[(宽度) 约束条件]
);

注意:
1. 在同一张表中,字段名是不能相同
2. 宽度和约束条件可选
3. 字段名和类型是必须的

澳门葡京备用网址 13澳门葡京备用网址 14

MariaDB [(none)]> create database db1 charset utf8;

MariaDB [(none)]> use db1;

MariaDB [db1]> create table t1(  
    -> id int, 
    -> name varchar(50),
    -> sex enum('male','female'),
    -> age int(3)
    -> );

MariaDB [db1]> show tables; #查看db1库下所有表名

MariaDB [db1]> desc t1;
+-------+-----------------------+------+-----+---------+-------+
| Field | Type                  | Null | Key | Default | Extra |
+-------+-----------------------+------+-----+---------+-------+
| id    | int(11)               | YES  |     | NULL    |       |
| name  | varchar(50)           | YES  |     | NULL    |       |
| sex   | enum('male','female') | YES  |     | NULL    |       |
| age   | int(3)                | YES  |     | NULL    |       |
+-------+-----------------------+------+-----+---------+-------+

MariaDB [db1]> select id,name,sex,age from t1;
Empty set (0.00 sec)

MariaDB [db1]> select * from t1;
Empty set (0.00 sec)

MariaDB [db1]> select id,name from t1;
Empty set (0.00 sec)

View Code

澳门葡京备用网址 15澳门葡京备用网址 16

MariaDB [db1]> insert into t1 values
    -> (1,'egon',18,'male'),
    -> (2,'alex',81,'female')
    -> ;
MariaDB [db1]> select * from t1;
+------+------+------+--------+
| id   | name | age  | sex    |
+------+------+------+--------+
|    1 | egon |   18 | male   |
|    2 | alex |   81 | female |
+------+------+------+--------+



MariaDB [db1]> insert into t1(id) values 
    -> (3),
    -> (4);
MariaDB [db1]> select * from t1;
+------+------+------+--------+
| id   | name | age  | sex    |
+------+------+------+--------+
|    1 | egon |   18 | male   |
|    2 | alex |   81 | female |
|    3 | NULL | NULL | NULL   |
|    4 | NULL | NULL | NULL   |
+------+------+------+--------+

归纳插入数据

澳门葡京备用网址 17澳门葡京备用网址 18

mysql> create database db1 charset latin1;
mysql> use db1;
mysql> create table t1(name varchar(20));
mysql> show create table t1; #查看表,发现表默认与数据db1的字符编码一致
mysql> insert into t1 values('林'); #插入中文出错,因为latin1不支持中文
ERROR 1366 (HY000): 
mysql> 

#解决方法一:删除库db1,重建db1,字符编码指定为utf8

#解决方法二:修改
mysql> alter table t1 charset utf8; #修改表t1的编码
mysql> insert into t1 values('林'); #虽然t1的编码改了,但是t1的字段name仍然是按照latin1编码创建的
ERROR 1366 (HY000): 
mysql> alter table t1 modify name varchar(20); #需要重新定义下字段name
mysql> insert into t1 values('林');
mysql> select * from t1;
+------+
| name |
+------+
| 林   |
+------+

ps:不要忘记将数据库编码也改成utf8,这样以后在该数据库下创建表时,都默认utf8编码了

#配置文件:http://blog.csdn.net/yipiankongbai/article/details/16937815

乱码难点

澳门葡京备用网址 19澳门葡京备用网址 20

#1. 修改配置文件
[mysqld]
default-character-set=utf8 
[client]
default-character-set=utf8 
[mysql]
default-character-set=utf8

#mysql5.5以上:修改方式有所改动
    [mysqld]
    character-set-server=utf8
    collation-server=utf8_general_ci
    [client]
    default-character-set=utf8
    [mysql]
    default-character-set=utf8

#2. 重启服务
#3. 查看修改结果:
\s
show variables like '%char%'

斩草除根办法

 查看表结构:

MariaDB [db1]> describe t1; #查看表结构,可简写为desc 表名
+-------+-----------------------+------+-----+---------+-------+
| Field | Type                  | Null | Key | Default | Extra |
+-------+-----------------------+------+-----+---------+-------+
| id    | int(11)               | YES  |     | NULL    |       |
| name  | varchar(50)           | YES  |     | NULL    |       |
| sex   | enum('male','female') | YES  |     | NULL    |       |
| age   | int(3)                | YES  |     | NULL    |       |
+-------+-----------------------+------+-----+---------+-------+


MariaDB [db1]> show create table t1\G; #查看表详细结构,可加\G

积存引擎:

mysql中树立的库===>文件夹

库中国建工业总会公司立的表===>文件

现实生活中大家用来囤积数据的文件应当有例外的品类:举个例子存文本用txt类型,存表格用excel,存图片用png等

数据库中的表也相应有不相同的花色,表的花色差异,会对应mysql差异的存取机制,表类型又称之为存款和储蓄引擎。

仓储引擎说白了就是何等存款和储蓄数据、怎么着为存款和储蓄的数码创立目录和怎么样翻新、查询数据等本领的兑现方
法。因为在关周密据库中数据的蕴藏是以表的样式储存的,所以存款和储蓄引擎也得以称为表类型(即存款和储蓄和
操作此表的类型)

在Oracle 和SQL
Server等数据库中只有1种存款和储蓄引擎,全数数据存储管理机制都是一律的。而MySql
数据库提供了三种积攒引擎。用户可以依照差别的供给为数据表采取分裂的蕴藏引擎,用户也得以依照
【澳门葡京备用网址】储存引擎,第八三章。本身的需求编写制定本身的积累引擎

mysql帮助的仓库储存引擎

MariaDB [(none)]> show engines\G  #查看所有支持的存储引擎
MariaDB [(none)]> show variables like 'storage_engine%'; #查看正在使用的存储引擎

澳门葡京备用网址 21澳门葡京备用网址 22

#InnoDB 存储引擎
支持事务,其设计目标主要面向联机事务处理(OLTP)的应用。其
特点是行锁设计、支持外键,并支持类似 Oracle 的非锁定读,即默认读取操作不会产生锁。 从 MySQL 5.5.8 版本开始是默认的存储引擎。
InnoDB 存储引擎将数据放在一个逻辑的表空间中,这个表空间就像黑盒一样由 InnoDB 存储引擎自身来管理。从 MySQL 4.1(包括 4.1)版本开始,可以将每个 InnoDB 存储引擎的 表单独存放到一个独立的 ibd 文件中。此外,InnoDB 存储引擎支持将裸设备(row disk)用 于建立其表空间。
InnoDB 通过使用多版本并发控制(MVCC)来获得高并发性,并且实现了 SQL 标准 的 4 种隔离级别,默认为 REPEATABLE 级别,同时使用一种称为 netx-key locking 的策略来 避免幻读(phantom)现象的产生。除此之外,InnoDB 存储引擎还提供了插入缓冲(insert buffer)、二次写(double write)、自适应哈希索引(adaptive hash index)、预读(read ahead) 等高性能和高可用的功能。
对于表中数据的存储,InnoDB 存储引擎采用了聚集(clustered)的方式,每张表都是按 主键的顺序进行存储的,如果没有显式地在表定义时指定主键,InnoDB 存储引擎会为每一 行生成一个 6 字节的 ROWID,并以此作为主键。
InnoDB 存储引擎是 MySQL 数据库最为常用的一种引擎,Facebook、Google、Yahoo 等 公司的成功应用已经证明了 InnoDB 存储引擎具备高可用性、高性能以及高可扩展性。对其 底层实现的掌握和理解也需要时间和技术的积累。如果想深入了解 InnoDB 存储引擎的工作 原理、实现和应用,可以参考《MySQL 技术内幕:InnoDB 存储引擎》一书。

#MyISAM 存储引擎
不支持事务、表锁设计、支持全文索引,主要面向一些 OLAP 数 据库应用,在 MySQL 5.5.8 版本之前是默认的存储引擎(除 Windows 版本外)。数据库系统 与文件系统一个很大的不同在于对事务的支持,MyISAM 存储引擎是不支持事务的。究其根 本,这也并不难理解。用户在所有的应用中是否都需要事务呢?在数据仓库中,如果没有 ETL 这些操作,只是简单地通过报表查询还需要事务的支持吗?此外,MyISAM 存储引擎的 另一个与众不同的地方是,它的缓冲池只缓存(cache)索引文件,而不缓存数据文件,这与 大多数的数据库都不相同。

#NDB 存储引擎
年,MySQL AB 公司从 Sony Ericsson 公司收购了 NDB 存储引擎。 NDB 存储引擎是一个集群存储引擎,类似于 Oracle 的 RAC 集群,不过与 Oracle RAC 的 share everything 结构不同的是,其结构是 share nothing 的集群架构,因此能提供更高级别的 高可用性。NDB 存储引擎的特点是数据全部放在内存中(从 5.1 版本开始,可以将非索引数 据放在磁盘上),因此主键查找(primary key lookups)的速度极快,并且能够在线添加 NDB 数据存储节点(data node)以便线性地提高数据库性能。由此可见,NDB 存储引擎是高可用、 高性能、高可扩展性的数据库集群系统,其面向的也是 OLTP 的数据库应用类型。

#Memory 存储引擎
正如其名,Memory 存储引擎中的数据都存放在内存中,数据库重 启或发生崩溃,表中的数据都将消失。它非常适合于存储 OLTP 数据库应用中临时数据的临时表,也可以作为 OLAP 数据库应用中数据仓库的维度表。Memory 存储引擎默认使用哈希 索引,而不是通常熟悉的 B+ 树索引。

#Infobright 存储引擎
第三方的存储引擎。其特点是存储是按照列而非行的,因此非常 适合 OLAP 的数据库应用。其官方网站是 http://www.infobright.org/,上面有不少成功的数据 仓库案例可供分析。

#NTSE 存储引擎
网易公司开发的面向其内部使用的存储引擎。目前的版本不支持事务, 但提供压缩、行级缓存等特性,不久的将来会实现面向内存的事务支持。

#BLACKHOLE
黑洞存储引擎,可以应用于主备复制中的分发主库。

MySQL 数据库还有很多其他存储引擎,上述只是列举了最为常用的一些引擎。如果 你喜欢,完全可以编写专属于自己的引擎,这就是开源赋予我们的能力,也是开源的魅 力所在。

介绍

设置:

澳门葡京备用网址 23澳门葡京备用网址 24

# 建表时指定
MariaDB [db1]> create table innodb_t1(id int,name char)engine=innodb;
MariaDB [db1]> create table innodb_t2(id int)engine=innodb;
MariaDB [db1]> show create table innodb_t1;
MariaDB [db1]> show create table innodb_t2;

# 配置文件指定
/etc/my.cnf
[mysqld]
default-storage-engine=INNODB
innodb_file_per_table=1

# 查看
[root@egon db1]# cd /var/lib/mysql/db1/
[root@egon db1]# ls
db.opt  innodb_t1.frm  innodb_t1.ibd  innodb_t2.frm  innodb_t2.ibd

View Code

数据类型:

  存款和储蓄引擎决定了表的门类,而表内部存款和储蓄器放的数码也要有例外的项目,每一种数据类型都有和好的大幅,但幅度是可选的

mysql数据类型大概浏览

澳门葡京备用网址 25澳门葡京备用网址 26

#1. 数字:
    整型:tinyinit  int  bigint
    小数:
        float :在位数比较短的情况下不精准
        double :在位数比较长的情况下不精准
            0.000001230123123123
            存成:0.000001230000

        decimal:(如果用小数,则用推荐使用decimal)
            精准
            内部原理是以字符串形式去存

#2. 字符串:
    char(10):简单粗暴,浪费空间,存取速度快
        root存成root000000
    varchar:精准,节省空间,存取速度慢

    sql优化:创建表时,定长的类型往前放,变长的往后放
                    比如性别           比如地址或描述信息

    >255个字符,超了就把文件路径存放到数据库中。
            比如图片,视频等找一个文件服务器,数据库中只存路径或url。



#3. 时间类型:
    最常用:datetime


#4. 枚举类型与集合类型

View Code

  数值类型:

    整数类型:TINYINT SMALLINT MEDIUMINT INT BIGINT

    成效:存款和储蓄年龄,品级,id,种种数码等

mysql软件基本管理

可以由字母、数字、下划线、@、#、$
区分大小写
唯一性
不能使用关键字如 create select
不能单独使用数字
最长128位

– – 澳门葡京备用网址 27澳门葡京备用网址 28

                tinyint[(m)] [unsigned] [zerofill]

                    小整数,数据类型用于保存一些范围的整数数值范围:
                    有符号:
                        -128 ~ 127
                    无符号:
        ~ 255

                    PS: MySQL中无布尔值,使用tinyint(1)构造。



        ========================================
                int[(m)][unsigned][zerofill]

                    整数,数据类型用于保存一些范围的整数数值范围:
                    有符号:
                            -2147483648 ~ 2147483647
                    无符号:
        ~ 4294967295



        ========================================
                bigint[(m)][unsigned][zerofill]
                    大整数,数据类型用于保存一些范围的整数数值范围:
                    有符号:
                            -9223372036854775808 ~ 9223372036854775807
                    无符号:
         ~  18446744073709551615

    View Code

    ![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)![](https://images.cnblogs.com/OutliningIndicators/ExpandedBlockStart.gif)
        =========有符号和无符号tinyint==========
        #tinyint默认为有符号
        MariaDB [db1]> create table t1(x tinyint); #默认为有符号,即数字前有正负号
        MariaDB [db1]> desc t1;
        MariaDB [db1]> insert into t1 values
            -> (-129),
            -> (-128),
            -> (127),
            -> (128);
        MariaDB [db1]> select * from t1;
        +------+
        | x    |
        +------+
        | -128 | #-129存成了-128
        | -128 | #有符号,最小值为-128
        |  127 | #有符号,最大值127
        |  127 | #128存成了127
        +------+



        #设置无符号tinyint
        MariaDB [db1]> create table t2(x tinyint unsigned);
        MariaDB [db1]> insert into t2 values
            -> (-1),
            -> (0),
            -> (255),
            -> (256);
        MariaDB [db1]> select * from t2;
        +------+
        | x    |
        +------+
        |    0 | -1存成了0
        |    0 | #无符号,最小值为0
        |  255 | #无符号,最大值为255
        |  255 | #256存成了255
        +------+



        ============有符号和无符号int=============
        #int默认为有符号
        MariaDB [db1]> create table t3(x int); #默认为有符号整数
        MariaDB [db1]> insert into t3 values
            -> (-2147483649),
            -> (-2147483648),
            -> (2147483647),
            -> (2147483648);
        MariaDB [db1]> select * from t3;
        +-------------+
        | x           |
        +-------------+
        | -2147483648 | #-2147483649存成了-2147483648
        | -2147483648 | #有符号,最小值为-2147483648
        |  2147483647 | #有符号,最大值为2147483647
        |  2147483647 | #2147483648存成了2147483647
        +-------------+



        #设置无符号int
        MariaDB [db1]> create table t4(x int unsigned);
        MariaDB [db1]> insert into t4 values
            -> (-1),
            -> (0),
            -> (4294967295),
            -> (4294967296);
        MariaDB [db1]> select * from t4;
        +------------+
        | x          |
        +------------+
        |          0 | #-1存成了0
        |          0 | #无符号,最小值为0
        | 4294967295 | #无符号,最大值为4294967295
        | 4294967295 | #4294967296存成了4294967295
        +------------+




        ==============有符号和无符号bigint=============
        MariaDB [db1]> create table t6(x bigint);
        MariaDB [db1]> insert into t5 values  
            -> (-9223372036854775809),
            -> (-9223372036854775808),
            -> (9223372036854775807),
            -> (9223372036854775808);

        MariaDB [db1]> select * from t5;
        +----------------------+
        | x                    |
        +----------------------+
        | -9223372036854775808 |
        | -9223372036854775808 |
        |  9223372036854775807 |
        |  9223372036854775807 |
        +----------------------+



        MariaDB [db1]> create table t6(x bigint unsigned);
        MariaDB [db1]> insert into t6 values  
            -> (-1),
            -> (0),
            -> (18446744073709551615),
            -> (18446744073709551616);

        MariaDB [db1]> select * from t6;
        +----------------------+
        | x                    |
        +----------------------+
        |                    0 |
        |                    0 |
        | 18446744073709551615 |
        | 18446744073709551615 |
        +----------------------+




        ======用zerofill测试整数类型的显示宽度=============
        MariaDB [db1]> create table t7(x int(3) zerofill);
        MariaDB [db1]> insert into t7 values
            -> (1),
            -> (11),
            -> (111),
            -> (1111);
        MariaDB [db1]> select * from t7;
        +------+
        | x    |
        +------+
        |  001 |
        |  011 |
        |  111 |
        | 1111 | #超过宽度限制仍然可以存
        +------+

        验证

    View Code

  澳门葡京备用网址 29

  • int的储存宽度是陆个Bytes,即33个bit,即2**32

    无符号最大值为:42949672九陆-1

    有暗号最大值:2147483648-壹

    有号子和无符号的最大数字须求的显示涨幅均为十,而针对有标识的细微值则须求13位才干显得完全,所以int类型暗中同意的来得上升的幅度为1一是13分合理的

    最终:整形类型,其实远非须求钦命显示涨幅,使用默许的就ok

  • 浮点类型

    • FLOAT
      DOUBLE DECIMAL
    • 澳门葡京备用网址 30澳门葡京备用网址 31

      #FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]
      
      定义:
              单精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30
      
      有符号:
                 -3.402823466E+38 to -1.175494351E-38,
                 1.175494351E-38 to 3.402823466E+38
      无符号:
                 1.175494351E-38 to 3.402823466E+38
      
        精确度: 
                   **** 随着小数的增多,精度变得不准确 ****


        ======================================
        #DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]

        定义:
                   双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30

        有符号:
                   -1.7976931348623157E+308 to -2.2250738585072014E-308
                   2.2250738585072014E-308 to 1.7976931348623157E+308

        无符号:
                   2.2250738585072014E-308 to 1.7976931348623157E+308

        精确度:
                   ****随着小数的增多,精度比float要高,但也会变得不准确 ****

        ======================================
        decimal[(m[,d])] [unsigned] [zerofill]

        定义:
                  准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。


        精确度:
                   **** 随着小数的增多,精度始终准确 ****
                   对于精确数值计算时需要用此类型
                   decaimal能够存储精确值的原因在于其内部按照字符串存储。

    View Code
  • 位类型 BIT 

    • BIT(M)能够用来存放在多位2进制数,M范围从壹~6四,假若不写默感觉一人。
        注意:对于位字段必要使用函数读取
            bin()展现为二进制
            hex()展现为十6进制
    • 澳门葡京备用网址 32澳门葡京备用网址 33

      MariaDB [db1]> create table t9(id bit);
      MariaDB [db1]> desc t9; #bit默认宽度为1
      +-------+--------+------+-----+---------+-------+
      | Field | Type   | Null | Key | Default | Extra |
      +-------+--------+------+-----+---------+-------+
      | id    | bit(1) | YES  |     | NULL    |       |
      +-------+--------+------+-----+---------+-------+
      
      MariaDB [db1]> insert into t9 values(8);
      MariaDB [db1]> select * from t9; #直接查看是无法显示二进制位的
      +------+
      | id   |
      +------+
      |     |
      +------+
      MariaDB [db1]> select bin(id),hex(id) from t9; #需要转换才能看到
      +---------+---------+
      | bin(id) | hex(id) |
      +---------+---------+
      | 1       | 1       |
      +---------+---------+
      
      MariaDB [db1]> alter table t9 modify id bit(5);
      MariaDB [db1]> insert into t9 values(8);
      MariaDB [db1]> select bin(id),hex(id) from t9;
      +---------+---------+
      | bin(id) | hex(id) |
      +---------+---------+
      | 1       | 1       |
      | 1000    | 8       |
      +---------+---------+
      
      验证
      

      View Code

日期类型:

DATE
TIME DATETIME TIMESTAMP
YEAR 

    • 澳门葡京备用网址 34澳门葡京备用网址 35

      YEAR
                  YYYY(1901/2155)
      
              DATE
                  YYYY-MM-DD(1000-01-01/9999-12-31)
      
              TIME
                  HH:MM:SS('-838:59:59'/'838:59:59')
      
              DATETIME
      
                  YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59    Y)
      
              TIMESTAMP
      
                  YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)
      

      View Code

      澳门葡京备用网址 36澳门葡京备用网址 37

      ============year===========
      MariaDB [db1]> create table t10(born_year year); #无论year指定何种宽度,最后都默认是year(4)
      MariaDB [db1]> insert into t10 values  
          -> (1900),
          -> (1901),
          -> (2155),
          -> (2156);
      MariaDB [db1]> select * from t10;
      +-----------+
      | born_year |
      +-----------+
      |      0000 |
      |      1901 |
      |      2155 |
      |      0000 |
      +-----------+
      
        ============date,time,datetime===========
        MariaDB [db1]> create table t11(d date,t time,dt datetime);
        MariaDB [db1]> desc t11;
        +-------+----------+------+-----+---------+-------+
        | Field | Type     | Null | Key | Default | Extra |
        +-------+----------+------+-----+---------+-------+
        | d     | date     | YES  |     | NULL    |       |
        | t     | time     | YES  |     | NULL    |       |
        | dt    | datetime | YES  |     | NULL    |       |
        +-------+----------+------+-----+---------+-------+

        MariaDB [db1]> insert into t11 values(now(),now(),now());
        MariaDB [db1]> select * from t11;
        +------------+----------+---------------------+
        | d          | t        | dt                  |
        +------------+----------+---------------------+
        | 2017-07-25 | 16:26:54 | 2017-07-25 16:26:54 |
        +------------+----------+---------------------+



        ============timestamp===========
        MariaDB [db1]> create table t12(time timestamp);
        MariaDB [db1]> insert into t12 values();
        MariaDB [db1]> insert into t12 values(null);
        MariaDB [db1]> select * from t12;
        +---------------------+
        | time                |
        +---------------------+
        | 2017-07-25 16:29:17 |
        | 2017-07-25 16:30:01 |
        +---------------------+



        ============注意啦,注意啦,注意啦===========
        1. 单独插入时间时,需要以字符串的形式,按照对应的格式插入
        2. 插入年份时,尽量使用4位值
        3. 插入两位年份时,<=69,以20开头,比如50,  结果2050      
                        >=70,以19开头,比如71,结果1971
        MariaDB [db1]> create table t12(y year);
        MariaDB [db1]> insert into t12 values  
            -> (50),
            -> (71);
        MariaDB [db1]> select * from t12;
        +------+
        | y    |
        +------+
        | 2050 |
        | 1971 |
        +------+



        ============综合练习===========
        MariaDB [db1]> create table student(
            -> id int,
            -> name varchar(20),
            -> born_year year,
            -> birth date,
            -> class_time time,
            -> reg_time datetime);

        MariaDB [db1]> insert into student values
            -> (1,'alex',"1995","1995-11-11","11:11:11","2017-11-11 11:11:11"),
            -> (2,'egon',"1997","1997-12-12","12:12:12","2017-12-12 12:12:12"),
            -> (3,'wsb',"1998","1998-01-01","13:13:13","2017-01-01 13:13:13");

        MariaDB [db1]> select * from student;
        +------+------+-----------+------------+------------+---------------------+
        | id   | name | born_year | birth      | class_time | reg_time            |
        +------+------+-----------+------------+------------+---------------------+
        |    1 | alex |      1995 | 1995-11-11 | 11:11:11   | 2017-11-11 11:11:11 |
        |    2 | egon |      1997 | 1997-12-12 | 12:12:12   | 2017-12-12 12:12:12 |
        |    3 | wsb  |      1998 | 1998-01-01 | 13:13:13   | 2017-01-01 13:13:13 |
        +------+------+-----------+------------+------------+---------------------+

        验证

    View Code

-   ![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)![](https://images.cnblogs.com/OutliningIndicators/ExpandedBlockStart.gif)
        在实际应用的很多场景中,MySQL的这两种日期类型都能够满足我们的需要,存储精度都为秒,但在某些情况下,会展现出他们各自的优劣。下面就来总结一下两种日期类型的区别。

        1.DATETIME的日期范围是1001——9999年,TIMESTAMP的时间范围是1970——2038年。

        2.DATETIME存储时间与时区无关,TIMESTAMP存储时间与时区有关,显示的值也依赖于时区。在mysql服务器,操作系统以及客户端连接都有时区的设置。

        3.DATETIME使用8字节的存储空间,TIMESTAMP的存储空间为4字节。因此,TIMESTAMP比DATETIME的空间利用率更高。

        4.DATETIME的默认值为null;TIMESTAMP的字段默认不为空(not null),默认值为当前时间(CURRENT_TIMESTAMP),如果不做特殊处理,并且update语句中没有指定该列的更新值,则默认更新为当前时间。

        datetime与timestamp的区别

    datetime与timestamp的区别

字符串类型:

    • 澳门葡京备用网址 38澳门葡京备用网址 39

      #官网:https://dev.mysql.com/doc/refman/5.7/en/char.html
      #注意:char和varchar括号内的参数指的都是字符的长度
      
      #char类型:定长,简单粗暴,浪费空间,存取速度快
          字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)
          存储:
              存储char类型的值时,会往右填充空格来满足长度
              例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储
      
          检索:
              在检索或者说查询时,查出的结果会自动删除尾部的空格,除非我们打开pad_char_to_full_length SQL模式(SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';)
      
      #varchar类型:变长,精准,节省空间,存取速度慢
          字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8:https://dev.mysql.com/doc/refman/5.7/en/column-count-limit.html)
          存储:
              varchar类型存储数据的真实内容,不会用空格填充,如果'ab  ',尾部的空格也会被存起来
              强调:varchar类型会在真实数据前加1-2Bytes的前缀,该前缀用来表示真实数据的bytes字节数(1-2Bytes最大表示65535个数字,正好符合mysql对row的最大字节限制,即已经足够使用)
              如果真实的数据<255bytes则需要1Bytes的前缀(1Bytes=8bit 2**8最大表示的数字为255)
              如果真实的数据>255bytes则需要2Bytes的前缀(2Bytes=16bit 2**16最大表示的数字为65535)
      
          检索:
              尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容
      

      View Code

      澳门葡京备用网址 40澳门葡京备用网址 41

      #官网:https://dev.mysql.com/doc/refman/5.7/en/char.html
      CHAR 和 VARCHAR 是最常使用的两种字符串类型。
      一般来说
      CHAR(N)用来保存固定长度的字符串,对于 CHAR 类型,N 的范围 为 0 ~ 255
      VARCHAR(N)用来保存变长字符类型,对于 VARCHAR 类型,N 的范围为 0 ~ 65 535
      CHAR(N)和 VARCHAR(N) 中的 N 都代表字符长度,而非字节长度。
      ps:对于 MySQL 4.1 之前的版本,如 MySQL 3.23 和 MySQL 4.0,CHAR(N)和 VARCHAR (N)中的 N 代表字节长度。
      
      #CHAR类型
      对于 CHAR 类型的字符串,MySQL 数据库会自动对存储列的右边进行填充(Right Padded)操作,直到字符串达到指定的长度 N。而在读取该列时,MySQL 数据库会自动将 填充的字符删除。有一种情况例外,那就是显式地将 SQL_MODE 设置为 PAD_CHAR_TO_ FULL_LENGTH,例如:
      mysql> CREATE TABLE t ( a CHAR(10));
            Query OK, 0 rows affected (0.03 sec)
      mysql> INSERT INTO t SELECT 'abc';
            Query OK, 1 row affected (0.03 sec)
            Records: 1  Duplicates: 0  Warnings: 0
      mysql> SELECT a,HEX(a),LENGTH(a) FROM t\G;
            *************************** 1. row ***************************
                    a: abc
               HEX(a): 616263
            LENGTH (a): 3
      row in set (0.00 sec)
            mysql> SET SQL_MODE='PAD_CHAR_TO_FULL_LENGTH';
            Query OK, 0 rows affected (0.00 sec)
      mysql> SELECT a,HEX(a),LENGTH(a) FROM t\G;
            *************************** 1. row ***************************
                    a: abc
               HEX(a): 61626320202020202020
            LENGTH (a): 10
      row in set (0.00 sec)
      
      在上述这个例子中,先创建了一张表 t,a 列的类型为 CHAR(10)。然后通过 INSERT语句插入值“abc”,因为 a 列的类型为 CHAR 型,所以会自动在后面填充空字符串,使其长 度为 10。接下来在通过 SELECT 语句取出数据时会将 a 列右填充的空字符移除,从而得到 值“abc”。通过 LENGTH 函数看到 a 列的字符长度为 3 而非 10。
      接着我们将 SQL_MODE 显式地设置为 PAD_CHAR_TO_FULL_LENGTH。这时再通过 SELECT 语句进行查询时,得到的结果是“abc ”,abc 右边有 7 个填充字符 0x20,并通 过 HEX 函数得到了验证。这次 LENGTH 函数返回的长度为 10。需要注意的是,LENGTH 函数返回的是字节长度,而不是字符长度。对于多字节字符集,CHAR(N)长度的列最多 可占用的字节数为该字符集单字符最大占用字节数 *N。例如,对于 utf8 下,CHAR(10)最 多可能占用 30 个字节。通过对多字节字符串使用 CHAR_LENGTH 函数和 LENGTH 函数, 可以发现两者的不同,示例如下:
      mysql> SET NAMES gbk;
           Query OK, 0 rows affected (0.03 sec)
      mysql> SELECT @a:='MySQL 技术内幕 '; Query OK, 0 rows affected (0.03 sec)
      mysql> SELECT @a,HEX(@a),LENGTH(@a),CHAR_LENGTH(@a)\G; ***************************** 1. row **************************** a: MySQL 技术内幕
      HEX(a): 4D7953514CBCBCCAF5C4DAC4BB
      LENGTH (a): 13
      CHAR_LENGTH(a): 9
      row in set (0.00 sec)
      
      变 量 @ a 是 g b k 字 符 集 的 字 符 串 类 型 , 值 为 “ M y S Q L 技 术 内 幕 ”, 十 六 进 制 为 0x4D7953514CBCBCCAF5C4DAC4BB,LENGTH 函数返回 13,即该字符串占用 13 字节, 因为 gbk 字符集中的中文字符占用两个字节,因此一共占用 13 字节。CHAR_LENGTH 函数 返回 9,很显然该字符长度为 9。
      
        #VARCHAR类型
        VARCHAR 类型存储变长字段的字符类型,与 CHAR 类型不同的是,其存储时需要在 前缀长度列表加上实际存储的字符,该字符占用 1 ~ 2 字节的空间。当存储的字符串长度小 于 255 字节时,其需要 1 字节的空间,当大于 255 字节时,需要 2 字节的空间。所以,对 于单字节的 latin1 来说,CHAR(10)和 VARCHAR(10)最大占用的存储空间是不同的, CHAR(10)占用 10 个字节这是毫无疑问的,而 VARCHAR(10)的最大占用空间数是 11 字节,因为其需要 1 字节来存放字符长度。
        -------------------------------------------------
        注意 对于有些多字节的字符集类型,其 CHAR 和 VARCHAR 在存储方法上是一样的,同样 需要为长度列表加上字符串的值。对于 GBK 和 UTF-8 这些字符类型,其有些字符是以 1 字节 存放的,有些字符是按 2 或 3 字节存放的,因此同样需要 1 ~ 2 字节的空间来存储字符的长 度。
        -------------------------------------------------
        虽然 CHAR 和 VARCHAR 的存储方式不太相同,但是对于两个字符串的比较,都只比 较其值,忽略 CHAR 值存在的右填充,即使将 SQL _MODE 设置为 PAD_CHAR_TO_FULL_ LENGTH 也一样,例如:
        mysql> CREATE TABLE t ( a CHAR(10), b VARCHAR(10));
            Query OK, 0 rows affected (0.01 sec)
        mysql> INSERT INTO t SELECT 'a','a';
            Query OK, 1 row affected (0.00 sec)
            Records: 1  Duplicates: 0  Warnings: 0
        mysql> SELECT a=b FROM t\G;
            *************************** 1. row ***************************
            a=b: 1
        row in set (0.00 sec)
            mysql> SET SQL_MODE='PAD_CHAR_TO_FULL_LENGTH';
            Query OK, 0 rows affected (0.00 sec)
        mysql> SELECT a=b FROM t\G;
            *************************** 1. row ***************************
            a=b: 1
        row in set (0.00 sec)

        官网详解

    官网

-   ![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)![](https://images.cnblogs.com/OutliningIndicators/ExpandedBlockStart.gif)
        #常用字符串系列:char与varchar
        注:虽然varchar使用起来较为灵活,但是从整个系统的性能角度来说,char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡

        #其他字符串系列(效率:char>varchar>text)
        TEXT系列 TINYTEXT TEXT MEDIUMTEXT LONGTEXT
        BLOB 系列    TINYBLOB BLOB MEDIUMBLOB LONGBLOB 
        BINARY系列 BINARY VARBINARY

        text:text数据类型用于保存变长的大字符串,可以组多到65535 (2**16 − 1)个字符。
        mediumtext:A TEXT column with a maximum length of 16,777,215 (2**24 − 1) characters.
        longtext:A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 − 1) characters.

    总结

枚举类型与集中类型:

    • 字段的值只幸亏加以范围中挑选,如单选框,多选框
      enum 单选 只还好给定的范围内选二个值,如性别 sex
      男male/女female
      set 多选
      在加以的限定内得以选用一个或一个上述的值(爱好一,爱好二,爱好叁…)
    • 澳门葡京备用网址 42澳门葡京备用网址 43
      枚举类型(enum)
                  An ENUM column can have a maximum of 65,535 distinct elements. (The practical limit is less than 3000.)
                  示例:
                      CREATE TABLE shirts (
                          name VARCHAR(40),
                          size ENUM('x-small', 'small', 'medium', 'large', 'x-large')
                      );
                      INSERT INTO shirts (name, size) VALUES ('dress shirt','large'), ('t-shirt','medium'),('polo shirt','small');
      
                    集合类型(set)
                    A SET column can have a maximum of 64 distinct members.
                    示例:
                        CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));
                        INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');

    View Code

    ![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)![](https://images.cnblogs.com/OutliningIndicators/ExpandedBlockStart.gif)
        MariaDB [db1]> create table consumer( 
            -> name varchar(50),
            -> sex enum('male','female'),
            -> level enum('vip1','vip2','vip3','vip4','vip5'), #在指定范围内,多选一
            -> hobby set('play','music','read','study') #在指定范围内,多选多
            -> );

        MariaDB [db1]> insert into consumer values  
            -> ('egon','male','vip5','read,study'),
            -> ('alex','female','vip1','girl');

        MariaDB [db1]> select * from consumer;
        +------+--------+-------+------------+
        | name | sex    | level | hobby      |
        +------+--------+-------+------------+
        | egon | male   | vip5  | read,study |
        | alex | female | vip1  |            |
        +------+--------+-------+------------+

        验证

    View Code

完整性约束:

封锁标准与数据类型的肥瘦同样,都以可选参数

功用:用于保障数据的完整性和一致性

PRIMARY KEY (PK)    标识该字段为该表的主键,可以唯一的标识记录
FOREIGN KEY (FK)    标识该字段为该表的外键
NOT NULL    标识该字段不能为空
UNIQUE KEY (UK)    标识该字段的值是唯一的
AUTO_INCREMENT    标识该字段的值自动增长(整数类型,而且为主键)
DEFAULT    为该字段设置默认值

UNSIGNED 无符号
ZEROFILL 使用0填充

1. 是否允许为空,默认NULL,可设置NOT NULL,字段不允许为空,必须赋值
2. 字段是否有默认值,缺省的默认值是NULL,如果插入记录时不给字段赋值,此字段使用默认值
sex enum('male','female') not null default 'male'
age int unsigned NOT NULL default 20 必须为正值(无符号) 不允许为空 默认是20
3. 是否是key
主键 primary key
外键 foreign key
索引 (index,unique...)

not null 与 defalut:

    • 是不是可空,null表示空,非字符串
      not null – 不可空
      null – 可空

      暗中同意值,成立列时能够内定暗中同意值,当插入数据时要是未主动设置,则自动加多暗中同意值
      create table tb1(
      nid int not null defalut 2,
      num int not null
      )

    • 澳门葡京备用网址 44澳门葡京备用网址 45

      ==================not null====================
      mysql> create table t1(id int); #id字段默认可以插入空
      mysql> desc t1;
      +-------+---------+------+-----+---------+-------+
      | Field | Type    | Null | Key | Default | Extra |
      +-------+---------+------+-----+---------+-------+
      | id    | int(11) | YES  |     | NULL    |       |
      +-------+---------+------+-----+---------+-------+
      mysql> insert into t1 values(); #可以插入空
      
        mysql> create table t2(id int not null); #设置字段id不为空
        mysql> desc t2;
        +-------+---------+------+-----+---------+-------+
        | Field | Type    | Null | Key | Default | Extra |
        +-------+---------+------+-----+---------+-------+
        | id    | int(11) | NO   |     | NULL    |       |
        +-------+---------+------+-----+---------+-------+
        mysql> insert into t2 values(); #不能插入空
        ERROR 1364 (HY000): Field 'id' doesn't have a default value



        ==================default====================
        #设置id字段有默认值后,则无论id字段是null还是not null,都可以插入空,插入空默认填入default指定的默认值
        mysql> create table t3(id int default 1);
        mysql> alter table t3 modify id int not null default 1;



        ==================综合练习====================
        mysql> create table student(
            -> name varchar(20) not null,
            -> age int(3) unsigned not null default 18,
            -> sex enum('male','female') default 'male',
            -> hobby set('play','study','read','music') default 'play,music'
            -> );
        mysql> desc student;
        +-------+------------------------------------+------+-----+------------+-------+
        | Field | Type                               | Null | Key | Default    | Extra |
        +-------+------------------------------------+------+-----+------------+-------+
        | name  | varchar(20)                        | NO   |     | NULL       |       |
        | age   | int(3) unsigned                    | NO   |     | 18         |       |
        | sex   | enum('male','female')              | YES  |     | male       |       |
        | hobby | set('play','study','read','music') | YES  |     | play,music |       |
        +-------+------------------------------------+------+-----+------------+-------+
        mysql> insert into student(name) values('egon');
        mysql> select * from student;
        +------+-----+------+------------+
        | name | age | sex  | hobby      |
        +------+-----+------+------------+
        | egon |  18 | male | play,music |
        +------+-----+------+------------+

        验证

    View Code

unique:

  • 澳门葡京备用网址 46澳门葡京备用网址 47
    ============设置唯一约束 UNIQUE===============
    方法一:
    create table department1(
    id int,
    name varchar(20) unique,
    comment varchar(100)
    );
    
    方法二:
    create table department2(
    id int,
    name varchar(20),
    comment varchar(100),
    constraint uk_name unique(name)
    );


    mysql> insert into department1 values(1,'IT','技术');
    Query OK, 1 row affected (0.00 sec)
    mysql> insert into department1 values(1,'IT','技术');
    ERROR 1062 (23000): Duplicate entry 'IT' for key 'name'

View Code

![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)![](https://images.cnblogs.com/OutliningIndicators/ExpandedBlockStart.gif)
    mysql> create table t1(id int not null unique);
    Query OK, 0 rows affected (0.02 sec)

    mysql> desc t1;
    +-------+---------+------+-----+---------+-------+
    | Field | Type    | Null | Key | Default | Extra |
    +-------+---------+------+-----+---------+-------+
    | id    | int(11) | NO   | PRI | NULL    |       |
    +-------+---------+------+-----+---------+-------+
    row in set (0.00 sec)

    not null+unique的化学反应

not null+unique的化学反应
  • 澳门葡京备用网址 48澳门葡京备用网址 49

    create table service(
    id int primary key auto_increment,
    name varchar(20),
    host varchar(15) not null,
    port int not null,
    unique(host,port) #联合唯一
    );
    
    mysql> insert into service values
        -> (1,'nginx','192.168.0.10',80),
        -> (2,'haproxy','192.168.0.20',80),
        -> (3,'mysql','192.168.0.30',3306)
        -> ;
    Query OK, 3 rows affected (0.01 sec)
    Records: 3  Duplicates: 0  Warnings: 0
    
    mysql> insert into service(name,host,port) values('nginx','192.168.0.10',80);
    ERROR 1062 (23000): Duplicate entry '192.168.0.10-80' for key 'host'
    
    联合唯一
    

    同步唯1

primarykey:

    • primary key字段的值不为空且唯一

      二个表中能够:

      单列做主键
      多列做主键(复合主键)

      但一个表内只好有叁个主键primary key

    • 澳门葡京备用网址 50澳门葡京备用网址 51

      ============单列做主键===============
      #方法一:not null+unique
      create table department1(
      id int not null unique, #主键
      name varchar(20) not null unique,
      comment varchar(100)
      );
      
      mysql> desc department1;
      +---------+--------------+------+-----+---------+-------+
      | Field   | Type         | Null | Key | Default | Extra |
      +---------+--------------+------+-----+---------+-------+
      | id      | int(11)      | NO   | PRI | NULL    |       |
      | name    | varchar(20)  | NO   | UNI | NULL    |       |
      | comment | varchar(100) | YES  |     | NULL    |       |
      +---------+--------------+------+-----+---------+-------+
      rows in set (0.01 sec)
      
      #方法二:在某一个字段后用primary key
      create table department2(
      id int primary key, #主键
      name varchar(20),
      comment varchar(100)
      );
      
      mysql> desc department2;
      +---------+--------------+------+-----+---------+-------+
      | Field   | Type         | Null | Key | Default | Extra |
      +---------+--------------+------+-----+---------+-------+
      | id      | int(11)      | NO   | PRI | NULL    |       |
      | name    | varchar(20)  | YES  |     | NULL    |       |
      | comment | varchar(100) | YES  |     | NULL    |       |
      +---------+--------------+------+-----+---------+-------+
      rows in set (0.00 sec)
      
      #方法三:在所有字段后单独定义primary key
      create table department3(
      id int,
      name varchar(20),
      comment varchar(100),
      constraint pk_name primary key(id); #创建主键并为其命名pk_name
      
      mysql> desc department3;
      +---------+--------------+------+-----+---------+-------+
      | Field   | Type         | Null | Key | Default | Extra |
      +---------+--------------+------+-----+---------+-------+
      | id      | int(11)      | NO   | PRI | NULL    |       |
      | name    | varchar(20)  | YES  |     | NULL    |       |
      | comment | varchar(100) | YES  |     | NULL    |       |
      +---------+--------------+------+-----+---------+-------+
      rows in set (0.01 sec)
      
      单列主键
      

      单列主键

      澳门葡京备用网址 52澳门葡京备用网址 53

      ==================多列做主键================
      create table service(
      ip varchar(15),
      port char(5),
      service_name varchar(10) not null,
      primary key(ip,port)
      );
      
        mysql> desc service;
        +--------------+-------------+------+-----+---------+-------+
        | Field        | Type        | Null | Key | Default | Extra |
        +--------------+-------------+------+-----+---------+-------+
        | ip           | varchar(15) | NO   | PRI | NULL    |       |
        | port         | char(5)     | NO   | PRI | NULL    |       |
        | service_name | varchar(10) | NO   |     | NULL    |       |
        +--------------+-------------+------+-----+---------+-------+
        rows in set (0.00 sec)

        mysql> insert into service values
            -> ('172.16.45.10','3306','mysqld'),
            -> ('172.16.45.11','3306','mariadb')
            -> ;
        Query OK, 2 rows affected (0.00 sec)
        Records: 2  Duplicates: 0  Warnings: 0

        mysql> insert into service values ('172.16.45.10','3306','nginx');
        ERROR 1062 (23000): Duplicate entry '172.16.45.10-3306' for key 'PRIMARY'

        多列主键

    多列主键

auto_increment:

    • 封锁字段为自发性拉长,被封锁的字段必须同时被key约束
    • 澳门葡京备用网址 54澳门葡京备用网址 55

      #不指定id,则自动增长
      create table student(
      id int primary key auto_increment,
      name varchar(20),
      sex enum('male','female') default 'male'
      );
      
      mysql> desc student;
      +-------+-----------------------+------+-----+---------+----------------+
      | Field | Type                  | Null | Key | Default | Extra          |
      +-------+-----------------------+------+-----+---------+----------------+
      | id    | int(11)               | NO   | PRI | NULL    | auto_increment |
      | name  | varchar(20)           | YES  |     | NULL    |                |
      | sex   | enum('male','female') | YES  |     | male    |                |
      +-------+-----------------------+------+-----+---------+----------------+
      mysql> insert into student(name) values
          -> ('egon'),
          -> ('alex')
          -> ;
      
      mysql> select * from student;
      +----+------+------+
      | id | name | sex  |
      +----+------+------+
      |  1 | egon | male |
      |  2 | alex | male |
      +----+------+------+
      
        #也可以指定id
        mysql> insert into student values(4,'asb','female');
        Query OK, 1 row affected (0.00 sec)

        mysql> insert into student values(7,'wsb','female');
        Query OK, 1 row affected (0.00 sec)

        mysql> select * from student;
        +----+------+--------+
        | id | name | sex    |
        +----+------+--------+
        |  1 | egon | male   |
        |  2 | alex | male   |
        |  4 | asb  | female |
        |  7 | wsb  | female |
        +----+------+--------+


        #对于自增的字段,在用delete删除后,再插入值,该字段仍按照删除前的位置继续增长
        mysql> delete from student;
        Query OK, 4 rows affected (0.00 sec)

        mysql> select * from student;
        Empty set (0.00 sec)

        mysql> insert into student(name) values('ysb');
        mysql> select * from student;
        +----+------+------+
        | id | name | sex  |
        +----+------+------+
        |  8 | ysb  | male |
        +----+------+------+

        #应该用truncate清空表,比起delete一条一条地删除记录,truncate是直接清空表,在删除大表时用它
        mysql> truncate student;
        Query OK, 0 rows affected (0.01 sec)

        mysql> insert into student(name) values('egon');
        Query OK, 1 row affected (0.01 sec)

        mysql> select * from student;
        +----+------+------+
        | id | name | sex  |
        +----+------+------+
        |  1 | egon | male |
        +----+------+------+
        row in set (0.00 sec)

    View Code

    ![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)![](https://images.cnblogs.com/OutliningIndicators/ExpandedBlockStart.gif)
        #在创建完表后,修改自增字段的起始值
        mysql> create table student(
            -> id int primary key auto_increment,
            -> name varchar(20),
            -> sex enum('male','female') default 'male'
            -> );

        mysql> alter table student auto_increment=3;

        mysql> show create table student;
        .......
        ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8

        mysql> insert into student(name) values('egon');
        Query OK, 1 row affected (0.01 sec)

        mysql> select * from student;
        +----+------+------+
        | id | name | sex  |
        +----+------+------+
        |  3 | egon | male |
        +----+------+------+
        row in set (0.00 sec)

        mysql> show create table student;
        .......
        ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8


        #也可以创建表时指定auto_increment的初始值,注意初始值的设置为表选项,应该放到括号外
        create table student(
        id int primary key auto_increment,
        name varchar(20),
        sex enum('male','female') default 'male'
        )auto_increment=3;




        #设置步长
        sqlserver:自增步长
            基于表级别
            create table t1(
                id int。。。
            )engine=innodb,auto_increment=2 步长=2 default charset=utf8

        mysql自增的步长:
            show session variables like 'auto_inc%';

            #基于会话级别
            set session auth_increment_increment=2 #修改会话级别的步长

            #基于全局级别的
            set global auth_increment_increment=2 #修改全局级别的步长(所有会话都生效)


        #!!!注意了注意了注意了!!!
        If the value of auto_increment_offset is greater than that of auto_increment_increment, the value of auto_increment_offset is ignored. 
        翻译:如果auto_increment_offset的值大于auto_increment_increment的值,则auto_increment_offset的值会被忽略 
        比如:设置auto_increment_offset=3,auto_increment_increment=2




        mysql> set global auto_increment_increment=5;
        Query OK, 0 rows affected (0.00 sec)

        mysql> set global auto_increment_offset=3;
        Query OK, 0 rows affected (0.00 sec)

        mysql> show variables like 'auto_incre%'; #需要退出重新登录
        +--------------------------+-------+
        | Variable_name            | Value |
        +--------------------------+-------+
        | auto_increment_increment | 1     |
        | auto_increment_offset    | 1     |
        +--------------------------+-------+



        create table student(
        id int primary key auto_increment,
        name varchar(20),
        sex enum('male','female') default 'male'
        );

        mysql> insert into student(name) values('egon1'),('egon2'),('egon3');
        mysql> select * from student;
        +----+-------+------+
        | id | name  | sex  |
        +----+-------+------+
        |  3 | egon1 | male |
        |  8 | egon2 | male |
        | 13 | egon3 | male |
        +----+-------+------+

        步长increment与起始偏移量offset:auto_increment_increment,auto_increment_offset

    步长increment与起始偏移量offset:auto\_increment\_increment,auto\_increment\_offset

  foreign key:

    • 确立表之间的涉嫌
    • 例子:
    • 职员和工人新闻表有四个字段:工号  姓名  部门

      信用合作社有三个机构,可是有一个亿的职工,那表示部门那几个字段须求再行存款和储蓄,部门名字越长,越浪费

      涸泽而渔办法:

      咱俩完全能够定义多个机关表

      下一场让职工音信表关联该表,如何关联,即foreign key

    • 澳门葡京备用网址 56澳门葡京备用网址 57

      #表类型必须是innodb存储引擎,且被关联的字段,即references指定的另外一个表的字段,必须保证唯一
      create table department(
      id int primary key,
      name varchar(20) not null
      )engine=innodb;
      
      #dpt_id外键,关联父表(department主键id),同步更新,同步删除
      create table employee(
      id int primary key,
      name varchar(20) not null,
      dpt_id int,
      constraint fk_name foreign key(dpt_id)
      references department(id)
      on delete cascade
      on update cascade 
      )engine=innodb;
      
        #先往父表department中插入记录
        insert into department values
        (1,'欧德博爱技术有限事业部'),
        (2,'艾利克斯人力资源部'),
        (3,'销售部');


        #再往子表employee中插入记录
        insert into employee values
        (1,'egon',1),
        (2,'alex1',2),
        (3,'alex2',2),
        (4,'alex3',2),
        (5,'李坦克',3),
        (6,'刘飞机',3),
        (7,'张火箭',3),
        (8,'林子弹',3),
        (9,'加特林',3)
        ;


        #删父表department,子表employee中对应的记录跟着删
        mysql> delete from department where id=3;
        mysql> select * from employee;
        +----+-------+--------+
        | id | name  | dpt_id |
        +----+-------+--------+
        |  1 | egon  |      1 |
        |  2 | alex1 |      2 |
        |  3 | alex2 |      2 |
        |  4 | alex3 |      2 |
        +----+-------+--------+


        #更新父表department,子表employee中对应的记录跟着改
        mysql> update department set id=22222 where id=2;
        mysql> select * from employee;
        +----+-------+--------+
        | id | name  | dpt_id |
        +----+-------+--------+
        |  1 | egon  |      1 |
        |  3 | alex2 |  22222 |
        |  4 | alex3 |  22222 |
        |  5 | alex1 |  22222 |
        +----+-------+--------+

         示范

     示范

-   分析步骤:
        #1、先站在左表的角度去找
        是否左表的多条记录可以对应右表的一条记录,如果是,则证明左表的一个字段foreign key 右表一个字段(通常是id)

        #2、再站在右表的角度去找
        是否右表的多条记录可以对应左表的一条记录,如果是,则证明右表的一个字段foreign key 左表一个字段(通常是id)

        #3、总结:
        #多对一:
        如果只有步骤1成立,则是左表多对一右表
        如果只有步骤2成立,则是右表多对一左表

        #多对多
        如果步骤1和2同时成立,则证明这两张表时一个双向的多对一,即多对多,需要定义一个这两张表的关系表来专门存放二者的关系

        #一对一:
        如果1和2都不成立,而是左表的一条记录唯一对应右表的一条记录,反之亦然。这种情况很简单,就是在左表foreign key右表的基础上,将左表的外键字段设置成unique即可

    ** 一对多或多对一:**

    -   #一对多或称为多对一
            三张表:出版社,作者信息,书

            一对多(或多对一):一个出版社可以出版多本书

            关联方式:foreign key

    -   ![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)![](https://images.cnblogs.com/OutliningIndicators/ExpandedBlockStart.gif)
            =====================多对一=====================
            create table press(
            id int primary key auto_increment,
            name varchar(20)
            );

            create table book(
            id int primary key auto_increment,
            name varchar(20),
            press_id int not null,
            foreign key(press_id) references press(id)
            on delete cascade
            on update cascade
            );


            insert into press(name) values
            ('北京工业地雷出版社'),
            ('人民音乐不好听出版社'),
            ('知识产权没有用出版社')
            ;

            insert into book(name,press_id) values
            ('九阳神功',1),
            ('九阴真经',2),
            ('九阴白骨爪',2),
            ('独孤九剑',3),
            ('降龙十巴掌',2),
            ('葵花宝典',3)
            ;

        View Code

多对多:

      • 澳门葡京备用网址 58澳门葡京备用网址 59

        #多对多
        三张表:出版社,作者信息,书
        
        多对多:一个作者可以写多本书,一本书也可以有多个作者,双向的一对多,即多对多
          
        关联方式:foreign key+一张新的表
        
        =====================多对多=====================
        create table author(
        id int primary key auto_increment,
        name varchar(20)
        );
        
            #这张表就存放作者表与书表的关系,即查询二者的关系查这表就可以了
            create table author2book(
            id int not null unique auto_increment,
            author_id int not null,
            book_id int not null,
            constraint fk_author foreign key(author_id) references author(id)
            on delete cascade
            on update cascade,
            constraint fk_book foreign key(book_id) references book(id)
            on delete cascade
            on update cascade,
            primary key(author_id,book_id)
            );


            #插入四个作者,id依次排开
            insert into author(name) values('egon'),('alex'),('yuanhao'),('wpq');

            #每个作者与自己的代表作如下
            egon: 
            九阳神功
            九阴真经
            九阴白骨爪
            独孤九剑
            降龙十巴掌
            葵花宝典
            alex: 
            九阳神功
            葵花宝典
            yuanhao:
            独孤九剑
            降龙十巴掌
            葵花宝典
            wpq:
            九阳神功


            insert into author2book(author_id,book_id) values
            (1,1),
            (1,2),
            (1,3),
            (1,4),
            (1,5),
            (1,6),
            (2,1),
            (2,6),
            (3,4),
            (3,5),
            (3,6),
            (4,1)
            ;

        View Code

一对一:

      • 澳门葡京备用网址 60澳门葡京备用网址 61

        #一对一
        两张表:学生表和客户表
        
        一对一:一个学生是一个客户,一个客户有可能变成一个学校,即一对一的关系
        
        关联方式:foreign key+unique
        
            #一定是student来foreign key表customer,这样就保证了:
            #1 学生一定是一个客户,
            #2 客户不一定是学生,但有可能成为一个学生


            create table customer(
            id int primary key auto_increment,
            name varchar(20) not null
            );


            create table student(
            id int primary key auto_increment,
            name varchar(20) not null,
            class_name varchar(20) not null default 'python自动化',
            level int default 1,
            customer_id int unique, #该字段一定要是唯一的
            foreign key(customer_id) references customer(id) #外键的字段一定要保证unique
            on delete cascade
            on update cascade
            );


            #增加客户
            insert into customer(name) values
            ('李飞机'),
            ('王大炮'),
            ('守榴弹'),
            ('吴坦克'),
            ('赢火箭'),
            ('战地雷')
            ;


            #增加学生
            insert into student(name,customer_id) values
            ('李飞机',1),
            ('王大炮',2)
            ;

        View Code

修改表:

澳门葡京备用网址 62澳门葡京备用网址 63

语法:
1. 修改表名
      ALTER TABLE 表名 
                          RENAME 新表名;

2. 增加字段
      ALTER TABLE 表名
                          ADD 字段名  数据类型 [完整性约束条件…],
                        ADD 字段名  数据类型 [完整性约束条件…];
    ALTER TABLE 表名
                          ADD 字段名  数据类型 [完整性约束条件…]  FIRST;
    ALTER TABLE 表名
                            ADD 字段名  数据类型 [完整性约束条件…]  AFTER 字段名;

3. 删除字段
      ALTER TABLE 表名 
                                    DROP 字段名;

4. 修改字段
      ALTER TABLE 表名 
                          MODIFY  字段名 数据类型 [完整性约束条件…];
      ALTER TABLE 表名 
                          CHANGE 旧字段名 新字段名 旧数据类型 [完整性约束条件…];
      ALTER TABLE 表名 
                          CHANGE 旧字段名 新字段名 新数据类型 [完整性约束条件…];

示例:
1. 修改存储引擎
mysql> alter table service 
    -> engine=innodb;

2. 添加字段
mysql> alter table student10
    -> add name varchar(20) not null,
    -> add age int(3) not null default 22;

mysql> alter table student10
    -> add stu_num varchar(10) not null after name;                //添加name字段之后

mysql> alter table student10                        
    -> add sex enum('male','female') default 'male' first;          //添加到最前面

3. 删除字段
mysql> alter table student10
    -> drop sex;

mysql> alter table service
    -> drop mac;

4. 修改字段类型modify
mysql> alter table student10
    -> modify age int(3);
mysql> alter table student10
    -> modify id int(11) not null primary key auto_increment;    //修改为主键

5. 增加约束(针对已有的主键增加auto_increment)
mysql> alter table student10 modify id int(11) not null primary key auto_increment;
ERROR 1068 (42000): Multiple primary key defined

mysql> alter table student10 modify id int(11) not null auto_increment;
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

6. 对已经存在的表增加复合主键
mysql> alter table service2
    -> add primary key(host_ip,port);        

7. 增加主键
mysql> alter table student1
    -> modify name varchar(10) not null primary key;

8. 增加主键和自动增长
mysql> alter table student1
    -> modify id int not null primary key auto_increment;

9. 删除主键
a. 删除自增约束
mysql> alter table student10 modify id int(11) not null; 

b. 删除主键
mysql> alter table student10                                 
    -> drop primary key;

View Code

澳门葡京备用网址 64澳门葡京备用网址 65

复制表结构+记录 (key不会复制: 主键、外键和索引)
mysql> create table new_service select * from service;

只复制表结构
mysql> select * from service where 1=2;        //条件为假,查不到任何记录
Empty set (0.00 sec)
mysql> create table new1_service select * from service where 1=2;  
Query OK, 0 rows affected (0.00 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> create table t4 like employees;

复制表

澳门葡京备用网址 66澳门葡京备用网址 67

DROP TABLE 表名;

删除

登6,设置密码

澳门葡京备用网址 68澳门葡京备用网址 69

初始状态下,管理员root,密码为空,默认只允许从本机登录localhost
设置密码
[root@egon ~]# mysqladmin -uroot password "123"        设置初始密码 由于原密码为空,因此-p可以不用
[root@egon ~]# mysqladmin -uroot -p"123" password "456"        修改mysql密码,因为已经有密码了,所以必须输入原密码才能设置新密码

命令格式:
[root@egon ~]# mysql -h172.31.0.2 -uroot -p456
[root@egon ~]# mysql -uroot -p
[root@egon ~]# mysql                    以root用户登录本机,密码为空

View Code

二、数据库相关操作

数量操作

 


 

MySQL数据操作: DML

========================================================

在MySQL管理软件中,能够通过SQL语句中的DML语言来落成数据的操作,包括

  1. 选用INSERT落成多少的插入
  2. UPDATE完成多少的立异
  3. 接纳DELETE实现数量的删除
  4. 动用SELECT查询数据以及。

========================================================

本节内容包括:

布置数据
更新数据
删除数据
询问数据

安排数据 insert

1. 插入完整数据(顺序插入)
    语法一:
    INSERT INTO 表名(字段1,字段2,字段3…字段n) VALUES(值1,值2,值3…值n);

    语法二:
    INSERT INTO 表名 VALUES (值1,值2,值3…值n);

2. 指定字段插入数据
    语法:
    INSERT INTO 表名(字段1,字段2,字段3…) VALUES (值1,值2,值3…);

3. 插入多条记录
    语法:
    INSERT INTO 表名 VALUES
        (值1,值2,值3…值n),
        (值1,值2,值3…值n),
        (值1,值2,值3…值n);

4. 插入查询结果
    语法:
    INSERT INTO 表名(字段1,字段2,字段3…字段n) 
                    SELECT (字段1,字段2,字段3…字段n) FROM 表2
                    WHERE …;

更新数据:

语法:
    UPDATE 表名 SET
        字段1=值1,
        字段2=值2,
        WHERE CONDITION;

示例:
    UPDATE mysql.user SET password=password(‘123’) 
        where user=’root’ and host=’localhost’;

剔除数据
delete:

语法:
    DELETE FROM 表名 
        WHERE CONITION;

示例:
    DELETE FROM mysql.user 
        WHERE password=’’;

练习:
    更新MySQL root用户密码为mysql123
    删除除从本地登录的root用户以外的所有用户

忘却密码

澳门葡京备用网址 70澳门葡京备用网址 71

#windows平台下,5.7版本mysql,破解密码的两种方式:
#方式一

#1 关闭mysql
#2 在cmd中执行:mysqld --skip-grant-tables
#3 在cmd中执行:mysql
#4 执行如下sql:
update mysql.user set authentication_string=password('') where user = 'root';
flush privileges;
#5 tskill mysqld #或taskkill -f /PID 7832
#6 重新启动mysql

#方式二
#1. 关闭mysql,可以用tskill mysqld将其杀死
#2. 在解压目录下,新建mysql配置文件my.ini
#3. my.ini内容,指定
[mysqld]
skip-grant-tables
#4.启动mysqld
#5.在cmd里直接输入mysql登录,然后操作
update mysql.user set authentication_string=password('') where user='root and host='localhost';
flush privileges;
#6.注释my.ini中的skip-grant-tables,然后启动myqsld,然后就可以以新密码登录了

View Code

 在windows下,为mysql服务钦命计划文件

#配置文件中的注释可以有中文,但是配置项中不能出现中文
#在mysql的解压目录下,新建my.ini,然后配置
#1. 在执行mysqld命令时,下列配置会生效,即mysql服务启动时生效
[mysqld]
;skip-grant-tables
port=3306
character_set_server=utf8
default-storage-engine=innodb
innodb_file_per_table=1
#解压的目录
basedir=E:\mysql-5.7.19-winx64
#data目录
datadir=E:\my_data #在mysqld --initialize时,就会将初始数据存入此处指定的目录,在初始化之后,启动mysql时,就会去这个目录里找数据


#2. 针对客户端命令的全局配置,当mysql客户端命令执行时,下列配置生效
[client]
port=3306
default-character-set=utf8
user=root
password=123

#3. 只针对mysql这个客户端的配置,2中的是全局配置,而此处的则是只针对mysql这个命令的局部配置
[mysql]
;port=3306
;default-character-set=utf8
user=egon
password=4573

#如果没有[mysql],则用户在执行mysql命令时的配置以[client]为准
#创建数据库

create  database  数据库名 charset utf8;

#查看数据库
show databases;
show create database db1;
select database();  #查看当前所在数据库

#选择数据库
use 数据库名

#删除数据库
drop database 数据库名;

#修改数据库
alter database db1 charset  utf8;

联合字符编码

澳门葡京备用网址 72澳门葡京备用网址 73

#1. 修改配置文件
[mysqld]
default-character-set=utf8
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

#mysql5.5以上:修改方式有所改动
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

#2. 重启服务
#3. 查看修改结果:
\s
show variables like '%char%'

View Code

二、表操作

sql语句

  Sql语句首要用来存取数据,查询数据,更新数据和治本数据库系统。

#Sql语句分为3种类型
#1.DDL语句:数据库定义语言: 数据库、表、视图、索引、存储过程,例如CREATE DROP ALTER
#2.DML语句:数据库操纵语言: 插入数据INSERT、删除数据DELETE、更新数据UPDATE、查询数据SELECT
#3.DCL语句:数据库控制语言: 例如控制用户的访问权限GRANT、REVOKE

1、创建表

库操作

  安装并登录mysql后,查看数据库,开掘有如下数据库:

  澳门葡京备用网址 74

#information_schema:虚拟库,不占用磁盘空间,存储的是数据库启动后的一些参数,如用户表信息、列信息、权限信息、字符信息等
#performance_schema:Mysql5.5开始新增一个数据库:主要用于收集数据库服务器性能参数,记录处理查询请求时发生的各种事件、锁等现象
#mysql:授权库,主要存储系统用户的权限信息
#test:Mysql数据库系统自动创建的测试数据库

  创造数据库

#数据库命名规则
#可以由字母、数字、下划线、@、#、$组成
#区分大小写
#唯一性
#不能使用关键字如select、create
#不能单独使用数字
#最长128位

#数据库相关操作

#创建数据库
create database db1 charset utf8;
#查看数据库
show databases;
show create database db1;
select database();
#选择数据库
use db1;
#修改数据库
alter database db1 charset utf8;
#删除数据库
drop database db1;
语法:
create table 表名(
字段名1 类型[(宽度) 约束条件],
字段名2 类型[(宽度) 约束条件],
字段名3 类型[(宽度) 约束条件]
);

注意:
1. 在同一张表中,字段名是不能相同
2. 宽度和约束条件可选
3. 字段名和类型是必须的

表操作

澳门葡京备用网址 75澳门葡京备用网址 76

表相关操作

#先切换到库下
use db1;
#创建表
#create table 表名(
字段名1 类型[(宽度) 约束条件],
字段名2 类型[(宽度)约束条件]
);
#在同一张表中,字段名不能相同;宽度和约束条件可选;字段名和类型是必须的;表中的最后一个字段不要加逗号
create table t1(id int,name char);

#查看表
show tables;  #查看表
describe t1;   #查看表结构,可简写为 desc t1
show create table t1\G  #查看表详细结构

#修改表
alter table t1 modify name char(3);
alter table t1 change name name1 char(2);

澳门葡京备用网址 77澳门葡京备用网址 78

1. 修改表名
      ALTER TABLE 表名
                          RENAME 新表名;

2. 增加字段
      ALTER TABLE 表名
                          ADD 字段名  数据类型 [完整性约束条件…],
                          ADD 字段名  数据类型 [完整性约束条件…];
      ALTER TABLE 表名
                          ADD 字段名  数据类型 [完整性约束条件…]  FIRST;
      ALTER TABLE 表名
                          ADD 字段名  数据类型 [完整性约束条件…]  AFTER 字段名;

3. 删除字段
      ALTER TABLE 表名
                          DROP 字段名;

4. 修改字段
      ALTER TABLE 表名
                          MODIFY  字段名 数据类型 [完整性约束条件…];
      ALTER TABLE 表名
                          CHANGE 旧字段名 新字段名 旧数据类型 [完整性约束条件…];
      ALTER TABLE 表名
                          CHANGE 旧字段名 新字段名 新数据类型 [完整性约束条件…];

修改表语法

澳门葡京备用网址 79澳门葡京备用网址 80

#1. 修改存储引擎
alter table service engine=innodb;

#2. 添加字段
alter table t1  add name varchar(20) not null;

alter table t1 add stu_num varchar(10) not null after name;  //添加name字段之后

alter table t1 add sex enum('male','female') default 'male' first; //添加到最前面

#3. 删除字段
 alter table t1 drop sex;

alter table service drop mac;

#4. 修改字段类型modify
alter table t1 modify age int(3);
alter table t1 modify id int(11) not null primary key auto_increment;    //修改为主键

#5. 增加约束(针对已有的主键增加auto_increment)
alter table student10 modify id int(11) not null primary key auto_increment;
#ERROR 1068 (42000): Multiple primary key defined

alter table student10 modify id int(11) not null auto_increment;
#Query OK, 0 rows affected (0.01 sec)

#6. 对已经存在的表增加复合主键
alter table service2 add primary key(host_ip,port);

#7. 增加主键
alter table student1 modify name varchar(10) not null primary key;

#8. 增加主键和自动增长
alter table student1 modify id int not null primary key auto_increment;

#9. 删除主键
#a. 删除自增约束
alter table student10 modify id int(11) not null;

#b. 删除主键
alter table student10 drop primary key;

示例

#复制表
#复制表结构+记录
create table new_service select * from service;
#只复制表结构
create table new1_service select * from service where 1=2;
create table t4 like employees;

#删除表
drop table t1;
MariaDB [(none)]> create database db1 charset utf8;

MariaDB [(none)]> use db1;

MariaDB [db1]> create table t1(  
    -> id int, 
    -> name varchar(50),
    -> sex enum('male','female'),
    -> age int(3)
    -> );

MariaDB [db1]> show tables; #查看db1库下所有表名

MariaDB [db1]> desc t1;
+-------+-----------------------+------+-----+---------+-------+
| Field | Type                  | Null | Key | Default | Extra |
+-------+-----------------------+------+-----+---------+-------+
| id    | int(11)               | YES  |     | NULL    |       |
| name  | varchar(50)           | YES  |     | NULL    |       |
| sex   | enum('male','female') | YES  |     | NULL    |       |
| age   | int(3)                | YES  |     | NULL    |       |
+-------+-----------------------+------+-----+---------+-------+

MariaDB [db1]> select id,name,sex,age from t1;
Empty set (0.00 sec)

MariaDB [db1]> select * from t1;
Empty set (0.00 sec)

MariaDB [db1]> select id,name from t1;
Empty set (0.00 sec)

数据类型

表内部存款和储蓄器放的数占有两样的品类,每一个数据类型都有和睦的上升的幅度,但幅度是可选的

数值类型

  整数类型:TINYINT SMALLINT MEDIUMINT INT BIGINT

为该类型钦命宽度时,仅仅只是钦点询问结果的展示升幅,与存款和储蓄范围无关,暗中认可的展现上升的幅度都以在最大值的功底上加壹

澳门葡京备用网址 81

  浮点型

  定点数类型:DEC等同于DE朗境L,浮点类型:FLOAT DOUBLE

  位类型

  BIT(M)能够用来存放在多位2进制数,M范围从一~6四,如若不写默以为一位

#对于位字段需要使用函数读取
bin()显示为二进制
hex()显示为十六进制

日期类型:DATE TIME DATETIME TIMESTAMP YEA本田UR-V

澳门葡京备用网址 82澳门葡京备用网址 83

YEAR
            YYYY(1901/2155)

DATE
            YYYY-MM-DD(1000-01-01/9999-12-31)

TIME
            HH:MM:SS('-838:59:59'/'838:59:59')

DATETIME

            YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59    Y)

TIMESTAMP

            YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)

View Code

字符串类型:char,varchar,

澳门葡京备用网址 84澳门葡京备用网址 85

1.CHAR 和 VARCHAR 是最常使用的两种字符串类型。
2.一般来说CHAR(N)用来保存固定长度的字符串,对于 CHAR 类型,N 的范围 为 0 ~ 255
VARCHAR(N)用来保存变长字符类型,对于 VARCHAR 类型,N 的范围为 0 ~ 65 535
CHAR(N)和 VARCHAR(N) 中的 N 都代表字符长度,而非字节长度。
3. char填充空格来满足固定长度,但是在查询时却会很不要脸地删除尾部的空格(装作自己好像没有浪费过空间一样),然后修改sql_mode让其现出原形
4.虽然 CHAR 和 VARCHAR 的存储方式不太相同,但是对于两个字符串的比较,都只比 较其值,忽略 CHAR 值存在的右填充,即使将 SQL _MODE 设置为 PAD_CHAR_TO_FULL_ LENGTH 也一样,,但这不适用于like
5.虽然varchar使用起来较为灵活,但是从整个系统的性能角度来说,char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡
6.#其他字符串系列(效率:char>varchar>text)
TEXT系列 TINYTEXT TEXT MEDIUMTEXT LONGTEXT
BLOB 系列    TINYBLOB BLOB MEDIUMBLOB LONGBLOB
BINARY系列 BINARY VARBINARY
text:text数据类型用于保存变长的大字符串,可以组多到65535 (2**16 − 1)个字符。
mediumtext:A TEXT column with a maximum length of 16,777,215 (2**24 − 1) characters.
longtext:A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 − 1) characters.

View Code

枚举类型与集中类型

  字段值只能在给定的限制内选3个值,enum(单选)只可以在加以的限量内选三个值,set(多选)在给定的限定内能够挑选贰个或三个值

create table consumer(
name varchar(50),
sex enum('male','female'),
hobby set('play','read','study')
);

View
Code

表完整性约束

  约束原则与数据类型的肥瘦同样,都以可选参数。重要用于保险数据的完整性和1致性。

primary key (PK) #标识主键,可以唯一的标识记录
foreign key (FK) #标识外键
not null  #标识字段不能为空
unique key (UK) #标识该字段唯一
auto_increment #标识该字段的值自动增长(整数类型且为主键)
default #为该字段设置默认值
unsigned #无符号
zerofill #用0填充

澳门葡京备用网址 86澳门葡京备用网址 87

1. 是否允许为空,默认NULL,可设置NOT NULL,字段不允许为空,必须赋值
2. 字段是否有默认值,缺省的默认值是NULL,如果插入记录时不给字段赋值,此字段使用默认值
sex enum('male','female') not null default 'male'
age int unsigned NOT NULL default 20 必须为正值(无符号) 不允许为空 默认是20
3. 是否是key
主键 primary key
外键 foreign key
索引 (index,unique...)

View Code

  not null与default

not null #不可空

create table t1(id int not null);
insert into t1 values(1); #设置id字段不为空则插入记录时不能插入空

null #可空
create table t2(id int);
insert into t2 values(); #默认可以插入空

default #默认值,无论字段是null还是not null都可以插入空,插入空填入默认值
create table t3(age int not null default 18);
create table t4(hobby varchar default 'read'); 

  unique

unique #设置唯一约束
#设置方法一
create table t1(name varchar(20) unique);

#设置方法二
create table t2(
name varchar(20),
constraint uk_name unique(name)
);

#联合唯一
create table t3(
name varchar(20),
host varchar(15) not null,
port int not null,
unique(host,post)
);

#not null+ unique
create table t4(id int not null unique); #数据库会自动识别为primary key

  primary key

  主键primary
key是innodb存款和储蓄引擎组织数量的依靠,innodb称之为索引组织表,一张表中务必有且唯有二个主键

#not null + unique设置主键
create table t1(id int not null unique);

#primary key 设置主键方法一
create table t2(id int primary key);

#primary key 设置主键方法二
create table t2(
id int
constraint pk_name primary key(is)
);

#联合主键
create table t3(
host varchar(20),
port char(15),
primary key(host,port)
);

  auto_increment

  约束字段为活动增进,被束缚的字段必须同时被key约束

澳门葡京备用网址 88澳门葡京备用网址 89

#创建完表后修改自增字段的起始值方法一
create table student(
id int primary key auto_increment,
name varchar(20),
sex num('male','female') default 'male'
);

alter table student auto_increment=3;


#方法二
create table student(
id int primary key auto_increment,
name varchar(20),
sex enum('male','female') default 'male'
)auto_increment=3;

#设置步长
sqlserver:自增步长
    基于表级别
    create table t1(
        id int。。。
    )engine=innodb,auto_increment=2 步长=2 default charset=utf8

mysql自增的步长:
    show session variables like 'auto_inc%';

#基于会话级别
    set session auth_increment_increment=2 #修改会话级别的步长

#基于全局级别的
    set global auth_increment_increment=2 #修改全局级别的步长(所有会话都生效)

如果auto_increment_offset的值大于auto_increment_increment的值,则auto_increment_offset的值会被忽略

View Code

#不指定id,则自动增长
create table student(
id int primary key auto_increment,
name varchar(20),
sex enum('male','female') default 'male'
);

#插入数据时可不指定id
insert into student(name) values('lary')

#插入数据时也可以指定id
insert into student(id,name) values(3,'lily')

#对于自增的字段,在用delete删除后,再插入值,该字段仍按照删除前的位置继续增长
delete from student

#truncate 清空表,清空后,直接从0开始
truncate student 

   foreign key

#表类型必须是innodb存储引擎,且被关联的字段必须保证唯一
create table department(
id int primary key,
name varchar(20) not null
)engine=innodb;

create table employee(
id int primary key,
name varchar(20) not null,
dep_id int,
constraint fk_name foreign key(dep_id) references department(id)
on delete cascade        # 删除父表department,子表employee中对应的记录跟着删
on update cascade     #更新父表department,子表employee中对应的记录跟着改
)engine=innodb;            

 

  

澳门葡京备用网址 90澳门葡京备用网址 91

MariaDB [db1]> insert into t1 values
    -> (1,'egon',18,'male'),
    -> (2,'alex',81,'female')
    -> ;
MariaDB [db1]> select * from t1;
+------+------+------+--------+
| id   | name | age  | sex    |
+------+------+------+--------+
|    1 | egon |   18 | male   |
|    2 | alex |   81 | female |
+------+------+------+--------+



MariaDB [db1]> insert into t1(id) values 
    -> (3),
    -> (4);
MariaDB [db1]> select * from t1;
+------+------+------+--------+
| id   | name | age  | sex    |
+------+------+------+--------+
|    1 | egon |   18 | male   |
|    2 | alex |   81 | female |
|    3 | NULL | NULL | NULL   |
|    4 | NULL | NULL | NULL   |
+------+------+------+--------+

往表中插入数据

往表中插入数据

澳门葡京备用网址 92澳门葡京备用网址 93

mysql> create database db1 charset latin1;
mysql> use db1;
mysql> create table t1(name varchar(20));
mysql> show create table t1; #查看表,发现表默认与数据db1的字符编码一致
mysql> insert into t1 values('林'); #插入中文出错,因为latin1不支持中文
ERROR 1366 (HY000): 
mysql> 

#解决方法一:删除库db1,重建db1,字符编码指定为utf8

#解决方法二:修改
mysql> alter table t1 charset utf8; #修改表t1的编码
mysql> insert into t1 values('林'); #虽然t1的编码改了,但是t1的字段name仍然是按照latin1编码创建的
ERROR 1366 (HY000): 
mysql> alter table t1 modify name varchar(20); #需要重新定义下字段name
mysql> insert into t1 values('林');
mysql> select * from t1;
+------+
| name |
+------+
| 林   |
+------+

ps:不要忘记将数据库编码也改成utf8,这样以后在该数据库下创建表时,都默认utf8编码了

#配置文件:http://blog.csdn.net/yipiankongbai/article/details/16937815

乱码难点:主要!!!

澳门葡京备用网址 94澳门葡京备用网址 95

#1. 修改配置文件
[mysqld]
default-character-set=utf8 
[client]
default-character-set=utf8 
[mysql]
default-character-set=utf8

#mysql5.5以上:修改方式有所改动
    [mysqld]
    character-set-server=utf8
    collation-server=utf8_general_ci
    [client]
    default-character-set=utf8
    [mysql]
    default-character-set=utf8

#2. 重启服务
#3. 查看修改结果:
\s
show variables like '%char%'

千古化解编码难点

 

二、查看表结构

MariaDB [db1]> describe t1; #查看表结构,可简写为desc 表名
+-------+-----------------------+------+-----+---------+-------+
| Field | Type                  | Null | Key | Default | Extra |
+-------+-----------------------+------+-----+---------+-------+
| id    | int(11)               | YES  |     | NULL    |       |
| name  | varchar(50)           | YES  |     | NULL    |       |
| sex   | enum('male','female') | YES  |     | NULL    |       |
| age   | int(3)                | YES  |     | NULL    |       |
+-------+-----------------------+------+-----+---------+-------+


MariaDB [db1]> show create table t1\G; #查看表详细结构,可加\G

 

 3、数据类型

mysql数据类型大概浏览

澳门葡京备用网址 96澳门葡京备用网址 97

#1. 数字:
    整型:tinyinit  int  bigint
    小数:
        float :在位数比较短的情况下不精准
        double :在位数比较长的情况下不精准
            0.000001230123123123
            存成:0.000001230000

        decimal:(如果用小数,则用推荐使用decimal)
            精准
            内部原理是以字符串形式去存

#2. 字符串:
    char(10):简单粗暴,浪费空间,存取速度快
        root存成root000000
    varchar:精准,节省空间,存取速度慢

    sql优化:创建表时,定长的类型往前放,变长的往后放
                    比如性别           比如地址或描述信息

    >255个字符,超了就把文件路径存放到数据库中。
            比如图片,视频等找一个文件服务器,数据库中只存路径或url。



#3. 时间类型:
    最常用:datetime


#4. 枚举类型与集合类型

View
Code

 

(一)、数值类型

      澳门葡京备用网址 ,  整数类型: 

       
成效: 存款和储蓄年龄,等级,id,各样数码等

澳门葡京备用网址 98澳门葡京备用网址 99

========================================
        tinyint[(m)] [unsigned] [zerofill]

            小整数,数据类型用于保存一些范围的整数数值范围:
            有符号:
                -128 ~ 127
            无符号:
~ 255

            PS: MySQL中无布尔值,使用tinyint(1)构造。



========================================
        int[(m)][unsigned][zerofill]

            整数,数据类型用于保存一些范围的整数数值范围:
            有符号:
                    -2147483648 ~ 2147483647
            无符号:
~ 4294967295



========================================
        bigint[(m)][unsigned][zerofill]
            大整数,数据类型用于保存一些范围的整数数值范围:
            有符号:
                    -9223372036854775808 ~ 9223372036854775807
            无符号:
 ~  18446744073709551615

View
Code

澳门葡京备用网址 100澳门葡京备用网址 101

=========有符号和无符号tinyint==========
#tinyint默认为有符号
MariaDB [db1]> create table t1(x tinyint); #默认为有符号,即数字前有正负号
MariaDB [db1]> desc t1;
MariaDB [db1]> insert into t1 values
    -> (-129),
    -> (-128),
    -> (127),
    -> (128);
MariaDB [db1]> select * from t1;
+------+
| x    |
+------+
| -128 | #-129存成了-128
| -128 | #有符号,最小值为-128
|  127 | #有符号,最大值127
|  127 | #128存成了127
+------+



#设置无符号tinyint
MariaDB [db1]> create table t2(x tinyint unsigned);
MariaDB [db1]> insert into t2 values
    -> (-1),
    -> (0),
    -> (255),
    -> (256);
MariaDB [db1]> select * from t2;
+------+
| x    |
+------+
|    0 | -1存成了0
|    0 | #无符号,最小值为0
|  255 | #无符号,最大值为255
|  255 | #256存成了255
+------+



============有符号和无符号int=============
#int默认为有符号
MariaDB [db1]> create table t3(x int); #默认为有符号整数
MariaDB [db1]> insert into t3 values
    -> (-2147483649),
    -> (-2147483648),
    -> (2147483647),
    -> (2147483648);
MariaDB [db1]> select * from t3;
+-------------+
| x           |
+-------------+
| -2147483648 | #-2147483649存成了-2147483648
| -2147483648 | #有符号,最小值为-2147483648
|  2147483647 | #有符号,最大值为2147483647
|  2147483647 | #2147483648存成了2147483647
+-------------+



#设置无符号int
MariaDB [db1]> create table t4(x int unsigned);
MariaDB [db1]> insert into t4 values
    -> (-1),
    -> (0),
    -> (4294967295),
    -> (4294967296);
MariaDB [db1]> select * from t4;
+------------+
| x          |
+------------+
|          0 | #-1存成了0
|          0 | #无符号,最小值为0
| 4294967295 | #无符号,最大值为4294967295
| 4294967295 | #4294967296存成了4294967295
+------------+




==============有符号和无符号bigint=============
MariaDB [db1]> create table t6(x bigint);
MariaDB [db1]> insert into t5 values  
    -> (-9223372036854775809),
    -> (-9223372036854775808),
    -> (9223372036854775807),
    -> (9223372036854775808);

MariaDB [db1]> select * from t5;
+----------------------+
| x                    |
+----------------------+
| -9223372036854775808 |
| -9223372036854775808 |
|  9223372036854775807 |
|  9223372036854775807 |
+----------------------+



MariaDB [db1]> create table t6(x bigint unsigned);
MariaDB [db1]> insert into t6 values  
    -> (-1),
    -> (0),
    -> (18446744073709551615),
    -> (18446744073709551616);

MariaDB [db1]> select * from t6;
+----------------------+
| x                    |
+----------------------+
|                    0 |
|                    0 |
| 18446744073709551615 |
| 18446744073709551615 |
+----------------------+




======用zerofill测试整数类型的显示宽度=============
MariaDB [db1]> create table t7(x int(3) zerofill);
MariaDB [db1]> insert into t7 values
    -> (1),
    -> (11),
    -> (111),
    -> (1111);
MariaDB [db1]> select * from t7;
+------+
| x    |
+------+
|  001 |
|  011 |
|  111 |
| 1111 | #超过宽度限制仍然可以存
+------+

验证

!!!注意:为该品种钦赐宽度时,仅仅只是钦命询问结果的来得上涨的幅度,与储存范围无关,存款和储蓄范围如下

        
其实我们全然没必要为整数类型钦定显示升幅,使用私下认可的就足以了

    
  私下认可的来得上升的幅度,都以在最大值的底蕴上加一

 

         浮点类型:

       
 功用:存储薪俸、身高、体重、体质参数等

澳门葡京备用网址 102澳门葡京备用网址 103

======================================
        decimal[(m[,d])] [unsigned] [zerofill]
            准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。

            特别的:对于精确数值计算时需要用此类型
                   decaimal能够存储精确值的原因在于其内部按照字符串存储。



======================================
        FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]
            单精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。
                有符号:
                    -3.402823466E+38 to -1.175494351E-38,
                    1.175494351E-38 to 3.402823466E+38
                无符号:
                    1.175494351E-38 to 3.402823466E+38

            **** 数值越大,越不准确 ****


======================================
        DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]
            双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。

                有符号:
                    -1.7976931348623157E+308 to -2.2250738585072014E-308
                    2.2250738585072014E-308 to 1.7976931348623157E+308
                无符号:
                    2.2250738585072014E-308 to 1.7976931348623157E+308
            **** 数值越大,越不准确 ****

View
Code

澳门葡京备用网址 104澳门葡京备用网址 105

MariaDB [db1]> create table t8(salary float(5,2)); #总共5位,小数部分占2位,因而整数部分最多3位
MariaDB [db1]> insert into t8 values
    -> (3.3),
    -> (7.33),
    -> (9.335),
    -> (1000.1);
MariaDB [db1]> select * from t8;
+--------+
| salary |
+--------+
|   3.30 |
|   7.33 |
|   9.34 | #4舍5入
| 999.99 | #小数最多2位,整数最多3位
+--------+

验证

 

       位类型:BIT   #了解

  BIT(M)能够用来存放多位贰进制数,M范围从①~6四,假诺不写默以为一位。
  注意:对于位字段必要动用函数读取
      bin()显示为二进制
      hex()呈现为十六进制

澳门葡京备用网址 106澳门葡京备用网址 107

MariaDB [db1]> create table t9(id bit);
MariaDB [db1]> desc t9; #bit默认宽度为1
+-------+--------+------+-----+---------+-------+
| Field | Type   | Null | Key | Default | Extra |
+-------+--------+------+-----+---------+-------+
| id    | bit(1) | YES  |     | NULL    |       |
+-------+--------+------+-----+---------+-------+

MariaDB [db1]> insert into t9 values(8);
MariaDB [db1]> select * from t9; #直接查看是无法显示二进制位的
+------+
| id   |
+------+
|     |
+------+
MariaDB [db1]> select bin(id),hex(id) from t9; #需要转换才能看到
+---------+---------+
| bin(id) | hex(id) |
+---------+---------+
| 1       | 1       |
+---------+---------+

MariaDB [db1]> alter table t9 modify id bit(5);
MariaDB [db1]> insert into t9 values(8);
MariaDB [db1]> select bin(id),hex(id) from t9;
+---------+---------+
| bin(id) | hex(id) |
+---------+---------+
| 1       | 1       |
| 1000    | 8       |
+---------+---------+

验证

 

(2)、日期类型

         
 效能:存款和储蓄用户注册时间,小说公布时间,职员和工人入职时间,出生时间,过期光阴等

澳门葡京备用网址 108澳门葡京备用网址 109

year
            YYYY(1901/2155)

        date
            YYYY-MM-DD(1000-01-01/9999-12-31)

       time
            HH:MM:SS('-838:59:59'/'838:59:59')

      datetime

            YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59    Y)

        time stamp

            YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)

View
Code

澳门葡京备用网址 110澳门葡京备用网址 111

============year===========
MariaDB [db1]> create table t10(born_year year); #无论year指定何种宽度,最后都默认是year(4)
MariaDB [db1]> insert into t10 values  
    -> (1900),
    -> (1901),
    -> (2155),
    -> (2156);
MariaDB [db1]> select * from t10;
+-----------+
| born_year |
+-----------+
|      0000 |
|      1901 |
|      2155 |
|      0000 |
+-----------+


============date,time,datetime===========
MariaDB [db1]> create table t11(d date,t time,dt datetime);
MariaDB [db1]> desc t11;
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| d     | date     | YES  |     | NULL    |       |
| t     | time     | YES  |     | NULL    |       |
| dt    | datetime | YES  |     | NULL    |       |
+-------+----------+------+-----+---------+-------+

MariaDB [db1]> insert into t11 values(now(),now(),now());
MariaDB [db1]> select * from t11;
+------------+----------+---------------------+
| d          | t        | dt                  |
+------------+----------+---------------------+
| 2017-07-25 | 16:26:54 | 2017-07-25 16:26:54 |
+------------+----------+---------------------+



============timestamp===========
MariaDB [db1]> create table t12(time timestamp);
MariaDB [db1]> insert into t12 values();
MariaDB [db1]> insert into t12 values(null);
MariaDB [db1]> select * from t12;
+---------------------+
| time                |
+---------------------+
| 2017-07-25 16:29:17 |
| 2017-07-25 16:30:01 |
+---------------------+



============注意啦,注意啦,注意啦===========
1. 单独插入时间时,需要以字符串的形式,按照对应的格式插入
2. 插入年份时,尽量使用4位值
3. 插入两位年份时,<=69,以20开头,比如50,  结果2050      
                >=70,以19开头,比如71,结果1971
MariaDB [db1]> create table t12(y year);
MariaDB [db1]> insert into t12 values  
    -> (50),
    -> (71);
MariaDB [db1]> select * from t12;
+------+
| y    |
+------+
| 2050 |
| 1971 |
+------+



============综合练习===========
MariaDB [db1]> create table student(
    -> id int,
    -> name varchar(20),
    -> born_year year,
    -> birth date,
    -> class_time time,
    -> reg_time datetime);

MariaDB [db1]> insert into student values
    -> (1,'alex',"1995","1995-11-11","11:11:11","2017-11-11 11:11:11"),
    -> (2,'egon',"1997","1997-12-12","12:12:12","2017-12-12 12:12:12"),
    -> (3,'wsb',"1998","1998-01-01","13:13:13","2017-01-01 13:13:13");

MariaDB [db1]> select * from student;
+------+------+-----------+------------+------------+---------------------+
| id   | name | born_year | birth      | class_time | reg_time            |
+------+------+-----------+------------+------------+---------------------+
|    1 | alex |      1995 | 1995-11-11 | 11:11:11   | 2017-11-11 11:11:11 |
|    2 | egon |      1997 | 1997-12-12 | 12:12:12   | 2017-12-12 12:12:12 |
|    3 | wsb  |      1998 | 1998-01-01 | 13:13:13   | 2017-01-01 13:13:13 |
+------+------+-----------+------------+------------+---------------------+

验证

澳门葡京备用网址 112澳门葡京备用网址 113

在实际应用的很多场景中,MySQL的这两种日期类型都能够满足我们的需要,存储精度都为秒,但在某些情况下,会展现出他们各自的优劣。下面就来总结一下两种日期类型的区别。

1.DATETIME的日期范围是1001——9999年,TIMESTAMP的时间范围是1970——2038年。

2.DATETIME存储时间与时区无关,TIMESTAMP存储时间与时区有关,显示的值也依赖于时区。在mysql服务器,操作系统以及客户端连接都有时区的设置。

3.DATETIME使用8字节的存储空间,TIMESTAMP的存储空间为4字节。因此,TIMESTAMP比DATETIME的空间利用率更高。

4.DATETIME的默认值为null;TIMESTAMP的字段默认不为空(not null),默认值为当前时间(CURRENT_TIMESTAMP),如果不做特殊处理,并且update语句中没有指定该列的更新值,则默认更新为当前时间。

datetime与timestamp的区别

 

 (三)、字符串类型

澳门葡京备用网址 114澳门葡京备用网址 115

#官网:https://dev.mysql.com/doc/refman/5.7/en/char.html
#注意:char和varchar括号内的参数指的都是字符的长度

#char类型:定长,简单粗暴,浪费空间,存取速度快
    字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)
    存储:
        存储char类型的值时,会往右填充空格来满足长度
        例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储

    检索:
        在检索或者说查询时,查出的结果会自动删除尾部的空格,除非我们打开pad_char_to_full_length SQL模式(SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';)

#varchar类型:变长,精准,节省空间,存取速度慢
    字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8:https://dev.mysql.com/doc/refman/5.7/en/column-count-limit.html)
    存储:
        varchar类型存储数据的真实内容,不会用空格填充,如果'ab  ',尾部的空格也会被存起来
        强调:varchar类型会在真实数据前加1-2Bytes的前缀,该前缀用来表示真实数据的bytes字节数(1-2Bytes最大表示65535个数字,正好符合mysql对row的最大字节限制,即已经足够使用)
        如果真实的数据<255bytes则需要1Bytes的前缀(1Bytes=8bit 2**8最大表示的数字为255)
        如果真实的数据>255bytes则需要2Bytes的前缀(2Bytes=16bit 2**16最大表示的数字为65535)

    检索:
        尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容

View
Code

测试前了解两个函数
length:查看字节数
char_length:查看字符数

 一.
char填充空格来满意一定长度,然则在询问时却会很不要脸地删除尾巴部分的空格(装作本人看似一贯不浪费过空间同样),然后修改sql_mode让其现出真相

澳门葡京备用网址 116澳门葡京备用网址 117

mysql> create table t1(x char(5),y varchar(5));
Query OK, 0 rows affected (0.26 sec)

#char存5个字符,而varchar存4个字符
mysql> insert into t1 values('你瞅啥 ','你瞅啥 ');
Query OK, 1 row affected (0.05 sec)

mysql> SET sql_mode='';
Query OK, 0 rows affected, 1 warning (0.00 sec)

#在检索时char很不要脸地将自己浪费的2个字符给删掉了,装的好像自己没浪费过空间一样,而varchar很老实,存了多少,就显示多少
mysql> select x,char_length(x),y,char_length(y) from t1; 
+-----------+----------------+------------+----------------+
| x         | char_length(x) | y          | char_length(y) |
+-----------+----------------+------------+----------------+
| 你瞅啥    |              3 | 你瞅啥     |              4 |
+-----------+----------------+------------+----------------+
row in set (0.00 sec)

#略施小计,让char现出原形
mysql> SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';
Query OK, 0 rows affected (0.00 sec)

#这下子char原形毕露了......
mysql> select x,char_length(x),y,char_length(y) from t1;
+-------------+----------------+------------+----------------+
| x           | char_length(x) | y          | char_length(y) |
+-------------+----------------+------------+----------------+
| 你瞅啥      |              5 | 你瞅啥     |              4 |
+-------------+----------------+------------+----------------+
row in set (0.00 sec)


#char类型:3个中文字符+2个空格=11Bytes
#varchar类型:3个中文字符+1个空格=10Bytes
mysql> select x,length(x),y,length(y) from t1;
+-------------+-----------+------------+-----------+
| x           | length(x) | y          | length(y) |
+-------------+-----------+------------+-----------+
| 你瞅啥      |        11 | 你瞅啥     |        10 |
+-------------+-----------+------------+-----------+
row in set (0.00 sec)

View
Code

澳门葡京备用网址 118澳门葡京备用网址 119

mysql> select concat('数据: ',x,'长度: ',char_length(x)),concat(y,char_length(y)
) from t1;
+------------------------------------------------+--------------------------+
| concat('数据: ',x,'长度: ',char_length(x))     | concat(y,char_length(y)) |
+------------------------------------------------+--------------------------+
| 数据: 你瞅啥  长度: 5                          | 你瞅啥 4                 |
+------------------------------------------------+--------------------------+
row in set (0.00 sec)

了解concat

 2. 就算 CHA猎豹CS陆 和 VA奥迪Q5CHA大切诺基的储存格局不太雷同,但是对于三个字符串的比较,都只比 较其值,忽略 CHA帕杰罗值存在的右填充,就算将 SQL _MODE 设置为 PAD_CHAR_TO_FULL_ LENGTH
也同样,,但那不适用于like

澳门葡京备用网址 120澳门葡京备用网址 121

Values in CHAR and VARCHAR columns are sorted and compared according to the character set collation assigned to the column.

All MySQL collations are of type PAD SPACE. This means that all CHAR, VARCHAR, and TEXT values are compared without regard to any trailing spaces. “Comparison” in this context does not include the LIKE pattern-matching operator, for which trailing spaces are significant. For example:

mysql> CREATE TABLE names (myname CHAR(10));
Query OK, 0 rows affected (0.03 sec)

mysql> INSERT INTO names VALUES ('Monty');
Query OK, 1 row affected (0.00 sec)

mysql> SELECT myname = 'Monty', myname = 'Monty  ' FROM names;
+------------------+--------------------+
| myname = 'Monty' | myname = 'Monty  ' |
+------------------+--------------------+
|                1 |                  1 |
+------------------+--------------------+
row in set (0.00 sec)

mysql> SELECT myname LIKE 'Monty', myname LIKE 'Monty  ' FROM names;
+---------------------+-----------------------+
| myname LIKE 'Monty' | myname LIKE 'Monty  ' |
+---------------------+-----------------------+
|                   1 |                     0 |
+---------------------+-----------------------+
row in set (0.00 sec)

View
Code

 3. 总结 

澳门葡京备用网址 122澳门葡京备用网址 123

#常用字符串系列:char与varchar
注:虽然varchar使用起来较为灵活,但是从整个系统的性能角度来说,char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡

#其他字符串系列(效率:char>varchar>text)
TEXT系列 TINYTEXT TEXT MEDIUMTEXT LONGTEXT
BLOB 系列    TINYBLOB BLOB MEDIUMBLOB LONGBLOB 
BINARY系列 BINARY VARBINARY

text:text数据类型用于保存变长的大字符串,可以组多到65535 (2**16 − 1)个字符。
mediumtext:A TEXT column with a maximum length of 16,777,215 (2**24 − 1) characters.
longtext:A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 − 1) characters.

View
Code 

 

(肆)枚举类型与聚焦类型

 字段的值只万幸给定范围中甄选,如单选框,多选框
enum 单选
只可以在加以的限制内选1个值,如性别 sex 男male/女female
set 多选
在加以的范围内足以选用1个或三个上述的值(爱好1,爱好二,爱好三…)

澳门葡京备用网址 124澳门葡京备用网址 125

枚举类型(enum)
            An ENUM column can have a maximum of 65,535 distinct elements. (The practical limit is less than 3000.)
            示例:
                CREATE TABLE shirts (
                    name VARCHAR(40),
                    size ENUM('x-small', 'small', 'medium', 'large', 'x-large')
                );
                INSERT INTO shirts (name, size) VALUES ('dress shirt','large'), ('t-shirt','medium'),('polo shirt','small');



            集合类型(set)
            A SET column can have a maximum of 64 distinct members.
            示例:
                CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));
                INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');

View
Code

澳门葡京备用网址 126澳门葡京备用网址 127

MariaDB [db1]> create table consumer( 
    -> name varchar(50),
    -> sex enum('male','female'),
    -> level enum('vip1','vip2','vip3','vip4','vip5'), #在指定范围内,多选一
    -> hobby set('play','music','read','study') #在指定范围内,多选多
    -> );

MariaDB [db1]> insert into consumer values  
    -> ('egon','male','vip5','read,study'),
    -> ('alex','female','vip1','girl');

MariaDB [db1]> select * from consumer;
+------+--------+-------+------------+
| name | sex    | level | hobby      |
+------+--------+-------+------------+
| egon | male   | vip5  | read,study |
| alex | female | vip1  |            |
+------+--------+-------+------------+

验证

 

 四、表完整性约束

封锁标准与数据类型的大幅同样,都以可选参数

功能:用于保障数据的完整性和壹致性

 首要分为:

primary key (PK)    标识该字段为该表的主键,可以唯一的标识记录
foreign key (FK)    标识该字段为该表的外键
not null    标识该字段不能为空
unique key (UK)    标识该字段的值是唯一的
auto_increment    标识该字段的值自动增长(整数类型,而且为主键)
default    为该字段设置默认值

unsigned 无符号
zerofill 使用0填充

 说明:

1. 是否允许为空,默认NULL,可设置NOT NULL,字段不允许为空,必须赋值
2. 字段是否有默认值,缺省的默认值是NULL,如果插入记录时不给字段赋值,此字段使用默认值
sex enum('male','female') not null default 'male'
age int unsigned NOT NULL default 20 必须为正值(无符号) 不允许为空 默认是20
3. 是否是key
主键 primary key
外键 foreign key
索引 (index,unique...)

 

(1)、not null与default

澳门葡京备用网址 128澳门葡京备用网址 129

是否可空,null表示空,非字符串
not null - 不可空
null - 可空


默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动添加默认值
create table tb1(
nid int not null defalut 2,
num int not null
)

View
Code

澳门葡京备用网址 130澳门葡京备用网址 131

==================not null====================
mysql> create table t1(id int); #id字段默认可以插入空
mysql> desc t1;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | YES  |     | NULL    |       |
+-------+---------+------+-----+---------+-------+
mysql> insert into t1 values(); #可以插入空


mysql> create table t2(id int not null); #设置字段id不为空
mysql> desc t2;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | NO   |     | NULL    |       |
+-------+---------+------+-----+---------+-------+
mysql> insert into t2 values(); #不能插入空
ERROR 1364 (HY000): Field 'id' doesn't have a default value



==================default====================
#设置id字段有默认值后,则无论id字段是null还是not null,都可以插入空,插入空默认填入default指定的默认值
mysql> create table t3(id int default 1);
mysql> alter table t3 modify id int not null default 1;



==================综合练习====================
mysql> create table student(
    -> name varchar(20) not null,
    -> age int(3) unsigned not null default 18,
    -> sex enum('male','female') default 'male',
    -> hobby set('play','study','read','music') default 'play,music'
    -> );
mysql> desc student;
+-------+------------------------------------+------+-----+------------+-------+
| Field | Type                               | Null | Key | Default    | Extra |
+-------+------------------------------------+------+-----+------------+-------+
| name  | varchar(20)                        | NO   |     | NULL       |       |
| age   | int(3) unsigned                    | NO   |     | 18         |       |
| sex   | enum('male','female')              | YES  |     | male       |       |
| hobby | set('play','study','read','music') | YES  |     | play,music |       |
+-------+------------------------------------+------+-----+------------+-------+
mysql> insert into student(name) values('egon');
mysql> select * from student;
+------+-----+------+------------+
| name | age | sex  | hobby      |
+------+-----+------+------------+
| egon |  18 | male | play,music |
+------+-----+------+------------+

验证

 

(2)、unique

澳门葡京备用网址 132澳门葡京备用网址 133

============设置唯一约束 UNIQUE===============
方法一:
create table department1(
id int,
name varchar(20) unique,
comment varchar(100)
);


方法二:
create table department2(
id int,
name varchar(20),
comment varchar(100),
constraint uk_name unique(name)
);


mysql> insert into department1 values(1,'IT','技术');
Query OK, 1 row affected (0.00 sec)
mysql> insert into department1 values(1,'IT','技术');
ERROR 1062 (23000): Duplicate entry 'IT' for key 'name'

View
Code

澳门葡京备用网址 134澳门葡京备用网址 135

mysql> create table t1(id int not null unique);
Query OK, 0 rows affected (0.02 sec)

mysql> desc t1;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | NO   | PRI | NULL    |       |
+-------+---------+------+-----+---------+-------+
row in set (0.00 sec)

mysql> create table t1(id int not null unique);
Query OK, 0 rows affected (0.02 sec)

mysql> desc t1;
+-------+---------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
| id    | int(11) | NO   | PRI | NULL    |       |
+-------+---------+------+-----+---------+-------+
row in set (0.00 sec)

not
null+unique的化学反应

澳门葡京备用网址 136澳门葡京备用网址 137

create table service(
id int primary key auto_increment,
name varchar(20),
host varchar(15) not null,
port int not null,
unique(host,port) #联合唯一
);

mysql> insert into service values
    -> (1,'nginx','192.168.0.10',80),
    -> (2,'haproxy','192.168.0.20',80),
    -> (3,'mysql','192.168.0.30',3306)
    -> ;
Query OK, 3 rows affected (0.01 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> insert into service(name,host,port) values('nginx','192.168.0.10',80);
ERROR 1062 (23000): Duplicate entry '192.168.0.10-80' for key 'host'

同台唯1

 

(3)、primary key

primary key字段的值不为空且唯1

三个表中能够:

单列做主键
多列做主键(复合主键)

但三个表内只好有二个主键primary key

澳门葡京备用网址 138澳门葡京备用网址 139

============单列做主键===============
#方法一:not null+unique
create table department1(
id int not null unique, #主键
name varchar(20) not null unique,
comment varchar(100)
);

mysql> desc department1;
+---------+--------------+------+-----+---------+-------+
| Field   | Type         | Null | Key | Default | Extra |
+---------+--------------+------+-----+---------+-------+
| id      | int(11)      | NO   | PRI | NULL    |       |
| name    | varchar(20)  | NO   | UNI | NULL    |       |
| comment | varchar(100) | YES  |     | NULL    |       |
+---------+--------------+------+-----+---------+-------+
rows in set (0.01 sec)

#方法二:在某一个字段后用primary key
create table department2(
id int primary key, #主键
name varchar(20),
comment varchar(100)
);

mysql> desc department2;
+---------+--------------+------+-----+---------+-------+
| Field   | Type         | Null | Key | Default | Extra |
+---------+--------------+------+-----+---------+-------+
| id      | int(11)      | NO   | PRI | NULL    |       |
| name    | varchar(20)  | YES  |     | NULL    |       |
| comment | varchar(100) | YES  |     | NULL    |       |
+---------+--------------+------+-----+---------+-------+
rows in set (0.00 sec)

#方法三:在所有字段后单独定义primary key
create table department3(
id int,
name varchar(20),
comment varchar(100),
constraint pk_name primary key(id); #创建主键并为其命名pk_name

mysql> desc department3;
+---------+--------------+------+-----+---------+-------+
| Field   | Type         | Null | Key | Default | Extra |
+---------+--------------+------+-----+---------+-------+
| id      | int(11)      | NO   | PRI | NULL    |       |
| name    | varchar(20)  | YES  |     | NULL    |       |
| comment | varchar(100) | YES  |     | NULL    |       |
+---------+--------------+------+-----+---------+-------+
rows in set (0.01 sec)

单列主键

澳门葡京备用网址 140澳门葡京备用网址 141

==================多列做主键================
create table service(
ip varchar(15),
port char(5),
service_name varchar(10) not null,
primary key(ip,port)
);


mysql> desc service;
+--------------+-------------+------+-----+---------+-------+
| Field        | Type        | Null | Key | Default | Extra |
+--------------+-------------+------+-----+---------+-------+
| ip           | varchar(15) | NO   | PRI | NULL    |       |
| port         | char(5)     | NO   | PRI | NULL    |       |
| service_name | varchar(10) | NO   |     | NULL    |       |
+--------------+-------------+------+-----+---------+-------+
rows in set (0.00 sec)

mysql> insert into service values
    -> ('172.16.45.10','3306','mysqld'),
    -> ('172.16.45.11','3306','mariadb')
    -> ;
Query OK, 2 rows affected (0.00 sec)
Records: 2  Duplicates: 0  Warnings: 0

mysql> insert into service values ('172.16.45.10','3306','nginx');
ERROR 1062 (23000): Duplicate entry '172.16.45.10-3306' for key 'PRIMARY'

多列主键

  

(4)   auto_increment

封锁字段为自发性增进,被封锁的字段必须同时被key约束

澳门葡京备用网址 142澳门葡京备用网址 143

#不指定id,则自动增长
create table student(
id int primary key auto_increment,
name varchar(20),
sex enum('male','female') default 'male'
);

mysql> desc student;
+-------+-----------------------+------+-----+---------+----------------+
| Field | Type                  | Null | Key | Default | Extra          |
+-------+-----------------------+------+-----+---------+----------------+
| id    | int(11)               | NO   | PRI | NULL    | auto_increment |
| name  | varchar(20)           | YES  |     | NULL    |                |
| sex   | enum('male','female') | YES  |     | male    |                |
+-------+-----------------------+------+-----+---------+----------------+
mysql> insert into student(name) values
    -> ('egon'),
    -> ('alex')
    -> ;

mysql> select * from student;
+----+------+------+
| id | name | sex  |
+----+------+------+
|  1 | egon | male |
|  2 | alex | male |
+----+------+------+


#也可以指定id
mysql> insert into student values(4,'asb','female');
Query OK, 1 row affected (0.00 sec)

mysql> insert into student values(7,'wsb','female');
Query OK, 1 row affected (0.00 sec)

mysql> select * from student;
+----+------+--------+
| id | name | sex    |
+----+------+--------+
|  1 | egon | male   |
|  2 | alex | male   |
|  4 | asb  | female |
|  7 | wsb  | female |
+----+------+--------+


#对于自增的字段,在用delete删除后,再插入值,该字段仍按照删除前的位置继续增长
mysql> delete from student;
Query OK, 4 rows affected (0.00 sec)

mysql> select * from student;
Empty set (0.00 sec)

mysql> insert into student(name) values('ysb');
mysql> select * from student;
+----+------+------+
| id | name | sex  |
+----+------+------+
|  8 | ysb  | male |
+----+------+------+

#应该用truncate清空表,比起delete一条一条地删除记录,truncate是直接清空表,在删除大表时用它
mysql> truncate student;
Query OK, 0 rows affected (0.01 sec)

mysql> insert into student(name) values('egon');
Query OK, 1 row affected (0.01 sec)

mysql> select * from student;
+----+------+------+
| id | name | sex  |
+----+------+------+
|  1 | egon | male |
+----+------+------+
row in set (0.00 sec)

View
Code

澳门葡京备用网址 144澳门葡京备用网址 145

#在创建完表后,修改自增字段的起始值
mysql> create table student(
    -> id int primary key auto_increment,
    -> name varchar(20),
    -> sex enum('male','female') default 'male'
    -> );

mysql> alter table student auto_increment=3;

mysql> show create table student;
.......
ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8

mysql> insert into student(name) values('egon');
Query OK, 1 row affected (0.01 sec)

mysql> select * from student;
+----+------+------+
| id | name | sex  |
+----+------+------+
|  3 | egon | male |
+----+------+------+
row in set (0.00 sec)

mysql> show create table student;
.......
ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8


#也可以创建表时指定auto_increment的初始值,注意初始值的设置为表选项,应该放到括号外
create table student(
id int primary key auto_increment,
name varchar(20),
sex enum('male','female') default 'male'
)auto_increment=3;




#设置步长
sqlserver:自增步长
    基于表级别
    create table t1(
        id int。。。
    )engine=innodb,auto_increment=2 步长=2 default charset=utf8

mysql自增的步长:
    show session variables like 'auto_inc%';

    #基于会话级别
    set session auth_increment_increment=2 #修改会话级别的步长

    #基于全局级别的
    set global auth_increment_increment=2 #修改全局级别的步长(所有会话都生效)


#!!!注意了注意了注意了!!!
If the value of auto_increment_offset is greater than that of auto_increment_increment, the value of auto_increment_offset is ignored. 
翻译:如果auto_increment_offset的值大于auto_increment_increment的值,则auto_increment_offset的值会被忽略 
比如:设置auto_increment_offset=3,auto_increment_increment=2




mysql> set global auto_increment_increment=5;
Query OK, 0 rows affected (0.00 sec)

mysql> set global auto_increment_offset=3;
Query OK, 0 rows affected (0.00 sec)

mysql> show variables like 'auto_incre%'; #需要退出重新登录
+--------------------------+-------+
| Variable_name            | Value |
+--------------------------+-------+
| auto_increment_increment | 1     |
| auto_increment_offset    | 1     |
+--------------------------+-------+



create table student(
id int primary key auto_increment,
name varchar(20),
sex enum('male','female') default 'male'
);

mysql> insert into student(name) values('egon1'),('egon2'),('egon3');
mysql> select * from student;
+----+-------+------+
| id | name  | sex  |
+----+-------+------+
|  3 | egon1 | male |
|  8 | egon2 | male |
| 13 | egon3 | male |
+----+-------+------+

步长increment与起始偏移量offset:auto_increment_increment,auto_increment_offset

View
Code

 

(5)  foreign  key

职工音讯表有四个字段:工号  姓名
 部门

公司有一个单位,不过有2个亿的职工,那表示部门这些字段须求再行存款和储蓄,部门名字越长,越浪费

解决措施:

咱俩全然能够定义2个机关表

下一场让职工新闻表关联该表,怎么样关联,即foreign
key

澳门葡京备用网址 146澳门葡京备用网址 147

#表类型必须是innodb存储引擎,且被关联的字段,即references指定的另外一个表的字段,必须保证唯一
create table department(
id int primary key,
name varchar(20) not null
)engine=innodb;

#dpt_id外键,关联父表(department主键id),同步更新,同步删除
create table employee(
id int primary key,
name varchar(20) not null,
dpt_id int,
constraint fk_name foreign key(dpt_id)
references department(id)
on delete cascade
on update cascade 
)engine=innodb;


#先往父表department中插入记录
insert into department values
(1,'欧德博爱技术有限事业部'),
(2,'艾利克斯人力资源部'),
(3,'销售部');


#再往子表employee中插入记录
insert into employee values
(1,'egon',1),
(2,'alex1',2),
(3,'alex2',2),
(4,'alex3',2),
(5,'李坦克',3),
(6,'刘飞机',3),
(7,'张火箭',3),
(8,'林子弹',3),
(9,'加特林',3)
;


#删父表department,子表employee中对应的记录跟着删
mysql> delete from department where id=3;
mysql> select * from employee;
+----+-------+--------+
| id | name  | dpt_id |
+----+-------+--------+
|  1 | egon  |      1 |
|  2 | alex1 |      2 |
|  3 | alex2 |      2 |
|  4 | alex3 |      2 |
+----+-------+--------+


#更新父表department,子表employee中对应的记录跟着改
mysql> update department set id=22222 where id=2;
mysql> select * from employee;
+----+-------+--------+
| id | name  | dpt_id |
+----+-------+--------+
|  1 | egon  |      1 |
|  3 | alex2 |  22222 |
|  4 | alex3 |  22222 |
|  5 | alex1 |  22222 |
+----+-------+--------+

示范

 

澳门葡京备用网址 148澳门葡京备用网址 149

表1 foreign key 表2
则表1的多条记录对应表2的一条记录,即多对一

利用foreign key的原理我们可以制作两张表的多对多,一对一关系
多对多:
    表1的多条记录可以对应表2的一条记录
    表2的多条记录也可以对应表1的一条记录

一对一:
    表1的一条记录唯一对应表2的一条记录,反之亦然

分析时,我们先从按照上面的基本原理去套,然后再翻译成真实的意义,就很好理解了

扶持精通

#一对多或称为多对一
三张表:出版社,作者信息,书

一对多(或多对一):一个出版社可以出版多本书

关联方式:foreign key

澳门葡京备用网址 150澳门葡京备用网址 151

=====================多对一=====================
create table press(
id int primary key auto_increment,
name varchar(20)
);

create table book(
id int primary key auto_increment,
name varchar(20),
press_id int not null,
foreign key(press_id) references press(id)
on delete cascade
on update cascade
);


insert into press(name) values
('北京工业地雷出版社'),
('人民音乐不好听出版社'),
('知识产权没有用出版社')
;

insert into book(name,press_id) values
('九阳神功',1),
('九阴真经',2),
('九阴白骨爪',2),
('独孤九剑',3),
('降龙十巴掌',2),
('葵花宝典',3)
;

View
Code

 

#多对多
三张表:出版社,作者信息,书

多对多:一个作者可以写多本书,一本书也可以有多个作者,双向的一对多,即多对多
  
关联方式:foreign key+一张新的表

澳门葡京备用网址 152澳门葡京备用网址 153

=====================多对多=====================
create table author(
id int primary key auto_increment,
name varchar(20)
);


#这张表就存放作者表与书表的关系,即查询二者的关系查这表就可以了
create table author2book(
id int not null unique auto_increment,
author_id int not null,
book_id int not null,
constraint fk_author foreign key(author_id) references author(id)
on delete cascade
on update cascade,
constraint fk_book foreign key(book_id) references book(id)
on delete cascade
on update cascade,
primary key(author_id,book_id)
);


#插入四个作者,id依次排开
insert into author(name) values('egon'),('alex'),('yuanhao'),('wpq');

#每个作者与自己的代表作如下
egon: 
九阳神功
九阴真经
九阴白骨爪
独孤九剑
降龙十巴掌
葵花宝典
alex: 
九阳神功
葵花宝典
yuanhao:
独孤九剑
降龙十巴掌
葵花宝典
wpq:
九阳神功


insert into author2book(author_id,book_id) values
(1,1),
(1,2),
(1,3),
(1,4),
(1,5),
(1,6),
(2,1),
(2,6),
(3,4),
(3,5),
(3,6),
(4,1)
;

View
Code

 

#一对一
两张表:学生表和客户表

一对一:一个学生是一个客户,一个客户有可能变成一个学校,即一对一的关系

关联方式:foreign key+unique

澳门葡京备用网址 154澳门葡京备用网址 155

#一定是student来foreign key表customer,这样就保证了:
#1 学生一定是一个客户,
#2 客户不一定是学生,但有可能成为一个学生


create table customer(
id int primary key auto_increment,
name varchar(20) not null
);


create table student(
id int primary key auto_increment,
name varchar(20) not null,
class_name varchar(20) not null default 'python自动化',
level int default 1,
customer_id int unique, #该字段一定要是唯一的
foreign key(customer_id) references customer(id) #外键的字段一定要保证unique
on delete cascade
on update cascade
);


#增加客户
insert into customer(name) values
('李飞机'),
('王大炮'),
('守榴弹'),
('吴坦克'),
('赢火箭'),
('战地雷')
;


#增加学生
insert into student(name,customer_id) values
('李飞机',1),
('王大炮',2)
;

View
Code

澳门葡京备用网址 156澳门葡京备用网址 157

例一:一个用户只有一个博客

    用户表:
    id  name
   egon
   alex
   wupeiqi


    博客表   
           fk+unique
    id url name_id
 xxxx   1
 yyyy   3
 zzz    2



例二:一个管理员唯一对应一个用户
    用户表:
    id user  password
 egon    xxxx
 alex    yyyy

    管理员表:
       fk+unique
    id user_id password
  1      xxxxx
  2      yyyyy

其他例子

View
Code

  

练习:账号消息表,用户组,主机表,主机组

澳门葡京备用网址 158澳门葡京备用网址 159

#用户表
create table user(
id int not null unique auto_increment,
username varchar(20) not null,
password varchar(50) not null,
primary key(username,password)
);

insert into user(username,password) values
('root','123'),
('egon','456'),
('alex','alex3714')
;


#用户组表
create table usergroup(
id int primary key auto_increment,
groupname varchar(20) not null unique
);

insert into usergroup(groupname) values
('IT'),
('Sale'),
('Finance'),
('boss')
;


#主机表
create table host(
id int primary key auto_increment,
ip char(15) not null unique default '127.0.0.1'
);

insert into host(ip) values
('172.16.45.2'),
('172.16.31.10'),
('172.16.45.3'),
('172.16.31.11'),
('172.10.45.3'),
('172.10.45.4'),
('172.10.45.5'),
('192.168.1.20'),
('192.168.1.21'),
('192.168.1.22'),
('192.168.2.23'),
('192.168.2.223'),
('192.168.2.24'),
('192.168.3.22'),
('192.168.3.23'),
('192.168.3.24')
;


#业务线表
create table business(
id int primary key auto_increment,
business varchar(20) not null unique
);
insert into business(business) values
('轻松贷'),
('随便花'),
('大富翁'),
('穷一生')
;


#建关系:user与usergroup

create table user2usergroup(
id int not null unique auto_increment,
user_id int not null,
group_id int not null,
primary key(user_id,group_id),
foreign key(user_id) references user(id),
foreign key(group_id) references usergroup(id)
);

insert into user2usergroup(user_id,group_id) values
(1,1),
(1,2),
(1,3),
(1,4),
(2,3),
(2,4),
(3,4)
;



#建关系:host与business

create table host2business(
id int not null unique auto_increment,
host_id int not null,
business_id int not null,
primary key(host_id,business_id),
foreign key(host_id) references host(id),
foreign key(business_id) references business(id)
);

insert into host2business(host_id,business_id) values
(1,1),
(1,2),
(1,3),
(2,2),
(2,3),
(3,4)
;

#建关系:user与host

create table user2host(
id int not null unique auto_increment,
user_id int not null,
host_id int not null,
primary key(user_id,host_id),
foreign key(user_id) references user(id),
foreign key(host_id) references host(id)
);

insert into user2host(user_id,host_id) values
(1,1),
(1,2),
(1,3),
(1,4),
(1,5),
(1,6),
(1,7),
(1,8),
(1,9),
(1,10),
(1,11),
(1,12),
(1,13),
(1,14),
(1,15),
(1,16),
(2,2),
(2,3),
(2,4),
(2,5),
(3,10),
(3,11),
(3,12)
;

View
Code 

 

伍、表的操作

澳门葡京备用网址 160澳门葡京备用网址 161

语法:
1. 修改表名
      ALTER TABLE 表名 
                          RENAME 新表名;

2. 增加字段
      ALTER TABLE 表名
                          ADD 字段名  数据类型 [完整性约束条件…],
                        ADD 字段名  数据类型 [完整性约束条件…];
    ALTER TABLE 表名
                          ADD 字段名  数据类型 [完整性约束条件…]  FIRST;
    ALTER TABLE 表名
                            ADD 字段名  数据类型 [完整性约束条件…]  AFTER 字段名;

3. 删除字段
      ALTER TABLE 表名 
                                    DROP 字段名;

4. 修改字段
      ALTER TABLE 表名 
                          MODIFY  字段名 数据类型 [完整性约束条件…];
      ALTER TABLE 表名 
                          CHANGE 旧字段名 新字段名 旧数据类型 [完整性约束条件…];
      ALTER TABLE 表名 
                          CHANGE 旧字段名 新字段名 新数据类型 [完整性约束条件…];

示例:
1. 修改存储引擎
mysql> alter table service 
    -> engine=innodb;

2. 添加字段
mysql> alter table student10
    -> add name varchar(20) not null,
    -> add age int(3) not null default 22;

mysql> alter table student10
    -> add stu_num varchar(10) not null after name;                //添加name字段之后

mysql> alter table student10                        
    -> add sex enum('male','female') default 'male' first;          //添加到最前面

3. 删除字段
mysql> alter table student10
    -> drop sex;

mysql> alter table service
    -> drop mac;

4. 修改字段类型modify
mysql> alter table student10
    -> modify age int(3);
mysql> alter table student10
    -> modify id int(11) not null primary key auto_increment;    //修改为主键

5. 增加约束(针对已有的主键增加auto_increment)
mysql> alter table student10 modify id int(11) not null primary key auto_increment;
ERROR 1068 (42000): Multiple primary key defined

mysql> alter table student10 modify id int(11) not null auto_increment;
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

6. 对已经存在的表增加复合主键
mysql> alter table service2
    -> add primary key(host_ip,port);        

7. 增加主键
mysql> alter table student1
    -> modify name varchar(10) not null primary key;

8. 增加主键和自动增长
mysql> alter table student1
    -> modify id int not null primary key auto_increment;

9. 删除主键
a. 删除自增约束
mysql> alter table student10 modify id int(11) not null; 

b. 删除主键
mysql> alter table student10                                 
    -> drop primary key;

修改表alter
table

澳门葡京备用网址 162澳门葡京备用网址 163

复制表结构+记录 (key不会复制: 主键、外键和索引)
mysql> create table new_service select * from service;

只复制表结构
mysql> select * from service where 1=2;        //条件为假,查不到任何记录
Empty set (0.00 sec)
mysql> create table new1_service select * from service where 1=2;  
Query OK, 0 rows affected (0.00 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> create table t4 like employees;

复制表

澳门葡京备用网址 164澳门葡京备用网址 165

drop table 表名;

删除表

 

3、存款和储蓄引擎

 

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

*
*
Website