数据库查询语句(高端)

1. 想要查出在订单这张表中,按起始港出现频率由高到低的订单排序

select o.* from orders o orderby (select count(os.shid) from orders os where os.shid = o.shid)

 

2. 想要查出在订单表中,出现频率最高的起始港的港口信息

SELECT h.*, orderharbor.count from harbor h INNER JOIN 

(SELECT o.shid,COUNT(o.shid) as count from orders o GROUP BY o.shid ORDER BY count DESC LIMIT 1) orderharbor

ON h.harborid = orderharbor.shid

 

3. 查询表中最小值属性的一般方法: 将记录按该属性的升序排列,取出第一个记录即可。

 

4. union 会消除重复数据。如果想在结果保留重复数据,可以使用union all。

    intersect 操作输入两个关系A和B,选择那些即在A也在B的行。

    except 操作输入两个关系A和B,找出所有在A但不在B的行。

 

5. is null 或者is not null 操作符检测null是否存在。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值