当我们编写SQL查询时,我们会为缩进添加额外的空间,使其更具可读性。这些空间可以很快加起来。我想知道这些额外的空间是否可以
明显地
影响网络延迟和/或DB中的查询解析时间。
-
从客户端/ORM发送到数据库服务器的查询字符串是否也包括这些空间,或者它们是否被客户端/ORM剥离/规范化?
-
查询字符串中有很大的空间会影响性能吗
明显地
,因此应尽量减少
在合理范围内
?
为了便于说明,以下查询总共由577个字符组成:
select * from (
select
u.id as userId,
u.name as userName,
sum(case when date(u.login_at) <= date('2020-12-31') then 1 else 0 end) as loginCount,
max(case when date(u.login_at) <= date('2020-12-31') then u.login_at else null end) as lastLogin,
from user u
join user_login ul on u.id = ul.user_id
where u.id = '12345'
group by u.name, u.id
) x
where loginCount > 0;
而去掉不必要空白的同一查询只包含329个字符,查询大小减少了43%。
select * from(select u.id userId,u.name userName,sum(case when date(u.login_at)<=date('2020-12-31')then 1 else 0 end)loginCount,max(case when date(u.login_at)<=date('2020-12-31')then u.login_at else null end)lastLogin,from user u join user_login ul on u.id=ul.user_id where u.id='12345' group by u.name,u.id)x where loginCount>0;
注意:我不赞成像第二个那样编写查询。我只是想知道时间上是否有实质性的差异。