關於sql語句中的一些函式(長期更新)
前言
在最近看別人的sql的時候,看到一些函式,比如left(),right()等等,好奇是什麼意思,查詢之後覺得還是挺有用的,特此記錄下來。部落格會在遇到新的函式的時候定期更新。
————————————————————————————————————————————————————
正文
1. left()和right()
在一個sql中遇見了left(character,integer)函式,覺得好奇,百度了之後發現意義是:返回left(character,integer)中character從左起第一個到第integer個字元。如果integer是負的,那麼返回空的字串。
right()同理。
舉個例子:left("abcdefg",3)得到的結果是:abc,因為要拿abcdefg的前三個字元,也就是abc。
需要注意的是:oracle中是沒有這兩個函式的,oracle中對應的是substr(字串,擷取開始位置,擷取結束位置)。
2. ISNULL(A,B)
關於ISNULL(A,B),其意義是:如果A為null的時候,則返回B的值,如果不為null,則返回A的值。常見應用為聚合求和的時候。
舉個例子:
ISNULL(SUM(num),0):如果對num列求和結果為null(也就是資料庫這列資料都沒有值),那麼就返回0。
3. NOW()函式:<<Mysql可用>>
NOW()函式,可以用來獲取當前時間的函式。目前測試了mysql和sqlserver,只可以在mysql中使用。--Mysql資料庫
SqlServer資料庫,無法識別的內建函式
4. day(),month(),year()時間函式
- day()函式:獲取查詢結果的日期值
- month()函式:獲取查詢結果的月份值
- year()函式:獲取查詢結果的年份值
正常的年份的查詢,8位的資料格式。
6位的時間格式,如果年份的後兩位<= 12,那麼系統會預設將後兩位作為月份和日期來處理,前兩位預設為20+“日期的前兩位”,所以得到的是2020年12月01日的時間,需要特別注意!
如果你的年份後兩位>12,那麼會直接報錯!因為不能轉換成大於12月的資料。所以一般還是建議時間格式位8位!
所以:如果時間格式確定都是6位,那麼建議使用的是left()函式,而非year()函式。
5. dateAdd()和date_add()函式
sqlServer中,幾天後的時間使用的是dateAdd()函式,DATE_ADD() 函式向日期新增指定的時間間隔。
DATE_ADD(date,INTERVAL expr type)
date 引數是合法的日期表示式。
expr 引數是您希望新增的時間間隔。
type 引數可以是下列值:見w3cschool連結
在mysql中,使用的則是:date_add()函式,DATEADD() 函式在日期中新增或減去指定的時間間隔。
DATEADD(datepart,number,date):
date 引數是合法的日期表示式。
number 是您希望新增的間隔數;對於未來的時間,此數是正數,對於過去的時間,此數是負數。
datepart 引數可以是下列的值:見w3cschool連結
用法如下:
sqlServer中的方法
mysql中的方法
特別注意的是:更過的date的時間函式,請參考w3cschool:W3Cschool資料庫時間函式連結,其中有mysql和sqlServer的時間函式。
6. UNION和UNION ALL
在寫sql的時候,有些資料的儲存可能涉及到分庫分表,查詢的時候,可能需要查詢所有的分表,這個時候,就需要用到UNION或者UNION AL。
union操作符:用於合併兩個或多個SELECT語句的結果集,這裡需要注意的是:UNION內部的SELECT語句必須擁有相同數量的
列,列也必須擁有相似的資料型別,同時,每條SELECT語句中列的順序必須相同。
SELECT name FROM user UNION SELECT name FROM user1 //得到的結果就是:分別從user表和user1表中查詢name欄位,然後合併到一起。
需要特別注意的是:union操作符合並的結果集,不允許重複,如果不要去重的話,需要使用union all。
案例sql:(參考:https://blog.csdn.net/zouxucong/article/details/73468979)使用foreach迴圈,並用union all連線,簡化操作,查詢多表並將結果集進行合併。分庫分表必會技能!
<select id="getFourteenHotPost" parameterType="map" resultMap="productCommentsInfoAndroid">
select t.comments_id,t.product_id,t.comment,t.order_path from (
<foreach collection="tableNames" item="item" separator="UNION ALL">
(SELECT c.comments_id,c.product_id,c.comment,i.order_path,c.p_index,c.t_index,c.title,c.time
FROM ${item} as c left join `gshop_comments_img` as i on c.comments_id = i.comments_id
where c.object_type=2 and c.display=1 and c.is_show=1
and c.t_index=1
GROUP BY c.product_id ORDER BY c.p_index asc,c.t_index desc,c.title desc,c.time desc limit 14)
</foreach>) t
GROUP BY t.product_id ORDER BY t.p_index asc,t.t_index desc,t.title desc,t.time desc limit 14
</select>
————————————————————————————————————————————————————
後記
這裡僅僅記錄了目前遇見的一些函式,如果以後遇到了還會繼續更新。