首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mysql数据类型以及字段属性大盘点

也就是说不论中间用何种分隔,存储到数据库之后都是2012-08-00 l  Datetime:存储日期和时间组合,标准格式YYYY-MM-DD HH:MM:SS。...Timstamp:和datetime的区别在于插入和更新会自动回去当前时间 l   Year:存储年份信息,有两位和4位之分 2、  数字数值类型 Bool是tinyint的别名,用于赋值0或者1 Bigint:数据类型提供了...mysql最大的整数范围,取值范围分为有符号:-9223372036854775808~9223372036854775807,无符号是0~18446744073709551615 Int:提供了第二大的整数范围...Mediumint:提供了第三大整数 SMAllint:提供了第四大整数范围 Tinyint:提供了最小的整数范围,值在-128-127(分清楚范围就不担心数据够不够存储) Decimal,double...Set:枚举类型,最多可以设置有64个成员 数据类型属性 Auto_increment:自增,每次插入该列的值会是上次插入值+1 Default:默认值,当没存入数据时会自动存入默认值 Index:索引

88880
您找到你想要的搜索结果了吗?
是的
没有找到

mysql字段主键_sql改变列数据类型

MySQL数据类型 (1)数值类型 1、整数型 2、浮点型 3、定点型 (2)日期时间类型 (3)字符串类型 MySQL字段属性 1、空\不为空值:NULL、NOT NULL 2、主键:primary...中等长度文本数据 longtext L+4 极大文本数据 不要轻易的使用最大限度来存储字符串,因为涉及记录长度问题 : MySQL中规定任何一数据最长不能超过65535个字节 如果有任何一个字段允许为空...: 字段属性是字段数据类型外的属性,一般有空\不为空值、主键、唯一键、自增长、默认值、描述等属性。...空\不为空值:NULL、NOT NULL 字段数据默认情况下是允许为空的,比如说一人的信息记录中可以没有邮箱(或许有些人考虑用“空字符串”来代表),我们允许可以不填入数据字段可以设置为null;但比如说某些必填数据...(不给这个字段插入数据的情况下) 自增长的前提是这个字段必须是一个“索引”,比如主键、唯一键 自增长的前提这个字段数据类型是一个数值型的,(如果给了float,也不会增长成小数,而仅仅是整数) 一个表只能有一个自增长

2.5K20

mysql float字段类型数据查询为空问题

mysql float字段类型数据查询为空问题 作者:matrix 被围观: 224 次 发布时间:2021-12-28 分类:mysql PHP | 无评论 » 结论 不要用float、double...改用decimal字段类型 过程 之前是知道浮点数最好不要用float类型做存储,手上遇到老项目使用就正好是float字段存储的体重数据,比如51.6这种。...普通的查询没问题,个别数据就出现查询为空的问题。后来发现都是浮点类型数据,排查框架的sql日志到PDO的参数绑定找遍了都没找到根源。...$this->PDOStatement->bindValue(':ThinkBind_1_', 51.6, PDO::PARAM_STR) 虽然字段设置了精度float(10,2),但是依然有查询为空出现...办法 浮点数查询使用like 使用函数比如oncat(wi)=51.6,或者format(wi,2) = format(51.6 ,2) 使用decimal字段类型 参考: https://www.cnblogs.com

5.2K50

MySQL学习3_数据类型字段及运算符

本篇博文中主要是介绍MySQL数据库中的数据类型字段、运算符的相关知识 数据类型 MySQL数据库中的主要数据类型有四种: 数值类型 浮点型 字符串类型 日期时间类型 数值类型 一般情况下:用int就可以...数字和字母占1个字符 char_length 返回字符串所占的字符数 汉字、数字、字母都是一个字符 image.png 日期时间类型 建议使用int存储时间戳(10位数字)的形式 image.png 字段名修饰...字段指的是表中第一行即列属性,用column表示。...常用来修饰字段的有: image.png 修饰语 作用 unsigned 无符号 auto_increment 自增 default 默认值 comment 字段解释说明 not null 非空 null...空 unique 唯一索引 index 普通索引 primary key 主键,必须指定为auto_increment 索引的作用是加快查询速度 运算符 常用的运算符有: = :表示赋值或者判断 !

