1. 程式人生 > >關於sql語句中的一些函式(長期更新)

關於sql語句中的一些函式(長期更新)

前言

在最近看別人的sql的時候,看到一些函式,比如left(),right()等等,好奇是什麼意思,查詢之後覺得還是挺有用的,特此記錄下來。部落格會在遇到新的函式的時候定期更新。

————————————————————————————————————————————————————

正文

1. left()和right()

在一個sql中遇見了left(character,integer)函式,覺得好奇,百度了之後發現意義是:返回left(characterinteger)中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>  

————————————————————————————————————————————————————

後記

這裡僅僅記錄了目前遇見的一些函式,如果以後遇到了還會繼續更新。