T-SQL和PL/SQL 區別

 

ORACLE PL/SQL與SQL SERVER T-SQL一些比較

字符串連接
Oracle用|| 符號作爲連接符,而SQL Server的連接符是加號:+ 。
Oracle查詢如下所示:Select ‘Name’ || ‘Last Name’ From tableName
SQL Server查詢如下:Select ‘Name’ + ‘Last Name’
GUID
Oracle用SYS_GUID()生成GUID,不含{}和-;getregguidstring 生成 GUID 含{}和-;
SQL Server用NEWID生成GUID;  
數字取捨
Oracle數據庫內有一個TRUNC函數,該函數返回m位十進制數的n位;如果省略m則n就是0位。m的值可以爲負,表示截去小數點左邊m位數字。
在SQL Server下可以用Round或者Floor。
Oracle查詢如下所示:SELECT  TRUNC(15.79,1) "Truncate" FROM DUAL;
SQL Server查詢如下:SELECT ROUND(15.79, 0) rounded , ROUND(15.79, 0,1) truncated 
                                      SELECT FLOOR(ROUND(15.79, 0)), FLOOR(ROUND(15.79, 0,1) )
數字轉換
Oracle的TO_CHAR函數可以把n位NUMBER數據類型轉換爲VARCHAR2 數據類型,同時採用可選的數字格式。
SQL Server則通過STR函數返回數字轉換之後的字符數據。不過,該函數不具方便的Format參數。
Oracle查詢如下所示:SELECT to_char(123.45 ,99999999999999) from tab
                                      SELECT to_char(EXPIRY_DATE,'DDMONYYYY') from tab
SQL Server查詢如下:SELECT STR(123.45, 14) 
                                      SELECT STR(round(123.455 , 2),12,2)
                                      SELECT CAST(REPLACE((CONVERT(varchar(12) , EXPIRYDATE, 106 )),' ' , '') as varchar(9))
LENGTH和LEN
Oracle查詢如下所示:SELECT LENGTH('SQLMAG') "Length in characters" FROM DUAL;
SQL Server查詢如下:SELECT LEN('SQLMAG') "Length in characters"
日期
兩種系統都具有各自的當前日期和時間格式。
Oracle取得日期和採用如下方式:SYSDATE
SQL Server則是這樣的:GETDATE()
你可以用各種語法操作日期。
以下的代碼對Oracle日期值中的月份進行了格式調整(返回日期再加上n月):Select   add_months(sysdate,12) from dual
SQL Server則是如下完成同等功能的:Select dateadd(mm,12,getdate())
數據的減法也不同。
Oracle中直接對數據進行減法操作:SELECT sysdate -add_months(sysdate,12) FROM dual
SQL Server則是這樣做的:SELECT  datediff(dd, GetDate(),dateadd(mm,12,getdate()))
執行查詢時
PLSQL執行查詢的時候,FROM子句是必須的,而SQL SERVER不一定
如ORACLE中select 2*5 from dual
而SQL SERVER中select 2*5

 

SQLserver與Oralce中的兩表關聯更新是區別的。

在T-SQL中更新相對簡單些,直接用下面的語句都是可以:

Update b
Set b.processflag = a.processflag
From temp_1 a Join temp_2 b
On a.msgid_db = b.msgid

Update temp_2
Set Usertime = b.Usertime
From temp_2 a Join temp_1 b
On a.msgid = b.msgid_db

Update temp_2
Set Usertime = b.Usertime
From temp_1 b
where msgid = b.msgid_db

而在Oracle中這樣寫是不對的,應該更改如下:

Update Temp_2 a
   Set a.Usertime = (Select b.Usertime
             From Temp_1 b
             Where b.Msgid_Db = a.Msgid)
Where Exists (Select 1 From Temp_1 b Where b.Msgid_Db = a.Msgid);

更新多個字段:

Update Temp_2 a
   Set a.Usertime = (Select b.Usertime
             From Temp_1 b
             Where b.Msgid_Db = a.Msgid),
       a.processflag = (Select b.processflag
             From Temp_1 b
             Where b.Msgid_Db = a.Msgid)
Where Exists (Select 1 From Temp_1 b Where b.Msgid_Db = a.Msgid);

多表關係更新:

Update Temp_2 a
   Set a.Usertime = (Select b.Usertime
             From Temp_1 b
             Where b.Msgid_Db = a.Msgid),
       a.processflag = (Select c.processflag
             From Temp_3 c
             Where c.Msgid = a.Msgid)
Where Exists (Select 1 From Temp_1 b Where b.Msgid_Db = a.Msgid)
        And Exists (Select 1 From Temp_3 c Where c.Msgid = a.Msgid);

感覺這點沒sqlserver理簡單易用~~~

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章