记录一下最近项目中遇到的一些有关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)代替; 优点:表关联可能有多条记录,子查询只有一条记录,如果需要唯一的列,最好走子查询
hana sql语句
最新推荐文章于 2024-04-30 11:45:43 发布