前言: 要了解一个数据库,我们必须了解其支持的数据类型。MySQL 支持大量的字段类型,其中常用的也有很多。...浮点型主要有 float,double 两个,浮点型在数据库中存放的是近似值,例如float(6,3),如果插入一个数123.45678,实际数据库里存的是123.457,但总个数还以实际为准,即6位,...2.字符串类型 字符串类型也经常用到,常用的几个类型如下表: 其中 char 和 varchar 是最常用到的。char 类型是定长的,MySQL 总是根据定义的字符串长度分配足够的空间。...3.日期时间类型 MySQL支持的日期和时间类型有 YEAR 、TIME 、DATE 、DATETIME 、TIMESTAMP,几种类型比较如下: 涉及到日期和时间字段类型选择时,根据存储需求选择合适的类型即可...总结: 本篇文章主要介绍了 MySQL 中常用的字段类型,平时用到的字段类型基本都在这里了,以一张思维导图总结如下: 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。
07.14自我总结 MYSQL数据库约束类型 一.主键约束(primary key) 主键约束要求主键列的数据唯一,并且不能为空。主键分为两种类型:单字段主键和多字段联合主键。...,字段n] 2.自动增长 只能与primary key 联用 语法:字段 数据类型 primary key auto_increment n #n为起始位置,可以不填不填默认从1开始 二.外键约束(foreign...非空约束 语法规则:字段名 数据类型 not null 创建表格后 alter table test modify 段名 数据类型 not null; 四.唯一性约束(Unique) 指定唯一约束 唯一约束...语法规则:字段名 数据类型 Uniquel 再所有列创建完毕后:unique (字段名称) 创建表格后 alter table test modify 段名 数据类型 Unique; 五.默认约束(Default...语法规则: 字段名 数据类型 Dfault 默认值 创建表格后 alter table test modify 段名 数据类型 Dfault 默认值;
MYSQL数据库-数据类型 零、前言 一、数据类型分类 二、数据库的字段属性 三、数值类型 1、tinyint类型 2、bit类型 3、float类型 4、decimal类型 四、字符串类型 1、char...类型 2、varchar类型 3、char和varchar比较 4、日期和时间类型 5、enum和set类型 零、前言 本章主要讲解学习MYSQL数据库的数据类型 一、数据类型分类 数据类型示图:...二、数据库的字段属性 所谓字段属性就是用来修饰数据类型的 主要的字段属性: UnSigned:无符号的,声明了该列不能为负数 ZEROFILL:0填充的,不足位数的用0来填充 , 如int...较大的数据 8个字节 float 浮点数 4个字节 double 浮点数 8个字节 decimal 字符串形式的浮点数,一般用于金融计算 1、tinyint类型 数值越界测试: 说明: 在MySQL...,占用空间4个字节 示例:小数float(4,2)表示的范围是-99.99 ~ 99.99,MySQL在保存值时会进行四舍五入 示例:如果定义的是float(4,2) unsigned 这时,因为把它指定为无符号的数
MySQL索引类型: 1、普通索引 最基本的索引,它没有任何限制,用于加速查询。 创建方法: a. ...建表的时候一起创建 CREATE TABLE mytable ( name VARCHAR(32) , INDEX index_mytable_name (name) ); b....建表后,直接创建索引 CREATE INDEX index_mytable_name ON mytable(name); c....建表后,直接创建索引 CREATE UNIQUE INDEX index_mytable_name ON mytable(name); c....建表后,直接创建索引 CREATE INDEX index_mytable_id_name ON mytable(id,name); c.
1.索引类型 1.1 普通索引 NORMAL: 是最基本的索引,它没有任何限制。 1.2 唯一索引 SPATIAL: 与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。...它可以在create table,alter table ,create index使用,不过目前只有char、varchar,text 列上可以创建全文索引。...值得一提的是,在数据量较大时候,现将数据放入一个没有全局索引的表中,然后再用CREATE index创建fulltext索引,要比先为一张表建立fulltext然后再将数据写入的速度快很多。...所以我们在数据库设计时不要让字段的默认值为null。 3.2 使用短索引 对串列进行索引,如果可能应该指定一个前缀长度。...因此数据库默认排序可以符合要求的情况下不要使用排序操作;尽量不要包含多个列的排序,如果需要最好给这些列创建复合索引。
5.日期类型 5.1 datetime类型 与时区无关的, 占用8个字节的存储空间 datetime(6) 用于存储毫秒级别 时间范围是1000-01-01 00:00:00 到 9999-12-31...23:59:59 5.2 timestamp类型 本质存储的是时间戳, 使用int存储, 占用了4个字节....时间范围是1970-01-01到2038-01-19 类型显示依赖于所指定的时区 5.3 date类型和time类型 date类型存储常用于生日的存储....相比于字符串/datetime/int存储要更少, 只需要使用3个字节 使用date类型还可以利用日期时间函数进行日期之间的计算 时间范围: 1000-01-01到9999-12-31 不要使用字符串类型来存储日期时间数据...日期时间类型通常比字符串占用的存储空间更小 日期时间类型在进行查找过滤的时候可以利用日期来进行对比 日期时间 类型还有着丰富的处理函数, 可以方便的对时期类型进行日期计算 使用int不如使用timestamp
概述 MySQL主要包括五大数据类型: 数字、字符串、时间、其他。数据类型(data_type)是指系统中所允许的数据的类型。 MySQL数据类型定义了列中可以存储什么数据以及该数据怎样存储的规则。...数据库中的每个列都应该有适当的数据类型,用于限制或允许该列中存储的数据。例如,列中存储的为数字,则相应的数据类型应该为数值类型。...如果使用错误的数据类型可能会严重影响应用程序的功能和性能,所以在设计表时,应该特别重视数据列所用的数据类型。更改包含数据的列不是一件小事,这样做可能会导致数据丢失。...数据类型 数值类型 类型 大小 范围(有符号) 范围(无符号) 用途 TINYINT 1 字节 (-128, 127) (0, 255) 小整数值 SMALLINT 2 字节 (-32 768, 32...二进制类型 类型名称 说明 存储需求 BIT(M) 位字段类型 大约 (M+7)/8 字节 BINARY(M) 固定长度二进制字符串 M 字节 VARBINARY (M) 可变长度二进制字符串 M+1
07.14自我总结 MYSQL数据库数据类型 一.整数类型和浮点数典型 1.有符号/没符号 对于整数和负整数来说,默认情况下是有符号范围的 默认是有符号 有符号和没符号其实就是有没有包括负数,有符号是包括负数的...(0,+) 超出范围取极值 2.严选/非严选 我们不推荐使用非严格模式下建立table,因为它会可能造成数据丢失的情况,所以我们必须在5.6版本中将mysql设置为严格模式。...STRICT_TRANS_TABLES '; 方法二:直接修改配置文件; [mysqld] sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES 并重启服务端mysql...严选情况下,数据超过他的设置范围他会报错 非严选情况下,数据超过他的设置范围不会报错,但是只存他设置大小的那一部分的数据,多余的会丢掉 3.常见的类型 1.整数型 数据类型 字节数 符号范围 有符号范围...longtext 4.enum与set 规定这个里面输入内容是什么,你可以输入他的内容,也可以输入他的索引 enum与set区别,enum只能输一个,set能输入一个或多个,且用集合的形式输入 注意: mysql
MySQL数据库数据类型分类 在MySQL数据库中,MySQL数据类型分有四大类:数值类型、文本/二进制类型、时间日期和String类型。...以下是这四大类的具体类型: 数值类型 数值类型的范围和字节大小: tinyint类型 tinyint类型只有一个字节大小,其数据范围为:【-128,127】 有符号举例: mysql> create...无符号举例: mysql> create table tt2( --tt2表,只有num字段,类型为tinyiny unsigned,表示无符号 -> num tinyint unsigned...举例: mysql> create table tt3( --创建tt3表,字段有id 类型为int,a 类型为bit(8).表示有8位比特位 -> id int, -> a bit(...字符串类型 char类型 语法: char(L): 固定长度字符串,L是可以存储的长度,单位为字符,最大长度值可以为255 举例: mysql> create table tt8( ->
MySQL索引的建立对于MySQL的高效运行是 很重要的。对于少量的数据,没有合适的索引影响不是很大,但是,当随着数据量的增加,性能会急剧 下降。...当创建索引带来的好处多过于消耗的时候,才是最优的选择~ # 查看索引 show index from quickchat_user_additional; 索引的类型 (具体设置在Navicat中添加即可...可以在创建表的时候指定,也可以修改表结构 空间索引 SPATIAL 空间索引是对空间数据类型的字段建立的索引,MYSQL中的空间数据类型有4种,分别是GEOMETRY、POINT、LINESTRING、...MYSQL使用SPATIAL关键字进行扩展,使得能够用于创建正规索引类型的语法创建空间索引。...只访问索引的查询 哈希索引(适用范围窄,不推荐使用) Hash索引在MySQL中使用的并不是很多,目前主要是Memory存储引擎使用,在Memory存储引擎中 将Hash索引作为默认的索引类型。
数据库是一个系统(应用)最重要的资产之一,所以我们的数据库将从以下几个数据库来进行介绍。 MySQL(本章节) PostgreSQL MongoDB Redis Etcd 一、索引是什么?...在 MySQL 中,索引(Index) 就是帮助存储引擎快速获取数据的一种数据结构。它就像数据的“目录”,通过预先排序和构建特定结构,极大减少了数据库需要扫描的数据量,从而提高了查询速度。...三、索引的数据结构 MySQL 支持多种索引数据结构,最常见的两种是: 1. B+Tree 索引 (默认) 这是 MySQL 的 InnoDB 和 MyISAM 存储引擎默认且最常用的索引类型。...InnoDB 支持自适应哈希索引(Adaptive Hash Index),但它是数据库内部自动管理的,用户无法手动创建。...四、索引的类型(逻辑分类) 从逻辑功能的角度,索引可以分为: 普通索引 (INDEX):最基本的索引,没有任何限制,仅用于加速查询。
数据库是一个系统(应用)最重要的资产之一,所以我们的数据库将从以下几个数据库来进行介绍。...mysql> SHOW INDEX FROM test_data\G; *************************** 1. row ***************************...: A Cardinality: 7587917 Sub_part: NULL Packed: NULL Null: Index_type: BTREE...Comment: Index_comment: 1 row in set (0.00 sec) ERROR: No query specified mysql> 4.添加索引,...mysql> CREATE INDEX idx_test_data_value ON test_data (value); Query OK, 0 rows affected (1 min 1.10 sec
INDEX, 添加唯一索引add unique index 多列联合添加索引,primary key 关键词index vs key ---- show all index show index from...tb_name 例如: show index from springdemo.blog; ?...---- 添加索引ADD INDEX, 添加唯一索引add unique index ALTER TABLE `table` ADD INDEX `product_id` (`product_id`)...`) ---- 多列联合索引,添加主键 #多列索引 ALTER TABLE `table` ADD INDEX `index_name` (`col1`,`col2`) # add primary key...Key in MySQL CREATE TABLE tasks ( task_id INT UNSIGNED NOT NULL AUTO_INCREMENT, INDEX parent (parent_id
5,200) as abstract from my_content_t (注:如果位数是负数 如-5 则是从后倒数位数,到字符串结束或截取的长度) 4、按关键字截取字符串 substring_index...(str,delim,count) 说明:substring_index(被截取字段,关键字,关键字出现的次数) 例:select substring_index("blog.jb51.net","
FROM TABLE [ {USE|IGNORE|FORCE} INDEX (key_list)] WHERE ... 1 USE INDEX 用来提供你希望MySQL去参考的索引列表,就可以让MySQL...INGNORE INDEX 让MySQL忽略一个或者多个索引。 FORCE INDEX 强制MySQL使用一个特定的索引。
我们在此之前已经讲过MySQL分区表的原理,分区有利于管理非常大的表,它采用分而治之的逻辑,便于对数据的管理。本期我们就来进一步了解MySQL分区表,详细看一下MySQL分区表类型究竟有几个?...MySQL支持如下几种类型的分区: 1、RANGE分区:行数据基于一个给定连续范围分区。不好理解,看例子吧。5.5版本开始支持RANGE COLUMNS分区。...4、KEY分区:根据MySQL内部提供的哈希函数进行分区。 5、COLUMNS分区:5.5版本开始支持,可以直接使用非整形的数据进行分区,分区根据类型直接比较而得,不需要转换为整形。...无论创建何种类型的分区,如果表中存在主键或唯一索引的列,则分区列必须是主键或唯一索引的一部分。索引列可以是null值。在没有主键和唯一索引的表中可以指定任意列为索引列。...当然,分区技术的应用远不止与此,区分各种分区表的类型并加以利用,我们才能更好地使用MySQL数据库查询和利用各种各样的数据。
DROP INDEX(删除索引) DROP INDEX 语句用于删除表中的索引。...用于 MySQL 的 DROP INDEX 语法 ALTER TABLE table_name DROP INDEX index_name; 数据库实例 ALTER TABLE student DROP...INDEX index_name; DROP TABLE (删除表) DROP TABLE 语句用于删除表。...DROP TABLE table_name; 数据库实例 DROP TABLE student; DROP DATABASE (删除数据库) DROP DATABASE 语句用于删除数据库。...请使用 TRUNCATE TABLE 语句: TRUNCATE TABLE table_name; 数据库实例 TRUNCATE TABLE student; 到此,《数据库 DROP INDEX 用法
今天是日更的 63/365 天 大家好,我是阿常,上一篇阿常讲了《数据库 SQL 约束之 DEFAULT》,今天阿常和大家分享《数据库 CTREATE INDEX 用法》,CREATE INDEX 语句用于在表中创建索引...); 数据库实例 CREATE INDEX index_name ON WebSites (name); 2、在表上创建一个唯一的索引,不允许使用重复的值 唯一的索引意味着两个行不能拥有相同的索引值。...(column_name); 数据库实例 CREATE UNIQUE INDEX index_sname ON student (name); 3、在表上创建不止一个列的索引,括号中列出这些列用逗号隔开...创建多个列索引语法 CREATE INDEX index_name ON table_name (column_name1, column_name2); 数据库实例 CREATE INDEX PIndex...到此,《数据库 CTREATE INDEX 用法》就讲完啦,下节课我们讲《索引的类型和区别》。
1.2 数据类型 MySQL中的数据类型是强类型 1.2.1 数值型 1、 整型 整形 占用字节数 范围 tinyint 1 -128~127 smallint 2 -32768~32767 mediumint...1.2.2 字符型 在数据库中没有字符串概念,只有字符,所以数据库中只能用单引号 数据类型 描述 char 定长字符,最大可以到255 varchar 可变长度字符,最大可以到65535 tinytext...不支持布尔型,true和false在数据库中对应的是1和0 mysql> create table stu18( -> flag boolean -> ); Query OK, 0 rows...1.2.6 练习题 电话号码一般使用什么数据类型存储? varchar 手机号码用什么数据类型 char 性别一般使用什么数据类型存储?...char tinyint enum 年龄信息一般使用什么数据类型存储? tinyint 照片信息一般使用什么数据类型存储?
数据类型 一、数据类型分类 mysql 中的数据类型分类如下,其中红色字体的为常用的类型: 二、数值类型 mysql 中表的建立属性列:列名称 数据类型,例如 num int,它与我们平时写的语言数据类型是倒过来的...1. tinyint 接下来我们创建一个只有 tinyint 类型的表,然后分别插入 1 和 128,会发现 128 插入失败,因为越界插入了,超出类型范围: 说明: 在 MySQL 中,整型可以指定是有符号的和无符号的...如果我们在上面的表格中插入大于两个字符的数据,如下,是会越界插入的: 这也就说明了一个问题,如果我们向 mysql 特定类型中插入不合法的数据,mysql 一般都是直接拦截我们,不让我们做对应的操作!...反过来,如果我们已经有数据被成功插入到 mysql 中,一定插入的时候是合法的!...所以,mysql 中,一般而言,数据类型本身也是一种约束,所谓约束,就是倒逼用户尽可能进行正确的插入,约束的是用户,这样就能保证数据库中的数据是可预期的,完整的。