1.字符编码与配置文件

1.\s:查看当前MySQL相关信息:当前用户、版本、编码、端口号。
"""
Server characterset、Db characterset、Client characterset、Conn.characterset每个编码都不一样,我们需要手动改成utf8,注:MySQL5.6及之前的版本编码需要人为统一,之后的版本已经全部默认统一
"""

2.永久修改步骤:
2.1默认的配置文件是my-default.ini,拷贝上述文件并重命名为my.ini
2.2拷贝以下的代码:
[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_general_ci
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4
"""
PS:
1.utf8mb4能够存储表情,比utf8功能更强大
2.utf8与utf-8是有区别的,MySQL中只有utf
8"""
2.3修改了配置文件中关于[mysqld]的配置,需要重启服务端

2.数据库存储引擎

1.存储引擎:数据库针对数据采用的多种存取方式。

2.查看常见的存储引擎的方式:show engines;

3.需要了解的四个存储引擎:
'''MySQL中忽略大小写'''
3.1 MyISAM:MySQL5.5之前默认的存储引擎,特点:存储速度快,但是功能较少,安全性较低。 3.2 InnoDB:MySQL5.5之后的存储引擎,支持事务、行锁、外键等操作,存取速度没有MyISAM快,但是安全性更高。
"""
事务:某些操作因为系统原因没有及时更新,例如银行转账转款一端余额减少,收款一段余额未增加,事务有能力让余额回退到操作前的阶段。 行锁:比如共享文档,有人在操作某一行的时候其他人是无法操作的
"""
3.3 Memory:基于内存存取数据,仅用于临时表数据存取。 3.4 BlackHole:任何写入的数据都会立刻丢失。

3.创建表的完整语法

1.语法:create table 表名(
字段名 字段类型(数字) 约束条件,
字段名 字段类型(数字) 约束条件,
字段名 字段类型(数字) 约束条件
)
注意:
1.字段名和字段类型是必须要有的
2.数字和约束条件是可以没有的
3.约束条件也可优选多个,空格隔开即可
4.最后一行结尾不能加逗号

4.字段类型之整形

mysql中的整形有以下几种:
1.tinyint: 大小:1bytes(8个比特位,也就是8位0或1),unsigned情况下包含0,不包含256。
'''tinyint可以是正数也可以是负数,有正负号时结果是2**7有128种结果,无正负号时有2**8有256种结果。所以说tinyint表示的整形结果很有限'''
2.smallint: 大小:2bytes,包含正负号,unsigned情况下包含0,不包含65536。
'''2个字节是16位0或1,无正负号时可以表示65536种结果,有正负号时可以表示32768种结果'''
3.int、integer:大小4bytes,包含正负号,unsigned情况下包含0,不包含4294967296。
'''4个字节是32位0或1,无正负号可以表示4294967296种结果,有正负号可以表示2147483648种结果。结果无法表示电话号码'''
4.bigint:大小:8bytes,包含正负号,可以存储电话号码,unsigned情况下包含0,不包含18446744073709551616。

验证整形是否带正负号:


===

说明上述整形类型都是带符号的,可正可负。
我们也可以取消正负号,让所有比特位都用来表示数字:
创建方法: create table 表(字段名 tinyint unsigned)

"""
针对上述效果,添加超出范围的数字可以显示范围末端的数字,这种情况在5.7以上版本都会直接报错,而5.6版本需要手动修改
"""

5.严格模式

1.我们在使用数据库当中存储数据在范围外的数字应该直接报错,而不应该是添加一个范围末端的数字。针对上述需求,我们在5.6版本mysql做以下操作:
1.1首先输入show variables like '%mode%'查看sql_mode,发现里面没有添加任何东西。就是因为我们在新建my.ini配置文件时没有添加上去。

	1.2直接修配置文件,在my.ini中的服务端mysqld中加入:sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES。再重启mysqld服务端(net stop mysql; net start mysql),发现我们再插入数字超出范围的时候会直接报错。


===

===

===

6.字段类型之浮点型

1.float:float(30,20)指总共30个位数字,小数点前面10位,小数点后面20个数。

2.double:double(30,20)指总共300个数.小数点后面20个数。

3.decimal:decimal(30,20)指总共300个数.小数点后面20个数。

根据以上操作得出结论,三者不同在于精度,精度decimal>double>float

7.字段类型之字符类型

1.char:也叫定长。
char(4):最多4个字符(英文和汉字都不能超过4个字符,字符和字节要分开),过长就报错,不够四个空格填充至4个。
2.varchar:也叫变长。
varchar(4):最多4个字符,过长就报错,不够几位则存几位。

"""
经过上述操作验证:长度不足4都是本身的长度,也就是说char(4)并没,没有我们刚才叙述的效果,那么我们换一种方式再来验证。
"""
3.查看长度:select char_length(字段名) from 表名;查看某个字段下数据的长度。

"""
验证得知:char(4)模式字符添加的数据值长度还是原来的长度,并没有填充至4个。这是因为默认情况下MySQL针对char的存储会自动填充空格和删除空格。
""" 4.char与varchar对比:
char
优势:整存整取、速度快()
劣势:浪费存储空间
'''如果添加字符长度不等的数据,底层会自动将数据补全至定长。取的时候也是按定长来取,存取方便'''
varchar
优势:节省存储空间
劣势:存取数据的速度较char慢
'''存的时候会自动保留原来的字符长度,节省空间,但是取出的时候不好取,因为字符长度都不一致。取出的时候可以在每个名字前面加上报头,通过把报头解析出每个名字的长度。所以varchar存取数据的速度较char慢'''
char与varchar的使用需要结合具体应用场景

8.数字的含义

1.数字在很多地方都是用来表示限制存储数据的长度,但是在整型中数字不是用来限制储存数据的长度。

"""
验证发现int后面的数字设置为3,依然可以添加4位的数字。所以整型后面的数字不是用来限制数字长度的
"""
2.通过验证得知,int后面加参数没有什么用而加上zerofill之后int后面的参数就可以控制显示位数。图中不足5位的会自动补全成5位,超过5位不超过int范围几位就是几位。

综上所述,整形后面不用加数字,如果不写数字创建整型的时候系统也会自动补全成11。

9.字段类型之枚举与集合

1.枚举:在生成表的过程中,很多场景需要让用户来选择选项,比如让用户选择性别。语法结构为:字段名 enum(选项1, 选项2, 选项3)。如果被限制的字段名添加的是enum后面括号中的选项时,就会正常添加。如果不是中间的某个选项,就会直接报错。

2.集合:在生成表的过程中,如果某一项内容有多个选项供用户多选,可以用几何来操作。语法结构为:字段名 set(选项1, 选项2, 选项3)。集合中的选项可以多选,也可以单选,多选时候逗号两边不能加空格。

10.字段类型之日期类型

1.日期类型:
datetime 年月日时分秒
date 年月日
time 时分秒
year 年
时间类型和python当中类似,目前我们用自定义的时间尝试插入表,后期可以用系统自动生成,无需我们操作。

MySQL-SQL语法、字段类型的更多相关文章

  1. SQL Server 字段类型 decimal(18,6)小数点前是几位?记一次数据库SP的BUG处理

    原文:SQL Server 字段类型 decimal(18,6)小数点前是几位?记一次数据库SP的BUG处理 SQL Server 字段类型 decimal(18,6)小数点前是几位? 不可否认,这是 ...

  2. Oracle/SQL 修改字段类型和长度

    标准SQL修改字段类型和长度语句: ALTER TABLE tableName modify column columnName 类型;例如Mysql的修改字段类型语句:alter table tes ...

  3. Mysql基础1-基础语法-字段类型

    主要: 基础 字段类型 基础 基本概念 1) 数据库分类 层次数据库,网状数据库,关系数据库 常见:SQL Server, Oracle,infomix,sybase,ibmDB2,Mysql 2)数 ...

  4. MySQL数据库 存储引擎,创建表完整的语法,字段类型,约束条件

    1.存储引擎 - 存储引擎是用于根据不同的机制处理不同的数据. - 查看mysql中所有引擎: - show engines; - myisam: 5.5以前老的版本使用的存储引擎 - blackho ...

  5. sql server2008 字段类型

    bit    整型 bit数据类型是整型,其值只能是0.1或空值.这种数据类型用于存储只有两种可能值的数据,如Yes 或No.True 或False .On 或Off. 注意:很省空间的一种数据类型, ...

  6. 转: sql server2008 字段类型详解

    bit 整型 bit数据类型是整型,其值只能是0.1或空值.这种数据类型用于存储只有两种可能值的数据,如Yes 或No.True 或False .On 或Off. 注意:很省空间的一种数据类型,如果能 ...

  7. sql 数据字段类型

    bit    整型 bit数据类型是整型,其值只能是0.1或空值.这种数据类型用于存储只有两种可能值的数据,如Yes 或No.True 或False .On 或Off. 注意:很省空间的一种数据类型, ...

  8. MySQL开发——【字段类型、约束】

    创建数据表 基本语法: create table 数据表名称( 字段名称 字段类型 字段约束, ... )[表选项]; 字段类型 整数型 ,有符号型,可以表示 ,有符号型,可以表示 mediumint ...

  9. MySQL数据库中字段类型为tinyint,读取出来为true/false的问题

    由于MySQL中没有boolean类型,所以会用到tinyint类型来表示. 数据库一个表中有一个tinyint类型的字段,值为0或者1,如果取出来的话,0会变成false,1会变成true.

  10. SQL常用字段类型

    中文常用字段类型 1.   名称类    nvarchar(10) 2.   数量       int 3.   时间      date 4.   货币      money 5.   编号     ...

