最近面试中sql题

本文探讨了两种SQL查询方式的不同之处,即使用LIKE通配符的影响及NULL处理的区别,并对比了SELECT COUNT(*)与SELECT COUNT(1)在不同情况下的性能表现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.SQL问答题
SELECT * FROM TABLE

SELECT * FROM TABLE
WHERE NAME LIKE '%%' AND ADDR LIKE '%%'
AND (1_ADDR LIKE '%%' OR 2_ADDR LIKE '%%'
OR 3_ADDR LIKE '%%' OR 4_ADDR LIKE '%%' )
的检索结果为何不同?

(1).like通配符一个个比较肯定影响效率,
(2).数据库中存在null的时候,如果字段中有null存在select * from table 可以显示所有的内容,但是like不会通配null,所以字段为null它显示不出来!!

二.select count(*) from table
和select count(1) from talbe的区别??

只明白count(字段)时它是不检索null的!

但是在count中1和*现在还没有明确答案,求高手!!!~

网上搜索的答案:自己没有试过,有时间测试一下!!哎!

跟表结构有关系:
如果表中没有主键,那么count(1)比count(*)快
如果有主键,那么count(主键/联合主键)比count(*)快
如果表中只有一个字段,count(*)最快
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值