一、存储引擎

不同的存储引擎对应着不同的对数据的处理机制

mysql主要的存储引擎

  • innodb

    • 是mysql5.5版本之后默认的存储引擎,数据相对更安全
  • myisam
    • 是mysql5.5版本之前的默认存储引擎,速度快
  • memory
    • 内存引擎,断电丢失
  • blackhole
    • 无论存什么都会立刻消失(黑洞)

用代码测试不同引擎的区别

# 查看所有的存储引擎
show engines;

# 不同的存储引擎在存储表的时候 异同点
create table t1(id int) engine=innodb;
create table t2(id int) engine=myisam;
create table t3(id int) engine=blackhole;
create table t4(id int) engine=memory;

结果

​ 对每个表添加一个数据可以看到除了blackhole引擎,其他表的数据都还在,这里要注意,memory的数据只是存在内存中了,重启一下服务数据就丢失了

创建表的完整语法

# 基本语法
create table 表名(
字段1 类型(宽度(可不写)) 约束条件,
字段1 类型(宽度(可不写)) 约束条件,
字段1 类型(宽度(可不写)) 约束条件
)

注意

  • 在同一张表中的字段名不能重复
  • 宽度和约束条件是可选的,有默认值,字段名和字段类型必须写,约束条件可以写多个
  • 最后一行不能有逗号
  • 针对不同版本对数据宽度的限定情况
    • 5.6版本默认没有开启严格模式,如果设定char(1)但是给了多个字符,会自动截取第一个
    • 5.7版本及以后默认开启了严格模式,存多了会报错
  • 约束条件举例:create table t6(id int,name char not null); not null表示这个字段的数据不能插入null
  • 宽度和约束条件的关系
    • 宽度:限制数据的长度
    • 约束条件:在宽度的基础上增加额外的约束

二、数据类型

前引:严格模式

  • 查看严格模式

    • show variables like “%mode”;
  • 模糊查询
    • 关键字like
    • %:匹配任意多个字符串
    • _:匹配任意单个字符串
  • 修改严格类型
    • set session 只在当前窗口有效
    • set global 全局有效
    • set global sql_mode = 'STRICT_TRANS_TABLES';
    • 修改完成之后重新进入服务端即可

1 整形

  • 分类

    • TINYINT SMALLINT MEDUMINT INT BIGINT
  • 举例
    • 年龄,等级,id
# 不同的整形类型最大的区别就是能取到的范围,如果超出这个范围只会存最大范围(非严格模式下)
# 以上的5中整形类型能取的范围依次增大,所以我们通常用int能应付大部分情况 # 例子:tinyint
如果我们创建了一个tinyint类型的字段,他的范围是-128~127,超出这个范围就会报错 # 特殊约束,unsigned约束可以让该字段的范围只有正数,会把负号内的位数全都带到正数中,也就是说
create table t6(id tinyint usigned);
# 这里的id的范围不再是-128~127 而是0~255 # 长度:整形内的长度不表示限制位数
# 例子:
id int(8)
# 如果数字没超出8位,默认用空格填充至8位(显示的时候会自动去除)
# 如果超出了8位,有几位存几位,但是还是遵循该类型的最大范围
# 我们可以用zerofill约束让空格变成0显示出来
create table t7(in int(8) zerofill);

2 浮点型

  • 分类

    • FLOAT、DOUBLE、DECIMAL
  • 举例
    • 身高、体重
# 储存限制(不写的默认值)
create table t10(id float(255,30));
create table t11(id double(255,30));
create table t12(id decimal(65,30)); # 插入数据验证区别
insert into t10 values(1.111111111111111111111111111111);
insert into t11 values(1.111111111111111111111111111111);
insert into t12 values(1.111111111111111111111111111111);

总结:

精度从小到大:float<double<decimal

具体场景用不同的精度

3 字符类型

3.1 类型

  • char 定长

    • char(4)数据超过4个字符直接报错,不够4个用空格补全
  • varchar 变长
    • varchar(4)数据超过4个字符直接报错,不够有几个存几个

3.2 举例验证区别

可以用length关键字来分析内含几个字符,

修改sql_mode = 'STRICT_TRANS_TABLES,PAD_CHAR_TO_FULL_LENGTH';

在重启服务后,这个修改能让mysql不做自动剔除操作

得到的结果是,同样只插入了一个字符的数据,varchar的长度是1,char的长度是4

3.3 对比优缺点

  • char

    • 缺点:浪费空间(因为会自动补全)
    • 优点:读取很简单,因为我们取的都是最大长度
  • varchar
    • 优点:节省空间(不会自动补全)
    • 缺点:读取麻烦,存取都需要报头来限定长度。

总结:两者各有好处,都有用处

4 日期类型

分类

  • date:年月日 2020-5-4
  • datetime :年月日时分秒 2020-5-4 20:28:28
  • time :时分秒 20:28:28
  • year:2020
create table student(
now_year year,
now_data date,
now_datatime datetime,
now_time time
);
insert into student values("2020","2020-5-4","2020-5-4 11:11:11","11:11:11");

5 枚举和集合类型

  • 枚举(enum)多选一
  • 集合(set)多选多

具体使用

create table user(

​ gender enum('male','female','others'),

​ hobby set('read','DBJ','hecha')

)

insert into user values('male','read,hecha');

前一个是枚举,可以在3个中选一个,后一个是集合,可以多选,也可以单选

但是这两种都不能选自己没有的!

