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

MySQL Longtext字段优化记录(一)

大家好,又见面了,我是你们朋友全栈君。...工作中遇到一个查询很慢情况,环境如下: 开发语言:JAVA 数据库:MySQL 数据量:1600~1800 问题:查询200条时就很慢,是慢在IO上: 如果是查全部(一千六百多条),就更慢了,几乎四十秒还没有返回...数据流图: blob字段: 后端使用Zip压缩算法,使用java.util.zip包下DeflaterOutputStream和InflaterOutputStream,压缩文本再保存。...全都更新到blob字段中,然后把原表拷贝到两张表,一张表保留longtext字段,一张表保留blob字段,查询比对如下: 说明blob字段IO速度比long text字段IO速度快很多。...注:这种方式就是不存原文本内容,弊端就是无法做对文本搜索功能,如果要求要对文本做搜索,或者保留为文档到ES中,建议把content字段拆出来一张表和主表关联,也是保存和查询需要处理一下。

2.9K20

oracle修改sequence最大最小值_oracle最大值记录

maxvalue:可选子句,决定序列生成最大值。 start: 可选子句,制定序列开始位置。默认情况下,递增序列起始值为minvalue,递减序列起始值为maxvalue。...cycle: 可选关键字,当序列到达最大值(maxvalue)或者最小值(minvalue)时可复位并继续下去。如果达到极限。生成下一个数据将分别是最小值或者最大值。...如果使用NO CYCLE 选项,那么在序列达到最大值或最小值之后,如果再试图获取下一个值将返回一个错误。 order: 该选项可以保证生成序列值是按顺序产生。...例子: create sequence seq_dept maxvalue 99–序列产生产生最大值。...例如: select seq_dept from dual; 当sequence值到达了最大值之后,若选择了cycle属性,那么会复位到最小值继续增加依次循环。

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

MySQL|update字段为相同值是否会记录binlog

一 前言 前几天一个开发同事咨询我,update 更新字段为相同值是否会记录binlog,我回复说不会。 其实 严格说这个答案是不准确,说要区分场景。...当 row_format 为mixed或者statement格式是,binlog 大小发生改变,不管是否真的更新数据,MySQL记录执行sql 到binlog。...三 小结 基于row模式时,server层匹配到要更新记录,发现新值和旧值一致,不做更新,就直接返回,也不记录binlog。...基于 statement 或者 mixed格式,MySQL执行 update 语句,并把更新语句记录到binlog。 那为什么问题来了 statement 和 mixed 会完整记录sql语句呢?...且听下回分解吧,因为我要解析源码,使用Clion 编译MySQL 调试环境还没成功。

6.2K20

MYSQL学习:GROUP BY分组最新一条记录

日常开发当中,经常会遇到查询分组数据中最新一条记录,比如统计当前系统每个人最新登录记录、外卖系统统计所有买家最新一次订单记录、图书管理系统借阅者最新借阅书籍记录等等。...今天给大家介绍一下如何实现以上场景SQL写法,希望对大家能有所帮助!...INTO `bookinfo` VALUES (5, 'ISBN005', '物理'); INSERT INTO `bookinfo` VALUES (13, 'ISBN006', '读者'); -- 借阅记录表...b on b.id=a.book_id INNER JOIN userinfo c on c.uid=a.user_id GROUP BY a.user_id -- 说明: 这样会存在获取书籍名称错乱情况..., -- 因为使用聚合函数获取书籍名称,不一定是对应用户 -- 最新浏览记录对应书籍名称 写法2 采用子查询方式,获取借阅记录表最近浏览时间作为查询条件 select a.user_id ,c.uname

18.6K20

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

大家好,又见面了,我是你们朋友全栈君。 前言: 要了解一个数据库,我们必须了解其支持数据类型。MySQL 支持大量字段类型,其中常用也有很多。...DECIMAL 从 MySQL 5.1 引入,列声明语法是 DECIMAL(M,D) 。...2.字符串类型 字符串类型也经常用到,常用几个类型如下表: 其中 char 和 varchar 是最常用到。char 类型是定长MySQL 总是根据定义字符串长度分配足够空间。...3.日期时间类型 MySQL支持日期和时间类型有 YEAR 、TIME 、DATE 、DATETIME 、TIMESTAMP,几种类型比较如下: 涉及到日期和时间字段类型选择时,根据存储需求选择合适类型即可...总结: 本篇文章主要介绍了 MySQL 中常用字段类型,平时用到字段类型基本都在这里了,以一张思维导图总结如下: 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

19.3K10

MySQL根据某个字段将多条记录某个字段拼接成一个字段

