首页
学习
活动
专区
圈层
工具
发布

MySQL - 8种常见的SQL错误用法

前言:MySQL在2016年仍然保持强劲的数据库流行度增长趋势。越来越多的客户将自己的应用建立在MySQL数据库之上,甚至是从Oracle迁移到MySQL上来。...但也存在部分客户在使用MySQL数据库的过程中遇到一些比如响应时间慢,CPU打满等情况。现将《ApsaraDB专家诊断报告》中出现的部分常见SQL问题总结如下,供大家参考。 1....隐式转换 SQL语句中查询变量和字段定义类型不匹配是另一个常见的错误。...关于 MySQL 外部条件不能下推的详细解释说明请参考以前文章:MySQL · 性能优化 · 条件下推到物化表 http://mysql.taobao.org/monthly/2016/07/08。...程序员在设计数据模型以及编写SQL语句时,要把算法的思想或意识带进来。 编写复杂SQL语句要养成使用 WITH 语句的习惯。简洁且思路清晰的SQL语句也能减小数据库的负担 。

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

    MySQL:8种SQL典型错误用法,值得收藏!

    2、隐式转换 SQL语句中查询变量和字段定义类型不匹配是另一个常见的错误。比如下面的语句: 其中字段 bpn 的定义为 varchar(20),MySQL 的策略是将字符串转换为数字之后再比较。...3、关联更新、删除 虽然 MySQL5.6 引入了物化特性,但需要特别注意它目前仅仅针对查询语句的优化。对于更新或删除需要手工重写成 JOIN。...比如下面 UPDATE 语句,MySQL 实际执行的是循环/嵌套子查询(DEPENDENT SUBQUERY),其执行时间可想而知。...5、EXISTS语句 MySQL 对待 EXISTS 子句时,仍然采用嵌套子查询的执行方式。...编写复杂SQL语句要养成使用 WITH 语句的习惯。简洁且思路清晰的SQL语句也能减小数据库的负担 。

    95210

    8种MySQL常见新手SQL错误用法详解

    博主猫头虎的技术世界 欢迎来到猫头虎的博客 — 探索技术的无限可能 sql语句的执行顺序: FROM ON ...2、隐式转换 SQL语句中查询变量和字段定义类型不匹配是另一个常见的错误。...3、关联更新、删除 虽然 MySQL5.6 引入了物化特性,但需要特别注意它目前仅仅针对查询语句的优化。对于更新或删除需要手工重写成 JOIN。...比如下面 UPDATE 语句,MySQL 实际执行的是循环/嵌套子查询(DEPENDENT SUBQUERY),其执行时间可想而知。...程序员在设计数据模型以及编写SQL语句时,要把算法的思想或意识带进来。 编写复杂SQL语句要养成使用 WITH 语句的习惯。简洁且思路清晰的SQL语句也能减小数据库的负担 。

    71820

    mysql配置1045错误_MySql 1045错误「建议收藏」

    配置时以管理员身份运行MySQL Instance Configuration Wizard 当你登录MySQL数据库出现:Error 1045错误时(如下图),就表明你输入的用户名或密码错误被拒绝访问了...,最简单的解决方法就是将MySQL数据库卸载然后重装,但这样的缺点就是就以前的数据库中的信息将丢失,如果你不想重装,那么就需要找回密码或者重置密码。...MySQL 1045错误如图: ERROR 1045 (28000): Access denied for user ‘root’@’localhost’ (using password: YES) 解决方案...然后通过SQL语句修改root用户的密码; 4、 重启服务:将my.ini文件中加入的跳过权限语句删除或加#号注释。重启服务,使用修改后的密码登录即可。...2、 跳过验证: 进入MySQL的安装路径(以默认安装路径为例)C:\Program Files\MySQL\MySQL Server 5.1\,找到my.ini配置文件(些文件记录MySQL的常规参数

    2.9K10

    MySQL连接错误

    出现: Enter password: 输入或者不输入回车后出现错误: ERROR 1045 (28000): Access denied for user ‘root’@’localhost’ (using...下面这样(斜体为操作后命令提示的结果,不输入): 1.进入mysql数据库: mysql> use mysql; Database changed 2.给root用户设置新密码,新密码自己输: mysql...> update user set password=password(“新密码”) where user=”root”; 警告:这个命令是5.7之前一些老版本的,如果你用的新的,这样输入会出现错误:...这个文件,把刚才加入my.ini文件的的”skip-grant-tables”这行删除,保存退出再重启mysql就可以了。...进入mysql后,有出现了如下错误: ERROR 1820 (HY000): You must SET PASSWORD before executing this statement 坑了个爹的。。。

    4.5K20

    通过错误的SQL来测试推理SQL的解析过程

    整个流程上,我们做一些相关解释: ① 对SQL的文法检查,查看是否有文法错误,比如from、select拼写错误等。 ② 在数据字典里校验SQL涉及的对象是否存在。...如何通过测试来验证呢,我们可以试一下以毒攻毒,即用错误的的SQL来推理SQL的解析过程,我们先来看一下在MySQL侧的解析情况。...)); 如果我们提交一个语法错误的SQL,在解析方面MySQL提供的信息非常有限, mysql> select1 id3 from2 test1 where3 id2='aaa' group by4 id1...' group by4 id1 order by5 id0' at line 1 这种错误没有下标,也没有明确的错误提示,是难以去理解语法解析的过程的,在对象和权限的解析方面,MySQL的解析方式也相对比较单一...'id3' in 'order clause' 错误在order by子句 在此,我们需要明确的是,以上对于SQL语句测试,仅仅是简单测试了解析的过程,如果包含limit子句,整个SQL中是如下的顺序来执行的

    1.8K50

    MySQL SQL剖析(SQL profile)

    分析SQL执行带来的开销是优化SQL的重要手段。在MySQL数据库中,可以通过配置profiling参数来启用SQL剖析。该参数可以在全局和session级别来设置。...对于全局级别则作用于整个MySQL实例,而session级别紧影响当前session。该参数开启后,后续执行的SQL语句都将记录其资源开销,诸如IO,上下文切换,CPU,Memory等等。...根据这些开销进一步分析当前SQL瓶颈从而进行优化与调整。本文描述了如何使用MySQL profile,不涉及具体的样例分析。...IPC --显示发送和接收相关开销信息 | MEMORY --显示内存相关开销信息 | PAGE FAULTS --显示页面错误相关开销信息...语句的开销信息 --可以直接使用show profile来查看上一条SQL语句的开销信息 --注,show profile之类的语句不会被profiling,即自身不会产生Profiling --我们下面的这个

    4.5K10

    Mysql的SQL优化指北

    概述 在一次和技术大佬的聊天中被问到,平时我是怎么做Mysql的优化的?在这个问题上我只回答出了几点,感觉回答的不够完美,所以我打算整理一次SQL的优化问题。...接着要做“语法分析”,根据词法分析的结果,语法分析器会根据语法规则,判断你输入的这个SQL语句是否满足MySQL语法。...MySQL通过分析器知道了你要做什么,通过优化器知道了该怎么做,于是就进入了执行器阶段,开始执行语句。开始执行的时候,要先判断一下你对这个表T有没有执行查询的权限,如果没有,就会返回没有权限的错误。...所以SQL优化工作都是优化器的功劳,而我们要做的就是写出符合能被优化器优化的SQL。...所以上面的SQL相当于: mysql> select * from tradelog where CAST(tradid AS signed int) = 110717; 所以这条包含了隐式类型转换的

    1.2K20
    领券