MySQL—一个单引号引发的MYSQL性能损失

        如果使用字符串类型的字段来做主键,当我们在查询语句中对该字段值加上单引号和不加查询耗时相差很大!

        建表语句:

CREATE TABLE `foo` (
  `key` VARCHAR(10) NOT NULL,
  `time` INT(11) NOT NULL,
  PRIMARY KEY (`key`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
        然后插入30多万条数据,然后执行下面的SQL语句:
SELECT * FROM `foo` WHERE `key` =1293322797
       查询花费 0.1288 秒,然后给1293322797加上单引号:
SELECT * FROM `foo` WHERE `key` ='1293322797'
        查询花费 0.0009 秒,基本上相差100倍!也就是说不加单引号MYSQL性能损失很大! 惊恐
        后来用EXPLAIN分别跑了一下上面两条语句,见下面两张图:

        没有使用单引号:


         有单引号时:


         很明显,不使用单引号没有用上主索引,而是进行了全表扫描,使用单引号就能使用上索引了大笑。后来我用大于分别进行了测试,返回的结果集相同,而他们的耗时和上面一样,用EXPLAIN测试,也和上面一样:

SELECT * FROM `foo` WHERE `key` >1293322797
SELECT * FROM `foo` WHERE `key` >'1293322797'
         再后来,我将字段`key`换成INT类型,这时候,加不加单引号,就没有什么差别了,EXPLAIN显示他们都同样能够用上主索引,只是key_len变短了。

        综上所述,我们在写SQL查询的时候还是不厌其烦的加上单引号吧,似乎那没有坏处。

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 在 MySQL 中,单引号是用来表示字符串的。例如,如果你想在一个 SQL 查询中使用一个字符串常量,你可以将它放在单引号中。例如: ``` SELECT * FROM my_table WHERE name = 'John'; ``` 这条 SQL 查询将返回 `my_table` 表中所有 `name` 字段值为 `'John'` 的记录。注意,字符串常量必须用单引号括起来,否则 MySQL 将其解析为列名或关键字。 ### 回答2: MySQL中使用单引号是为了表示字符串类型的数据。在SQL语句中,字符串通常被包裹在单引号中,以便于识别字符串的起始和结束位置。 单引号MySQL中的使用有以下几个方面: 1. 插入数据:当向数据库中插入一条记录时,如果某个字段的值是字符串类型,就需要使用单引号将该值包裹起来。例如: ``` INSERT INTO table_name (column1, column2) VALUES ('value1', 'value2'); ``` 2. 更新数据:当更新数据库中的记录时,同样需要使用单引号将字符串类型的新值包裹起来。例如: ``` UPDATE table_name SET column1 = 'new_value' WHERE condition; ``` 3. 查询数据:在查询语句中,如果要匹配字符串类型的值,同样需要使用单引号将要匹配的值包裹起来。例如: ``` SELECT * FROM table_name WHERE column1 = 'value'; ``` 需要注意的是,如果字符串中需要包含单引号本身,可以使用两个单引号进行转义。例如,要保存一个包含单引号的字符串,可以这样写: ``` INSERT INTO table_name (column1) VALUES ('I''m a string with a single quote'); ``` 总结来说,MySQL使用单引号是为了表示字符串类型的数据,使其在SQL语句中容易辨识和区分。同时,使用两个单引号可以在字符串中包含单引号本身。 ### 回答3: MySQL 在查询语句中可以使用单引号 ' 来表示字符串值。这是因为在 MySQL 中,字符串值需要使用引号来标识,而单引号是其中一种常见的方式。 在 SQL 查询语句中,当我们需要指定一个字符串值时,可以使用单引号将该值括起来。例如,如果我们要查询某个用户的姓名是 "张三" 的记录,可以通过以下语句来实现: SELECT * FROM users WHERE name = '张三'; 在这个例子中,'张三' 是一个字符串值,它被单引号括起来表示为一个字符串。 需要注意的是,如果字符串中本身含有单引号,那么在字符串值中的单引号需要进行转义。例如,如果我们要查询某个产品的名称是 "Tom's Product",由于字符串中包含单引号,所以可以使用双引号将它括起来,也可以使用转义字符来表示单引号。以下是两种写法的示例: SELECT * FROM products WHERE name = "Tom's Product"; 或者 SELECT * FROM products WHERE name = 'Tom\'s Product'; 在这两个例子中,我们都成功地使用了单引号来表示字符串值,无论字符串值中是否包含单引号,我们都可以通过适当的方式在查询语句中表示出来。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值