问题 GROUP_CONCAT函数用于将多个字符串连接成一个字符串,在拼接成字符串时就会存在拼接长度问题,MySQL 默认拼接最大长度为1024 个字节,由于1024个字节会出现不够用情况,所以有时需要去根据情况进行修改..., 使用SHOW VARIABLES LIKE "%group_concat_max_len%"查看 mysql> SHOW VARIABLES LIKE "%group_concat_max_len%...> 1 临时修改(命令行) 1.1 修改group_concat_max_len长度为:10240 mysql> SET GLOBAL group_concat_max_len = 10240; mysql...[mysqld] ...... group_concat_max_len = 10240  #添加 2.2 重启mysql服务 如果mysql服务不重启的话,可以配合临时修改一起使用 $ service...> 3 附加 有时我们并不知需要多大字节才能满足需求,此种情况可以考虑不设置最大字节(即采用最大字节数)即在配置文件设置group_concat_max_len=-1 此种情况下group_concat_max_len

1.9K20

Mysql Explain主要字段

如果是Innodb引擎表,type列在这个情况通常都是all或者index 2、const 最多只有一行记录匹配。当联合主键或唯一索引所有字段跟常量值比较时,join类型为const。...当主键或唯一非NULL索引所有字段都被用作join联接时会使用此类型。 eq_r ef可用于使用’='操作符作比较索引列。比较值可以是常量,也可以是使用在此表之前读取表达式。...4、ref 对于来自前面表每一行,在此表索引中可以匹配到多行。若联接只用到索引最左前缀或索引不是主键或唯一索引时, 使用ref类型(也就是说,此联接能够匹配多行记录)。...要注意,全文索引优先级很高,若全文索引和普通索引同时存在时,mysql不管代价,优先选择使用全文索引 6、ref_or_null 跟ref类型类似,只是增加了null值比较。实际用不多。...SELECT * FROM ref_table WHERE key_column=expr OR key_column IS NULL; 7、index_merge 表示查询使用了两个以上索引,最后交集或者并集

1.4K20

MySQL修改表字段

MySQL修改表字段 MySQL 修改表字段方法有两种: ALTER TABLE MODIFY COLUMN。...其语法如下: ALTER TABLE 表名 MODIFY COLUMN 字段字段类型; 其中,表名 表示要修改表名,字段名 表示要修改字段名,字段类型 表示修改后字段类型。...其语法如下: ALTER TABLE 表名 MODIFY COLUMN 字段字段类型 [属性]; 其中,表名 表示要修改表名,字段名 表示要修改字段名,字段类型 表示修改后字段类型,属性 表示修改后字段属性...0; 需要注意是,如果修改表字段数据类型或长度,可能会造成数据丢失或者修改失败。...因此,在进行字段类型修改时,需要先备份数据,避免出现意外情况。

5.4K10

MySQLjson字段

// MySQLjson字段 // MySQL5.7.8中引入了json字段,这种类型字段使用频率比较低,但是在实际操作中,有些业务仍然在用,我们以此为例,介绍下json字段操作方法...,info是json字段,插入了三条数据,如上: mysql> select * from test1 where json_extract(info,"$.age")>=30; +------+---...其中: 1、$符号代表是json根目录, 2、我们使用$.age相当于取出来了json中age字段, 3、当然,在函数最前面,应该写上字段名字info 下面来看json中常用函数: a、json_valid...判断是否是json字段,如果是,返回1,如果不是,返回0 mysql> select json_valid(2); +---------------+ | json_valid(2) | +------...,如果传入了字符串2,那么,返回结果是1 b、json_keys传回执行json字段最上一层key值 mysql> select json_keys('{"name":"yeyz","score":100

9K20

mysql数据库中int类型最大值_mysql自增主键最大值

大家好,又见面了,我是你们朋友全栈君。 1、mysql中int(11)中11代表显示宽度 整数列显示宽度,与mysql需要用多少个字符来显示该列数值,与该整数需要存储空间大小都没有关系。...a、int是整型,(11)是指显示字符宽度,最大为255。 b、int(11)是记录行数id,插入10条记录,那么它就显示00000000001 ~~~00000000010。...c、当字符位数超过11,它也只显示11位。 d、如果没有加未满11位就前面加0参数,就不会在前面加0。 e、如果没有给它指定显示宽度,MySQL会为它指定一个默认值。...f、INT(3)会占用4个字节存储空间,并且允许最大值也不会是999,而是INT整型所允许最大值。...2、mysql有五种整型数据列类型,即TINYINT,SMALLINT,MEDIUMINT,INT和BIGINT。 a、区别是取值范围不同,存储空间不相同。

6K20

MySQL字段知识科普