随机推荐

  1. JUC学习笔记——进程与线程

    JUC学习笔记--进程与线程 在本系列内容中我们会对JUC做一个系统的学习,本片将会介绍JUC的进程与线程部分 我们会分为以下几部分进行介绍: 进程与线程 并发与并行 同步与异步 线程详解 进程与线程 ...

  2. 基于SpERT的中文关系抽取

    SpERT_chinese 基于论文SpERT: "Span-based Entity and Relation Transformer"的中文关系抽取,同时抽取实体.实体类别和关 ...

  3. go工具pprof部署

    在做内存分析时,用到了pprof,这里做一下部署介绍和入门级别的使用. pprof是golang的性能工具,有两种交互方式:命令行交互和web交互,同时还支持性能分析数据的图形化展示. 部署pprof ...

  4. 【Java集合框架001】为什么重写equals就要重写hashcode?

    一.前言 如果面试官问:你重写过 hashcode 和 equals 么,为什么重写equals时必须重写hashCode方法? 遇到这样的问题,应该怎样回答呢?其实,equals和hashCode都 ...

  5. Java阻塞队列中的异类,SynchronousQueue底层实现原理剖析

    上篇文章谈到BlockingQueue的使用场景,并重点分析了ArrayBlockingQueue的实现原理,了解到ArrayBlockingQueue底层是基于数组实现的阻塞队列. 但是Blocki ...

  6. Kubernetes专栏 | 安装部署(一)

    --随着云原生概念的普及,许多企业的业务纷纷上云,为了追求可靠性,稳定性,和弹性伸缩,提升资源利用率等需求.Kubernetes这个谷歌开源的容器编排平台已日益流行,被大家熟知和使用. 通常来说,Ku ...

  7. 【每日一题】【找到位置返回&升序数组中第K大就是n-K小】2022年1月17日-NC88 寻找第K大

    描述有一个整数数组,请你根据快速排序的思路,找出数组中第 k 大的数. 给定一个整数数组 a ,同时给定它的大小n和要找的 k ,请返回第 k 大的数(包括重复的元素,不用去重),保证答案存在. 方法 ...

  8. JavaScript入门⑤-欲罢不能的对象原型与继承-全网一般图文版

    JavaScript入门系列目录 JavaScript入门①-基础知识筑基 JavaScript入门②-函数(1)基础{浅出} JavaScript入门③-函数(2)原理{深入}执行上下文 JavaS ...

  9. <一>C++ STL

    STL (standard template libaray - 标准模板库):是 C++ 标准库的重要组成部分,不仅是一个可复用的组件库,而且是一个包罗数据结构与算法的软件框架. 通俗来说:STL就 ...

  10. 深度学习之Transformer网络

    [博主使用的python版本:3.6.8] 本次没有额外的资料下载 Packages ort tensorflow as tf import pandas as pd import time impo ...