ORACLE PL/SQL與SQL SERVER T-SQL一些比較
Oracle查詢如下所示:Select ‘Name’ || ‘Last Name’ From tableName
SQL Server查詢如下:Select ‘Name’ + ‘Last Name’
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))
Oracle查詢如下所示:SELECT LENGTH('SQLMAG') "Length in characters" FROM DUAL;
SQL Server查詢如下:SELECT LEN('SQLMAG') "Length in characters"
兩種系統都具有各自的當前日期和時間格式。
Oracle取得日期和採用如下方式:SYSDATE
SQL Server則是這樣的:GETDATE()
你可以用各種語法操作日期。
SQL Server則是如下完成同等功能的:Select dateadd(mm,12,getdate())
數據的減法也不同。
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 Update temp_2 Update temp_2 而在Oracle中這樣寫是不對的,應該更改如下: Update Temp_2 a 更新多個字段: Update Temp_2 a 多表關係更新: Update Temp_2 a 感覺這點沒sqlserver理簡單易用~~~ |