78210

mongodb修改字段数据类型

string类型,后来上了新架构之后DATE_TIME字段变成DateTime类型了,然后统计某一个月内数据的时候就出现问题了,因为string类型的数据查询方式和DateTime类型查询方式是完全不一样的两种查询...基于这种情况,我们只能将线上的数据类型进行修改了,将string类型的数据全部修改为DateTime类型。...解决方法: 对比上面的两种方法,最后我们决定采用脚本的方式数据类型修改,因为这种方式时间周期最短,代码量最少,也不需要修改应用代码。...;保存修改后的字段信息 具体步骤: 我这边使用的是NoSQL Manager for MongoDB工具进行MongoDB数据管理的,新架构之前的数据如下所示: ?...总结: 脚本其实很简单,最主要是对线上的数据进行修改都有一定的风险,所以在修改数据之前一定要先进行备份,但是在脚本运行期间新产生的数据就会丢失。

1.9K20

MySQL-存储引擎-创建表-字段数据类型-严格模式-字段约束-键-02

BLACKHOLE 引擎对应的本地化文件 案例 基本操作 创建表的完整语法 表记录基础操作 严格模式补充 查看数据库配置中变量名包含mode的配置参数 模糊匹配 基本数据类型 数据范围 整型 TINYINT...; insert into t1 values(1,'j'); # 正常存储 insert into t1 values(2,null); # 报错 # 总结 类型与约束条件区别 # 类型:限制字段必须以什么样的数据类型存储...在存储char 类型字段的时候,硬盘上确确实实存的是固定长度的数据,但是再取出来的那一瞬间mysql 会自动将填充的空格去除 ?...,每次添加数据,不需要用户手动输入 自动递增序号问题 删除数据后,序号不会接着上一存在数据往下递增,而是从上一次的最大序号开始递增 delete from 清空表仅仅是删除数据,不会重置 id...,只存整数,且范围变大 zerofill 给指定了宽度的数据类型的不足长度的字段不足部分用0填充 修改约束条件,不够8位用0填充(zerofill),会自动加上 unsigned alter table

2.3K30

查询 MySQL 字段注释的 5 种方法!

很多场景下,我们需要查看 MySQL 中表注释,或者是某张表下所有字段的注释,所以本文就来盘点和对比一下查询注释的几种方式。 创建测试数据库 开始之前咱们先创建一个数据库,以备下面演示使用。...WHERE table_schema='数据库名' ORDER BY table_name 案例:查询 test2022 数据库中的所有表注解: SELECT table_name 表名, table_comment...字段注释查询方式1 查询语法如下: show full columns from 表名; 案例:查询 student 表中所有字段的注释信息: show full columns from student...; 执行结果如下图所示: 字段注释查询方式2 查询语法如下: select COLUMN_NAME 字段名,column_comment 字段说明,column_type 字段类型, column_key...where table_schema='test2022' and table_name='student'; 执行结果如下图所示: 字段注释查询方式3 查询表的 DDL(数据定义语言)也可以看到字段的注释内容

5.2K30

mysql字段关键词模糊查询