为什么varchar默认长度是255 1、 mysql要求varchar一个行定义长度不能超过65535bytes,这个大小包括了字段占用空间在内,text和blob等大字段除外(注: 单行最大限制指就是一张表中所有字段所设置长度总和不得超过...65535字节) 2、 InnoDB存储引擎表索引前缀长度最长是: 767字节,如果需要创建索引,不能超过这个长度。...而utf-8编码时: 255 * 3(一个字符占3个字节)= 765字节,恰恰时能够建立索引最大值单列索引长度限制(5.6里面默认不能超过767bytes,5.7不超过3072bytes) 3...、总结: varchar(255)不是最优字符长度,最优需要按照具体情况来,但是这个长度可以保证你能少出错一个不错默认值 int(20)中20表示什么意思 1、是指显示字符长度。...写在最后   经验就是一个积累过程,没有谁能够一步登天,所以脚踏实地才是成功秘诀。

83410

AWK中字段记录和变量【Programming】

本文为awk入门系列第二篇文章,在本篇文章中,你可以了解到有关字段记录和一些功能强大awk变量。...记录字段 Awk通常将其输入数据视为以换行符分隔一系列记录。也就是说,awk通常会将文本文件中每一行视为新记录。每个记录包含一系列字段。而记录字段分隔符分割后则组成了字段。...假如设定字段分隔符是逗号,下面的例子中将包含三个字段,其中一个字段长度可能为零个字符(不可打印字符未隐藏在该字段情况下): a,,b AWK程序 awk命令程序部分由一系列规则组成。...NF变量 每个字段都有一个变量作为名称,但是字段记录也有特殊变量。变量NF存储awk在当前记录中找到字段数。可以打印或在测试中使用。...NR变量 除了对每个记录字段进行计数外,awk还对输入记录进行计数。记录号保存在变量NR中,并且可以与任何其他变量相同方式使用。

2K00

SQL 获取一行中多个字段最大值

需求描述: 在 chaos(id,v1,v2,v3) 表中获取每个 id 对应 v1、v2、v3 字段最大值,v1、v2、v3 同为数值类型。...v12 = IF(v1 > v2, v1, v2) v_max = IF(v12 > v3, v12, v3) 如果 chaos 再增加两个数值列 v4、v5,要同时比较这五个字段值,嵌套 IF...那么,有没有比较简单且通用实现呢? 有。先使用 UNION ALL 把每个字段值合并在一起,再根据 id 分组求得最大值。...那就试试用递归方式解决。下面仅提供用递归思路(MySQL 环境),具体实现就留给大家了。...使用 CONCAT_WS() 函数将 v1、v2、v3 值组合成使用逗号分割字符串; 在递归语句使用 SUBSTRING_INDEX() 根据逗号分解字符串每个数值; 根据 id 分组求得最大值

11.3K20

MySQL字段类型详细解释

MySQL支持大量列类型,它可以被分为3类:数字类型、日期和时间类型以及字符串(字符)类型。 概述有意简化,更详细说明应该考虑到有关特定列类型附加信息,例如你能为其指定值允许格式。...由MySQL支持列类型列在下面。下列代码字母用于描述中:M指出最大显示尺寸。最大合法显示尺寸是 255 。 D适用于浮点类型并且指出跟随在十进制小数点后数码数量。...FLOAT(X)有对应FLOAT和DOUBLE相同范围,但是显示尺寸和小数位数是未定义。在MySQL3.23中, 这是一个真正浮点值。...一个 TIMESTAMP列对于记录一个INSERT或UPDATE操作日期和时间是有用, 因为如果你不自己给它赋值,它自动地被设置为最近操作日期和时间。...这是MySQL缺省。CHAR是CHARACTER一个缩写。 [NATIONAL] VARCHAR(M) [BINARY] 一个变长字符串。

2.3K20

mysql 字段时间类型比较

字段时间类型分为: ,,,,; 下面就分别介绍这几种时间类型区别 每个时间类型都有一个有效范围和一个零值,当指定类型值超过有效范围时,就会使用零值 YEAR 该类型表示年,格式为 有三种表示方法...:分:秒,尽管时间范围为0~23,但是为了表示某些特殊时间,mysql将小时范围扩大了,并且支持负值。....我们可以通过获取当前值 DATE 该类型表示年-月-日,标准格式为,但是中还支持一些不严谨格式:比如等其他符号来分割 在插入数据数据也可以使用 年份转换和上面的类型规则一样 可以使用...函数获取当前值 DATETIME 该类型表示YYYY-MM-DD hh:mm:ss,可以看出和类型结合体.所以赋值规则时和上面和时一样 TIMESTAMP 该类型表示为YYYY-MM DD hh...哈哈,到年后就别用这个类型了 这只是一个简单区分说明,具体时间类型说明 请参考 官方文档 https://dev.mysql.com/doc/refman/5.7/en/date-and-time-types.html

4.6K80
领券