时间:2021-07-01 10:21:17 帮助过:21人阅读
? 1. 关系型 :需要有表结构
? 2. 非关系型 :key-value 进行存储的,没有表结构
1. Innodb存储引擎:支持事务,mysql默认引擎
2. MyISAM :不支持事务,存储速度比innodb快
3. memory :只存储在内存中,一旦mysql进行重启,数据会全部丢失
4. blackhole 黑洞存储引擎:存入就没了
create table t1(id int,name char(10)) engine=innodb;
语法:字段名1 类型[(宽度) 约束条件
注意:字段名与类型是必须要有的,其他可选
create table t1(id int(长度) 约束条件例如:primary key);
create table t5 select * from t1;
create table t5 select * from t1 where 1>2;
create table t5 like db2.t1;
function | info |
---|---|
now() | 获取当前的时间 |
char_length() | 获取字符长度 |
length() | 获取字节数 |
tinyint 这个一般用于布尔值的时候tinyint(1) 与 tinyint(0)
int 一般这个比较常用
bigint
float(m,d) 计算精度小
double(m,d) 计算精度比单浮点型要高
decimal(m,d) 计算精度比前面两个都要高
year
date
datetime
time
timestmp
create table t9(born_year year,born_date,born_time time,born_datetime datetime);
insert into t8 values(now(),now(),now(),now());
select * from t8;
char类型:定长,简单粗暴,浪费空间,存取速度快,但是会填充空格来满足固定长度,查询的时候会把后面的空格删掉进行显示,但是存储的时候是补充了一堆的空格在里面
varchar类型:变长,精准,节省空间,存取速度慢
注意:尽量使用char来代替varchar,因为varchar影响效率
查看当前mysql模式
select @@sql_mode;
其他字符串系列(效率:char>varchar>text)
enum 多里选一个 比如性别 enum( ‘男’,‘女’ )
set 多里选多个 比如爱好: hobby set (‘篮球’,‘足球’)
create table t1(id int primary key auto_increment,sex enum('男','女') not null)
create table t1(id int primary key auto_increment,hobby set('篮球','游泳') not null)
zerofill :用0进行补充长度 ,也等同于unsigned + zerofill
create table t1(id int primary key auto_increment,age int unsigned )
create table t1(id int primary key auto_increment,is_true int zerofill)
Mysql_数据类型
标签:字符 inno 关系 create nod 查看 数据类型 sql_mode 空间