day45 数据库基础的更多相关文章

  1. 数据库基础,表及SQL语句

    数据库基础及T-SQL语句 字符类型: int 整型 float 小数 double 小数 varchar(20) 字符串 bit 布尔型数据 datetime 日期时间类型 text 长文本 (以下 ...

  2. Oracle 数据库基础——安装

    一.数据库基础知识 1.概念 数据库全称数据库管理系统,简称DBMS,是一种在计算机中,针对数据进行管理.存储.共享的一种技术. 2.分类 数据库的发展过程中,按逻辑模型可分为以下几种: 3.关系型数 ...

  3. 10月14日下午MySQL数据库基础

    数据库基础 类型: 1.varchar:字符串,用于姓名班级,地址等,地址一般长50,姓名长20 2.int:整数,用于成绩,序号等 3.float:小数 4.bit:布尔型,用于性别等 5.时间也用 ...

  4. oracle系列--第一篇 数据库基础

    第一章 数据库基础 1.1 数据管理概述 1.1.1 什么是数据管理 与我们人类相比,计算机的最大优势就是能够高速.精准地运行,其运行的过程就是执行程序代码和操作指令.处理数据的过程.可以说,数据处理 ...

  5. PHP数据库基础

    PHP数据库基础: 1.varchar:字符串,用于姓名班级,地址等,地址一般长50,姓名长20 2.int:整数,用于成绩,序号等 3.float:小数 4.bit:布尔型,用于性别等 5.时间也用 ...

  6. 【MySQL】MySQL无基础学习和入门之一:数据库基础概述和实验环境搭建

    数据库基础概述  大部分互联网公司都选择MySQL作为业务数据存储数据库,除了MySQL目前还有很多公司使用Oracle(甲骨文).SQLserver(微软).MongoDB等. 从使用成本来区分可以 ...

  7. SQL 必知必会-- 第1课:数据库基础和什么是SQL

    第1课 了解SQL 1 1.1 数据库基础 11.2 什么是SQL 61.3 动手实践 71.4 小结 8 第一课主要是一些概念,具体笔记如下: 1,数据库(database):保存有组织的数据的容器 ...

  8. mysql数据库基础的简单操作指南

    最近在学习mysql,本文是做的关于mysql学习的笔记,跟大家分享一下,希望对大家学习mysql知识有所助益.mysql现在几乎已经成了网站建设的主流数据库,很多php网站系统都采用了mysql数据 ...

  9. 数据库基础(变量、运算符、if语句、while语句)

    数据库基础(变量.运算符.if语句.while语句)   变量: 定义变量:declare @变量名 数据类型 变量赋值:set @变量名 = 值 输出:print 变量或字符串 SQL语言也跟其他编 ...

随机推荐

  1. 程序员实用JDK小工具归纳,工作用得到

    在JDK的安用装目录bin下,有一些有非常实用的小工具,可用于分析JVM初始配置.内存溢出异常等问题,我们接下来将对些常用的工具进行一些说明. JDK小工具简介 在JDK的bin目录下面有一些小工具, ...

  2. .NET Core加解密实战系列之——RSA非对称加密算法

    目录 简介 功能依赖 生成RSA秘钥 PKCS1格式 PKCS8格式 私钥操作 PKCS1与PKCS8格式互转 PKCS1与PKCS8私钥中提取公钥 PEM操作 PEM格式密钥读取 PEM格式密钥写入 ...

  3. 安装 KubeSphere DevOps 系统

    1.  安装KubeSphere 安装了一夜,终于看到了期待已久的画面 第一步.硬件配置(PS:VirtualBox虚拟机): 操作系统:Ubuntu 18.04 CPU:4核 内存:8G 磁盘:60 ...

  4. @bzoj - 3724@ PA2014Final Krolestwo

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 你有一个无向连通图,边的总数为偶数. 设图中有k个奇点(度数为奇 ...

  5. Python删除一个列表元素的方法

    参考资料: https://www.cnblogs.com/xiaodai0/p/10564956.html https://www.cnblogs.com/huangbiquan/articles/ ...

  6. 什么是Galil(加利尔)运动控制卡,它是用来干嘛的呢?galil开发文件dmc32.dll,动态链接库,API

    什么是Galil(加利尔)运动控制卡,它是用来干嘛的呢?运动控制卡是基于PC总线,利用高性能微处理器(如 DSP)及大规模可编程器件实现多个伺服电机的多轴协调控制的一种高性能的步进/伺服电机运动控制卡 ...

  7. xenomai内核解析之双核系统调用(一)

    版权声明:本文为本文为博主原创文章,转载请注明出处.如有错误,欢迎指正.博客地址:https://www.cnblogs.com/wsg1100/ 目录 xenomai 内核系统调用 一.32位Lin ...

  8. 一分钟开始持续集成之旅系列之:C 语言 + Makefile

    作者:CODING - 朱增辉 前言 make 工具非常强大,配合 makefile 文件可以实现软件的自动化构建,但是执行 make 命令依然需要经历手动输入执行.等待编译完成.将目标文件转移到合适 ...

  9. OpenCV开发笔记(六十五):红胖子8分钟带你深入了解ORB特征点(图文并茂+浅显易懂+程序源码)

    若该文为原创文章,未经允许不得转载原博主博客地址:https://blog.csdn.net/qq21497936原博主博客导航:https://blog.csdn.net/qq21497936/ar ...

  10. 【漏洞一】检测到目标URL存在http host头攻击漏洞

    [漏洞] 检测到目标URL存在http host头攻击漏洞 [原因] 在项目中使用了 request.getServerName 导致漏洞的出现 不要使用request中的serverName,也就是 ...