十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
问题:mysql语句中使用like后面的%(百分号)
创新互联公司主营咸宁网站建设的网络公司,主营网站建设方案,重庆APP开发公司,咸宁h5微信平台小程序开发搭建,咸宁网站营销推广欢迎咸宁等地区企业咨询
是不是越多执行效率越慢!
总用时:0.0489秒
0.0691
0.0485
0.0467
SELECT
`goods_name`,
`goods_img`,
`sku_id`,
`import`
FROM
`goods`
WHERE
`goods_name`
LIKE
'%iPhone%iPod%'
AND
`stime`
1413877244
AND
`etime`
1413877244
ORDER
BY
`flag`
DESC
总用时:0.0460秒
0.0430
0.0493
0.0783
0.0496
SELECT
`goods_name`,
`goods_img`,
`sku_id`,
`import`
FROM
`goods`
WHERE
`goods_name`
LIKE
'%iPhone%'
AND
`goods_name`
LIKE
'%iPod%'
AND
`stime`
1413877367
AND
`etime`
1413877367
ORDER
BY
`flag`
DESC
总用时:0.0458秒
0.0441秒
0.0449秒
SELECT
`goods_name`,
`goods_img`,
`sku_id`,
`import`
FROM
`goods`
WHERE
`goods_name`
LIKE
'%%%%%%%%%%%%%%%%%%%%%%%iPhone%iPod%%%%%%%%%%%%%%%%%%%%%%%'
AND
`stime`
1413877997
AND
`etime`
1413877997
ORDER
BY
`flag`
DESC
实践证明,百分号的数量不影响sql执行的速度。这几种方法的效率都是差不多的。
以上是我测试的结果。个人可根据自己的实际需求去选择写法!建议是最好选择第二种!
建立数据库表时,百分数要用字符类型。
原因:因为百分号(%)不是可读的数字类型,除非用小数表示,否则只能用字符类型来保存。
工具:mysql 5.6
测试步骤:
1、数据库中test表结构如下,其中col1为字符类型,col2位数字类型
2、在col1中插入50%这个数据。语句如下:
insert into test(col1) values ('50%');
插入后结果:
3、在col2中也插入50%这个数据,语句如下:
update test set col2=50%;
系统会报错:
总结:说明带百分号的数据只能用字符类型来存储。
CONCAT(字段, '% ')
select CONCAT(sum(a)/(sum(a)+sum(b)*100), '% ')
from c
以百分比形式输出sql查询结果的步骤如下:要准备的材料是:computer,sql querier。
1.首先,打开sql查询器并连接到需要查询的数据表。以测试表的得分字段为例。
2.单击“查询”按钮并键入:选择`name`,concat(truncate(score * 100,2),'%')作为test的分数。
3.单击“运行”按钮。此时,得分字段的查询结果可以显示为百分比。
那你查询前把你要查询的特殊符号替换下 % 替换为 \% 这样mysql 就不会把你输入的 % 当成特殊字符了
select * from table where name like '/%' escape '/';
这样就行了,如果你要查找a%b
则可以
select * from table where name like 'a/%b' escape '/';