一:引擎 引擎决定数据库存取数据的方式==>不同的特点==>不同的用户体验 前提是:引擎是建表时规定,提供给表使用的,不是数据库 show engines; #展示所有引擎 重点:innodb...三:数据库模式 sql_mode:反映数据库的全局变量 数据库模式限制的是客户端对服务器操作数据的方式(是否严格) 两种模式: no_engine_substitution;非安全性,... Mysql数据库支持:整形,浮点型,字符型,时间类型,枚举类型,集合类型 4.1:整形 类型: tinyint:1字节 -128~127 smallint:2字节 mediumint:3字节...,超过宽度可以存放,最终由数据类型所占字节决定 2.如果没有超过宽度,且有zerofill限制,会用0填充前置位的不足位 3.没有必要规定整形的宽度,默认设置的宽度就为该整形能存放数据的最大宽度 例如:...double:8字节,1.7E-308~1.7E+308 decimal: M,D 大值基础上+2 宽度:限制存储宽度 (M,D)=>M为位数,D为小数位 float(255,30):精度最低,最常用
它是MySQL的默认数据表类型,基于了传统的ISAM类型,ISAM是Indexed Sequential Access Method(有索引的顺序访问方法)的缩写,一般来说,它是存储记录和文件的标准方法...MyISAM表(TYPE=MYISAM)是ISAM类型的一种延伸,具有很多优化和增强的特性。 是MySQL的默认表类型。...即使是具有相当多的插入、更新和删除操作的表,智能防碎片逻辑也能保证其高性能的协作性。 二、InnoDB InnoDB是MySQL 4.0之后推出的一种比较新的数据表类型,这种类型是事务安全的。...精细的(行级和表级)锁提高了MySQL事务处理的带走度,同时其也支持无锁定读操作(以前只在Oracle中包含)和多版本的特性。 ...异步输入/输出和一系列的读缓冲将提高数据检索速度,同时可以进行文件的优化和内存的管理。需要的基础上支持自动在内存上创建散列索引来提高性能,使用缓冲来提高可靠性和数据库操作的速度。
数据库软件MDBS(数据库管理系统)在上节课教大家从MySQL官网下载并且安装的mysql-installer-community-5.7.28.0.msi就是数据库软件MDBS。...我们通常讲的数据库就是这个, 而不是数据库软件。3. 表(Table)某种特定类型的结构化清单,数据库中的每一个表的名字都是唯一的。...表有行和列组成,列中存储着表中某部分的信息3.1 列(Column)表中的某一个字段,所有表都是由一个或多个列组成的。数据库中每个列都有相应的数据类型。...3.2 行(Row)表中的一个记录,表中的数据都是按行存储的,垂直的列为表列,水平行为表行。二. 数据类型(DataType)所容许的数据的类型,数据库中每个列都有相应的数据类型。...不同数据类型的列,存储不同格式的数据。MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。对于我们约束数据的类型有很大的帮助。1.
大家好,又见面了,我是你们的朋友全栈君。 前言: 要了解一个数据库,我们必须了解其支持的数据类型。MySQL 支持大量的字段类型,其中常用的也有很多。...前面文章我们也讲过 int 及 varchar 类型的用法,但一直没有全面讲过字段类型,本篇文章我们将把字段类型一网打尽,讲一讲常用字段类型的用法。...浮点型主要有 float,double 两个,浮点型在数据库中存放的是近似值,例如float(6,3),如果插入一个数123.45678,实际数据库里存的是123.457,但总个数还以实际为准,即6位,...2.字符串类型 字符串类型也经常用到,常用的几个类型如下表: 其中 char 和 varchar 是最常用到的。char 类型是定长的,MySQL 总是根据定义的字符串长度分配足够的空间。...总结: 本篇文章主要介绍了 MySQL 中常用的字段类型,平时用到的字段类型基本都在这里了,以一张思维导图总结如下: 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。
常用的数据类型 int 数字范围-2**32 ~ 2**32-1 bigint 数字范围-2**63 ~ 2 ** 63-1 float float(m,d), 其中m表示的是有效位, d表示小数位 有效位就是把当前的小数...---- char 表示固定长度的字符串, 长度为255个字节 中文字符占据3~4个字节 varchar 表示不定长的字符串, 长度为0~65535个字节 TEXT 长文本类型, 最大长度占据64kb...---- datetime 如果当前时区发生更改, datetime类型不会发生更改, 与存入的日期保持一致. timestamp 如果当前时区发生更改, timestamp类型会跟着时区更改....常用的运算符 算术运算符 + - * / div 取商 SELECT 5 div 3 mod 取余 SELECT 5 mod 3 比较运算符 = 类似python中的 == SELECT 1 =1 !...and 3 is null 与 is not null 用来判断当前是否有记录 逻辑运算符 NOT AND OR XOR(了解) 异或, 两个值一个True, 一个为False, 当前表达式才为True 常用的函数
MySQL中的数据类型 类型 类型举例 整数类型 TINYINT...常见数据类型的属性,如下: MySQL关键字 含义 NULL 数据列可包含NULL值 NOT NULL...CHARACTER SET 'gbk' ); SHOW CREATE TABLE temp; [在这里插入图片描述] 规律: 如果创建表中的字段时没有指明字符集,就按创建表的字符集,如果创建表时没有指明字符集就按创建数据库时指明的字符集...,如果创建数据库没有指明字符集,就按数据库配置文件 my.ini 中的字符集。...字段的字符集<表的字符集<创建数据库的字符集<数据库配置文件中的字符集 查看 数据库配置文件中的字符集: SHOW VARIABLES LIKE 'character_%'; [在这里插入图片描述] 注意
DATABASE()函数 返回当前数据库名 ? VERSION()函数 返回当前数据库版本 ? USER()函数 返回当前登录用户名 ?...INET_ATON(IP)函数 返回IP地址的网络字节序表示 ? INET_NTOA(num)函数 返回网络字节代表的IP地址 ?...INET_ATON(IP)和INET_NTOA(num)函数主要的用途是将字符串的IP地址转换为数字表示的网络字节序,这样可以方便地进行IP或者网段的比较。...原因:字符串的比较是一个字符一个字符的比较,当对应字符相同时,就比较下一个,直到遇到能区分出大小的字符才停止比较,后面的字符也将忽略。...在例子中,192.168.1.3其实比192.168.1.20要大,因为3比2大,而不能用我们日常的思维3<20。
枚举类型使用陷阱 超级不推荐在mysql中设置某一字段类型为enum,但是存的值为数字,比如‘0’,‘1’,‘2’; 解释1:你会混淆,因为enum可以通过角标取值,但它的角标是从1开始,对于不熟悉这个字段的人这里会出错...“空”(不是null) 解释3:enum类型对于php等弱语言类型的支持很差,弱语言类型打引号和不打引号的值可能是同一类型,但是对于mysql中enum类型的字段来说,那就不一定是一回事了 结论:总之,...不要拿mysql的enum类型取存一些数字;如果你一定要使用这个字段去存数字,请把这个字段定义为int,然后在java代码中使用枚举类做一个对于这个字段值范围的一个限定!...; * Mysql中枚举类型Color定义取值的顺序是RED、GREEN、BLUE,因此,当这三个取值持久化到数据库表时,取值分别是0、1、2; * 意思就是我们这里存往数据库的数据是...0、1、2这样的数字,而不是RED、GREEN、BLUE字符串, 但是Mysql数据库中定义的是RED、GREEN、BLUE,并没有其它值所以报错 解决:在entity中使用@Enumerated(EnumType.STRING
在数据库中建表时,需要给数据定义一个数据库中的数据库类型,当需要给String类型定义一个数据库中的类型时,可以看见有两个选择,一个是varchar,另一个是char,有很多人不清楚两者的区别,包括自己在内...也就是说当将两者的长度都定为10,然后向其中存入一个字符串“good”,显然字符串“good”的长度不到10,当定义类型为char类型时,存入的长度依旧是10,由字符串“good”和后面的6个空格组成。...当我们定义为varchar类型时,长度就变为了4,“good”字符串原有的长度。 在获取数据时,char类型的数据需要使用trim()方法,去掉字符串后面多余的空格。...2、存储时,char类型的数据要比varchar类型的数据速度更快,因为其长度固定,方便存储于查找。...3、从存储空间的角度讲,因为插入类型数据的长度固定,有时候需要用空格进行占位,所以存储数据时占用更大的空间。而varchar却不会。
Mysql中的列类型: 数字类型 字符串类型 布尔型 日期时间类型 数字类型: 1个字节=8比特,但数字里有一个比特用于符号占位 TINYINT 占用1个字节,表示范围:-128~127 SMALLINT...0\0\0\0\0” VARCHAR(8)输入“abc”实际储存为 “abc ”即“abc\0” 时间类型: DATE 支持的范围是1000-01-01 ~ 9999-12-31 TIME 支持的范围是...N位 员工所在部门:可取值必须在部门表中存在过 主键约束: 列名 类型 PRIMARY KEY 声明为“主键”的列上不能出现NULL值,且不能重复,如学生编号、商品编号。...表中所有的记录行会自动按照主键列上的值进行排序。 一个表至多只能有一个主键列。 唯一约束: 列名 类型 UNIQUE 声明为“唯一”的列上不能出现重复值,但可以出现多个NULL值。...非空约束: 列名 类型 NOT NULL 声明为“非空”约束的列上不能出现NULL,但可以重复 检查约束对于Mysql不支持 默认值约束 列名 类型 Default 值 声明为“默认值”约束的列上没有值的将会默认采用默认设置的值
1、两者的存储方式不一样 TIMESTAMP:把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。...DATETIME:不做任何改变,基本上是原样输入和输出 2、两者所能存储的时间范围不一样 timestamp存储的时间范围为:‘1970-01-01 00:00:01.000000’ 到 ‘2038-01...:00:00分保存的数据,在东9区看到的是09:00:00,datetime与时区无关 6、timestamp 4个字节存储(实际上就是int),datetime 8个字节 7、如果timestamp的值超出范围...,mysql不会报错 8、如果是自动更新模式,手动修改数据导致timestamp字段更新 9、同时有两个timestamp字段默认值为current_timestamp会报错 参考资料: MySQL中...TIMESTAMP类型 和 DATETIME类型 的区别 http://www.studyofnet.com/news/1123.html
时间类型MySQL中的时间类型有三大类:日期(Date)、时间(Time)和年(Year)。...常见用法了解了五种类型的基本信息之后,这部分重点介绍一下MySQL中关于时间类型的一些常见用法。...这个在应用中是比较常用的,比如给定日期,返回所在周的周一:mysql> SET @d="2022-03-08";mysql> SELECT @d, DATE_SUB(@d, INTERVAL WEEKDAY...时间类型实践接下来我们从实践的角度,看看时间类型的使用。3.1 时间类型的选择MySQL中的五种时间类型,在我们的应用中该如何选择呢?...3.2 代码中时间的映射代码中我们使用MySQL的driver来解析,对于go来说就是https://github.com/go-sql-driver/mysql在连接数据库的时候,和时间相关的参数有loc
MySQL索引类型: 1、普通索引 最基本的索引,它没有任何限制,用于加速查询。 创建方法: a. ...如果是组合索引,则列值的组合必须唯一。 创建方法: a. ...(例如:name(11)) 4、组合索引 指多个字段上创建的索引,只有在查询条件中使用了创建索引时的第一个字段,索引才会被使用。...修改表结构 ALTER TABLE mytable ADD INDEX index_mytable_id_name (id,name); 5、全文索引 主要用来查找文本中的关键字,而不是直接与索引中的值相比较...fulltext索引跟其它索引大不相同,它更像是一个搜索引擎,而不是简单的where语句的参数匹配。
目录 数据库常用操作 查看所有数据库 创建数据库 切换(操作的数据库) 删除数据库 修改数据库编码 创建表 查看当前数据库所有表名称...查看指定某个表的创建语句 查看表结构 删除表 添加列 修改类名和类型 删除列 修改表名 插入 删除 更新 数据库常用操作 查看所有数据库 show databases; 创建数据库 ...create database if not exists mydb1; 切换(操作的数据库) use mydb1; 删除数据库 drop database if exists...show tables; 查看指定某个表的创建语句 show create table 表名; 查看表结构 desc 表名; 删除表 drop table 表名; 添加列 alter table...表名 add 列名 类型(长度)[约束]; 修改类名和类型 alter table 表名 change 旧列名 新列名 类型(长度)[约束]; 删除列 alter table 表名 drop 列名
问题一:如果使用可视化工具链接mysql? mysql默认情况下是不支持远程连接的!只需要几个步骤就能轻松搞定了。...1.vi /etc/mysql/my.cnf 修改里面bind-address项,将127.0.0.1改成0.0.0.0 2.重启mysql,service mysql restart 3.最后执行赋权命令...:mysql -u用户名 -p密码 -e "GRANT ALL PRIVILEGES ON *.* TO '赋权的用户名'@'%' IDENTIFIED BY '赋权的密码' WITH GRANT OPTION...GRANT OPTION;" 问题二:常见的一些修改操作?...alter table 表名称 modify 字段名称 字段类型 [是否允许非空]; 例: alter table test modify testcolumn Integer not null;
日期时间类型中包含以下几种数据类型: DATE TIME DATETIME TIMESTAMP YEAR 各类型都有具体的取值范围,超出或非法的其他值时,MySQL 会回退到 0。...TIMESTAMP 类型是个例外,给它设置一个超出范围的值时,将保存上该类型允许的最大值。...虽然 MySQL 支持多种格式进行日期时间的设置,但日期部分要求必须是 年-月-日 的形式才能正确解析。比如 98-09-04 是按年月日顺序解析的,而不是英文里常用的月日年,或者日月年。...通过设置 MySQL 相关参数,日期类型可保存原本非法的值,比如开启 ALLOW_INVALID_DATES 设置项时,可设置日期类型保存一个 2009-11-31 值,但正常情况下我们知道 11 月哪来什么...所以 MySQL 是支持将月日设置成 0,比如 2019-00-00。但这种情况下就无法从日期相关的操作中获得到准确的结果,比如使用 DATE_SUB() 或 DATE_ADD() 函数时。
MySQL中定义数据字段的类型对数据库的优化是非常重要,它支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。 数值类型 ? 日期和时间类型 ? 字符串类型 ?...CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同,它们的最大长度和是否尾部空格被保留等方面也不同,在存储或检索过程中不进行大小写转换。...另外,CHAR(n) 和 VARCHAR(n) 中括号中 n 代表字符的个数,并不代表字节个数,比如 CHAR(30) 就可以存储 30 个字符。...BLOB 是一个二进制大对象,可以容纳可变数量的数据,上表所示中有共有4种类型,它们区别在于可容纳存储范围不同。...TEXT 用于存文本数据,对应BLOB的4种类型,4种类型存储的最大长度不同,可根据实际情况选择。
07.14自我总结 MYSQL数据库约束类型 一.主键约束(primary key) 主键约束要求主键列的数据唯一,并且不能为空。主键分为两种类型:单字段主键和多字段联合主键。...一个表的外键可以为空,若不为空,则每一个外键值必须等于另一个表中主键的某个值。 外键的作用:保证数据应用的完整性。 ...主表(父表):对于两个具有关联关系的表而言,相关联字段中的主键所在的那个表即是主表。 从表(子表):对于两个具有关联关系的表而言,相关联字段中的外键所在的那个表即是从表。...非空约束 语法规则:字段名 数据类型 not null 创建表格后 alter table test modify 段名 数据类型 not null; 四.唯一性约束(Unique) 指定唯一约束 唯一约束...语法规则: 字段名 数据类型 Dfault 默认值 创建表格后 alter table test modify 段名 数据类型 Dfault 默认值;
本文链接:https://blog.csdn.net/weixin_38004638/article/details/96135519 一、数字类型 类型 范围 说明 Char(...Float 4 bytes,Double 8 bytes Double [(M,D)] -1.79E+308~1.79E+308( 约 ) Decimal [(M,D)] 2.1 int(2)中的...2是能存储的最小显示长度,如果插入的数据不够2位时,需要在数据前面用0补满2位。比如定义一个age字段,其数据类型为int(4),那用select查询出来的结果是“0002”。...但是我们发现,在实际查出来的结果中,并没有补全效果,这是因为系统默认不显示,如果想显示出来,增加zerofill约束即可。...最大长度为4294967295,如果输入的值比最大长度更大,则数据库会自动转为这个最大的数进行存储。这个数是2的32次方-1。int占32位。 2.3 int(2)和int(4)的区别?
数据类型 一、数据类型分类 mysql 中的数据类型分类如下,其中红色字体的为常用的类型: 二、数值类型 mysql 中表的建立属性列:列名称 数据类型,例如 num int,它与我们平时写的语言数据类型是倒过来的...1. tinyint 接下来我们创建一个只有 tinyint 类型的表,然后分别插入 1 和 128,会发现 128 插入失败,因为越界插入了,超出类型范围: 说明: 在 MySQL 中,整型可以指定是有符号的和无符号的...如果我们在上面的表格中插入大于两个字符的数据,如下,是会越界插入的: 这也就说明了一个问题,如果我们向 mysql 特定类型中插入不合法的数据,mysql 一般都是直接拦截我们,不让我们做对应的操作!...反过来,如果我们已经有数据被成功插入到 mysql 中,一定插入的时候是合法的!...所以,mysql 中,一般而言,数据类型本身也是一种约束,所谓约束,就是倒逼用户尽可能进行正确的插入,约束的是用户,这样就能保证数据库中的数据是可预期的,完整的。
领取专属 10元无门槛券
手把手带您无忧上云