1,输入单个关键字“001”可查出四数据,可实现的sql语句是: SELECT * FROM tbl_app_clinic_item WHERE CONCAT(applicationCode, clinicItemDictCode...) LIKE '%001%' 2,输入两个关键字“001,003”可查出2数据,可实现的sql语句是: SELECT * FROM tbl_app_clinic_item WHERE CONCAT(applicationCode...1, '分隔符', 字段2, '分隔符', ...字段n) like '%关键字1%' and concat(字段1, '分隔符', 字段2, '分隔符', ...字段n) like '%关键字2%'...,所以我们在连接字符串时把每个字段以逗号分隔即可解决此问题,下面这个sql语句不会查询数据: SELECT * FROM tbl_app_clinic_item WHERE CONCAT(applicationCode...这样有个问题,如果这两个字段中有值为NULL,则返回的也是NULL,即将表格中数据的appl那么这一记录可能就会被错过,对此,我们可以使用IFNULL函数。

4K10

MySQL|查询字段数量多少对查询效率的影响

初次访问定位的时候还会构建一个模板(mysql_row_templ_t)(Innodb 层) 本模板主要用于当 Innodb 层数据MySQL 层做转换的时候使用,其中记录了使用的字段数量、字段的字符集...到这里我们大概知道了,查询字段越多那么这里转换的过程越长,并且这里都是实际的内存拷贝,而非指针指向。...对第一数据进行 where 过滤(MySQL 层) 拿到数据后当然还不能作为最终的结果返回给用户,我们需要在 MySQL 层做一个过滤操作,这个条件比较位于函数 evaluate_join_record...访问下一数据 上面我已经展示了访问第一数据的大体流程,接下面需要做的就是继续访问下去,如下: 移动游标到下一行 访问数据 根据模板转换数据返回给 MySQL 层 根据 where 条件过滤 整个过程会持续到全部主键索引数据访问完成...中为 '1' 的位数越多 建立的模板不同,字段越多模板数量越多 每行数据转换为 MySQL 格式的时候不同,字段越多模板越多,那么循环转换每个字段的循环次数也就越多,并且这是每行都要处理的。

5.6K20

MySQL字段类型_mysql数据字段类型

前言: 要了解一个数据库,我们必须了解其支持的数据类型MySQL 支持大量的字段类型,其中常用的也有很多。...定点型字段类型有 DECIMAL 一个,主要用于存储有精度要求的小数。 DECIMAL 从 MySQL 5.1 引入,列的声明语法是 DECIMAL(M,D) 。...我们在定义字段最大长度时应该按需分配,提前做好预估,能使用 varchar 类型就尽量不使用 text 类型。除非有存储长文本数据需求时,再考虑使用 text 类型。...不过值得注意的是,TIMESTAMP 字段数据会随着系统时区而改变但 DATETIME 字段数据不会。总体来说 DATETIME 使用范围更广。...总结: 本篇文章主要介绍了 MySQL 中常用的字段类型,平时用到的字段类型基本都在这里了,以一张思维导图总结如下: 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

19.3K10

MySQL数据类型

MySQL不同存储引擎可能会有不同。下面的内容以InnoDB为主。 选择数据类型的步骤 确定合适的大类型:数字、字符串、时间、二进制 确定具体的类型:有无符号、取值范围、变长定长等。...MySQL检索CHAR不会使用末尾的空格。(列是定长的,MySQL没有存储写入的字符串有多长,只好一刀切,末尾的空格都忽略掉。) VARCHAR末尾的空格不会被“干掉”,检索的时候会用到。...BLOB vs TEXT L表示数据的长度。 L+x表示存储需要的空间。...而MySQL在检索BIT的时候会将其当做字符串,而不是整数,这可能会导致一些奇怪的行为。 不建议使用这三个类型:用整数代替。 一些原则 选择最小的满足需求的数据类型。...一般情况下,应该尽量使用可以正确存储数据的最小数据类型。 简单就好。

2.5K40

mysql 数据类型

一.数值类型 Mysql支持所有标准SQL中的数值类型,其中包括严格数据类型(INTEGER,SMALLINT,DECIMAL,NUMBERIC),以及近似数值数据类型(FLOAT,REAL,DOUBLE...忽略 DECIMAL 数据类型的精度和计数方法修饰符将会使 MySQL 数据库把所有标识为这个数据类型字段精度设置为 10,计算方法设置为 0。...复合类型   MySQL 还支持两种复合数据类型 ENUM 和 SET,它们扩展了 SQL 规范。虽然这些类型在技术上是字符串类型,但是可以被视为不同的数据类型。...在处理相互排拆的数据时容易让人理解,比如人类的性别。ENUM 类型字段可以从集合中取得一个值或使用 null 值, 除此之外的输入将会使 MySQL 在这个字段中插入一个空字符串。...希望从 SET 类型字段中找出非法的记录只需查找包含空字符串或二进制值为 0 的行。 通过对每种数据类型的用途,物理存储,表示范围等有一个概要的了解。

2.7K40
领券