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

mysql longtext 查询_mysql中longtext存在大量数据,会导致查询很慢?

case1: select id, name from t order by last_update_time limit 10000, 10 当content当中有大量的文本,case1的效率极慢。...使用explain: 有content结果: mysql> explain select id, name, last_update_time from t order by last_update_time...无content的时候,查询走的是idx_last_update_time,我猜测这个索引中包含了id,name字段,因此仅通过索引就可以获取到所需的数据,因此速度很快。...我觉得,主要跟你的分页查询的方式有关,limit 10000,10 这个意思是扫描满足条件的10010条数据,扔掉前面的10000行,返回最后的10行,在加上你的表中有个,非常大的字段,这样必然增加数据库查询的...i/o时间, 查询优化你可以参照 @邢爱明 的 SELECT id,title,content FROM items WHERE id IN (SELECT id FROM items ORDER BY

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

mysql varchar类型字段为数字,不带引号查询查询结果与事实不符

背景 今天出现了一个bug,在数据库中我们将订单表中的order_no从之前的bigint(20)改成varchar(20)后,原有的代码逻辑在进行时查询,之前是以Long类型传参查询的。...select * from order_main where order_no=16541913435669023 debug的时候发现这条sql语句查询出来两条数据,另外一条毫不相关的订单也被查出来了...但是同样的sql我们放到数据库中确是只能查到一条数据。...根源 mysql5.7 查询varchar类型的数据,不加引号,触发隐式转换导致的查询结果错误。...,因此在使用时必须仔细甄别 数字类型的建议在字段定义就定义为int或者bigint,表关联关联字段必须保持类型、字符集、校对规则都一致

1.5K10

mysql乱码设置

MySQL默认字符编码的设置 MySQL的默认编码是Latin1,不支持中文,那么如何修改MySQL的默认编码呢,下面以UTF-8为例来说明  需要注意的是,要修改的地方非常多,相应的修改方法也很多...下面是一种最简单最彻底的方法:  一、Windows  1、中止MySQL服务  2、在MySQL的安装目录下找到my.ini,如果没有就把my-medium.ini复制为一个my.ini...即可  3、打开my.ini以后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭  4、启动MySQL服务  二、Linux... 1、中止MySQL服务(bin/mysqladmin -u root shutdown)  2、在/etc/下找到my.cnf,如果没有就把MySQL的安装目录下的support-files.../etc/下并改名为my.cnf即可  3、打开my.cnf以后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭  4、启动MySQL

3.8K60

Mysql插入中文的字段内容乱码的解决方法

Mysql插入中文的字段内容乱码的解决方法 1.我们在往数据库插入数据的时候,当遇到中文字符的插入时会发现插入的数据会变为?号,也就是乱码,如下所示: ?...image.png 2.这时候我们使用如下的查询语句可以看到相应的字符集编码: show variables like '%char%'; [图片上传失败......(image-33d826-1556266481174)] 3.这里我们可以看到有些字符编码集不是utf8的,为了让这里所有的字符集都设置为utf8, 我们需要更改改动mysql配置文件/etc/...=utf8 在window环境下在 MySQL 的安装目录下有一个 my.ini 配置文件, [mysql] default-character-set=utf8 [mysqld] character-set-server...useUnicode=true&characterEncoding=UTF-8&useSSL=false 修改后重新启动 MySQL 服务即可

2.9K50

Mysql连接查询查询条件放在On之后和Where之后的区别

一开始还比较费解,后面回过神来才发现,犯了一个低级的错误,就是在使用left join过滤条件放到on后面还是where后面是有区别的,如果没有搞清楚他们的区别,连表汇总的结果就会变少或者变多。...num from classes a left join students b on a.id = b.class_id where b.gender = 'F' group by a.name  查询结果...as num from classes a left join students b on a.id = b.class_id and b.gender = 'F' group by a.name 查询结果...as num from classes a left join students b on a.id = b.class_id and a.name = '一班' group by a.name  查询结果... 原因 mysql 对于left join的采用类似嵌套循环的方式来进行从处理,以下面的语句为例: SELECT * FROM LT LEFT JOIN RT ON P1(LT,RT)) WHERE

1.6K10

python MYsql中文乱码

以前用php连mssqy也经常出现中文乱码(中文变问号)的问题,那时就明白是编码没设置好导航,现在的Python连mssql数据库也同样出现这问题,问题一样,解决的办法当然也会相似,现在我们来看看解决方法...'20093504', u'xc8xcexd3xafxd3xaf', u'u5973 ', 24, u'xc6xafxc1xc1')]   [Finished in 0.2s]   虽然摆脱了问号和乱码的困扰...这个现象确实诡异,请教了许多高手,得知,最好的结果就是逐个字段查询,才能显示中文,整个查询的话,会以utf8的格式显示出来。  ...上述代码中第14行data是整个查询的结果,如果指定某个具体的字段,如print data[0][2](表示取查询结果的第一行第三列的字段的值),则会输出中文。  ...其实不仅仅是mssqlserver数据库,mysql(需下载MySQLdb包)、sqllite(python自带的文件数据库)、mongodb(需下载PyMongo包)等或者是普通文本文件也是类似的解决方案

4.4K20

mysql 联合查询_MySQL联合查询

MySQL联合查询 联合查询:union,将多次查询(多条select语句)的结果,在字段数相同的情况下,在记录的层次上进行拼接。...执行如下 SQL 语句,进行测试: — 联合查询,默认去重 select * from class union distinct select * from class; — 联合查询,保留所有记录 select...特别地,联合查询只要求字段数相同,而跟类型无关。...意义 联合查询的意义有两种,分别为: 查询同一张表,按时需要不同,例如查询学生信息,要求男生按年龄升序排序,女生按年龄降序排序; 多表查询,多张表的结构是完全一样的,保持的数据结构也是一样的。...根据我们刚刚学到的联合查询,貌似很容易啊!

18.7K30
领券