我有一个奇怪的mysql查询速度问题,我正在努力解决这个问题。我将mysql数据库从一台服务器移动到另一台服务器时,本应更加健壮的服务器运行某些mysql查询的速度几乎是原始服务器的4倍。经过几天的调试,我终于发现在存储过程的where子句中使用变量的方式存在巨大的速度差异。下面是一些示例:
快速:
set @s = Concat('delete from visitids where VisitID=''',xVisitID,''' and OrgCode=''',xOrgCode,'''
我的MySQL DB只有一个表,而没有与~1亿行连接--。可以更新或删除这些项,也可以将新记录定期保存到、MySQL、DB、中,例如每分钟一次。如何在弹性搜索中达到更新索引的目的
when data is updated/changed/deleted in MySQL DB?
对我来说,实现数据必须是非常重要的,与MySQL保持同步是非常重要的。有可能吗?谢谢。
另外,我也尝试过用schedule => "* * * * *" and updated_at > :sql_last_value解决方案,但是它非常慢。
操作系统为ubuntu 16.04
MySQL版本:MySQL Ver 14.14 Distrib 5.7.19, for Linux (x86_64) using EditLine wrapper
在我的系统中
/etc/mysql/ -> ls
conf.d debian.cnf debian-启动my.cnf my.cnf.fallback mysql.cnf mysql.conf.d
在该文件中,我需要配置以获取通用查询日志和慢查询日志。
我正在将我的.NET/MSSQL迁移到RoR/MySQL/EC2/Ubuntu平台。在我将所有现有数据转移到MySQL中后,我发现MySQL查询速度非常慢,即使是像查询select count(*) from countries这样的超基本查询,它也只是一个国家/地区表,只包含大约200条记录,但查询需要0.124ms。这显然是不正常的。
我是MySQL的新手,谁能告诉我可能的问题是什么?或者安装MySQL后我应该打开的任何初始优化按钮?
我看到有一个很好的选项,如何启用日志慢查询和没有索引的查询:
SET GLOBAL log_queries_not_using_indexes=1;
SET GLOBAL log_slow_queries=1;
好的,好的,但是它们似乎都写入了我在my.cnf配置文件中指定的同一个日志文件:
[mysqld]
long_query_time = 1
log-slow-queries = /var/log/mysql/mysql-slow.log
我使用mysqldumpslow查看最慢的查询,但是我需要做什么才能单独查看那些没有索引的查询呢?