hana sql语句

记录一下最近项目中遇到的一些有关sql语句的知识:
1.hana 中 isnull 写为ifnull (经常用于判断分母是否为0)
CASE WHEN IFNULL(PO.UMREN,0)=0 THEN 0 ELSE IFNULL(PO.MENGE,0)*IFNULL(PO.UMREZ,0)/IFNULL(PO.UMREN,0) AS “BaseQtyOrd”,
2."IF @VOperPrice = 0
SET @VNoNetValue1 = N’SRC.NetValue1’
ELSE
SET @VNoNetValue1 = N’0’(将@VNoNetValue1视为0)
2.case when SER.SerialNo <> ‘’ then RES.Qty/ABS(RES.Qty) else RES.Qty end
SER.SerialNo不等于’'时值为RES.Qty/ABS(RES.Qty) abs()取绝对值,否则值为RES.Qty
3.union 相当于去重,union all则将重复的也加入运算
4.select dept , max(salary) AS MAXIMUM FROM STAFF GROUP BY DEPT
查询max(),min().sum()等聚合函数后通过GROUP BY语句得到,
除聚集计算语句外,SELECT语句中的每个列都必须在GROUP BY子
句中给出(注意)。
WHERE语句在GROUP BY语句之前;SQL会在分组之前计算WHERE语句。
HAVING语句在GROUP BY语句之后;SQL会在分组之后计算HAVING语句。
5.SELECT Company,SUM(Amount) FROM Sales
GROUP BY Company
HAVING SUM(Amount)>10000
having是用来对Group by 查询的结果进行筛选的相当于where
6.CREATE INDEX PK_TmpKangDaBillingResult_SKU ON #TmpKangDaBillingResult(SKU)
在#TmpKangDaBillingResult表中为SKU列创建索引
7.where PO.MANDT = ‘20’
and (PO.BSART = ‘ZDDM’ or PO.BSART = ‘ZDID’)和
where PO.MANDT = ‘20’
and PO.BSART = ‘ZDDM’ or PO.BSART = ‘ZDID’
区别: AND优先级高于OR
8.子查询:缺点:执行时需要创建临时表,查询完毕后在删除这些临时表,所以查询速度受到影响,
优化:使用连接查询(join)代替; 优点:表关联可能有多条记录,子查询只有一条记录,如果需要唯一的列,最好走子查询

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值