最近面试中sql题

一.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(*)最快
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值