Oracle轉SqlServer

来源:https://www.cnblogs.com/saozhou/archive/2019/12/11/12020223.html
-Advertisement-
Play Games

基礎數據所對應的類型不同 在Oracle中有一些基礎類型與Sqlserver中名字一樣,但是所存儲的數據格式不同,Date類型在Oracle中精確到秒,在Sqlserver中只能精確到分 表的結構 Oracle中所有的表都有一個共同的欄位,rowid這是在物理上存在的,記錄了每一條記錄的行位置,ro ...


 基礎數據所對應的類型不同

   在Oracle中有一些基礎類型與Sqlserver中名字一樣,但是所存儲的數據格式不同,Date類型在Oracle中精確到秒,在Sqlserver中只能精確到分

   表的結構          

    Oracle中所有的表都有一個共同的欄位,rowid這是在物理上存在的,記錄了每一條記錄的行位置,rownum 是邏輯上的,根據排序方式的不同會出現不同的rownum,因為Oracle的這個特性,經常在進行一些crud操作的時候會通過rowid來進行,導致在轉資料庫的時候會遇到各種麻煩,所以我建議各位不管是使用哪一種資料庫最好是使用標準sql,並且不要太依賴某種資料庫的特性。我開始是想通過row_number()加with as 去代替rowid,但是總會出現一些奇怪的問題,你前一次查詢的id,重新進入資料庫操作的時候改變的是另外一條記錄,最後的解決方式我把每一張表都添加上了rowid

    Oracle的to_date,to_char方法

    在轉Oracle資料庫的時候這兩個方法出現了很多次,看他們的名字就知道是乾什麼的,Sqlserver中沒有這樣的方法,但是有conver,cast方法這兩個方法可以實現Oacle兩個方法的所有功能

    Oracle的NVL方法可以用isnull代替

    在Oracle中子查詢語句可以有order by,而在sqlserver需要添加top()函數    

 

Oracle比sqlserver的優勢

    我個人覺得oracle的優勢在他的圖形用戶界面,雖然長相不好,但卻實用,如果有失誤的操作還能夠rollback,導出數據時也很方便,在把oracle數據遷移到sqlserver時只要關註兩個資料庫之間數據類型的差異,不用擔心oracle的數據問題,可以一鍵查詢提出成文件,而sqlserver操作起來反而複雜,我還沒有找到導出sqlserver sql文件的方法。

資料庫轉換需要註意的幾個點:

  1:基礎數據之間的差異,在不同的數據中相同名字的數據類型可能存的值存在某些差異,我也沒有弄清有哪些類型,但是這是一個需要註意的點

  2: 某些資料庫獨有特性在轉換時要面向整體去設計

3:不同資料庫所用sql也有不同,但總能找到替代的方法,一定要用心

 

 

    


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 什麼是FTP? FTP(File Transfer Protocol,文件傳輸協議),是TCP/IP網路和Internet上最早使用的協議之一。用來將實現從一臺電腦傳送文件到另一臺電腦,或者接收和查看另一臺電腦上的文件。一般需要藉助軟體的幫助才能完成。這方面的軟體包括FlashFXP、leapftp ...
  • 文檔的壓縮和打包 .gz 表示由gzip壓縮工具壓縮的文件 .tar 表示由tar打包程式打包的文件 .tar.gz 先由tar打包,再由gzip壓縮 gzip壓縮工具 -d 該參數在解壓縮時使用 -# 表示壓縮等級,1為最差,9為最好,6為預設 xz壓縮工具 tar打包工具 ...
  • 配置雙主複製功能,在主1和主2上執行均下麵的步驟 vim syncprov_mod.ldif dn: cn=module,cn=configobjectClass: olcModuleListcn: moduleolcModulePath: /usr/lib64/openldapolcModuleL ...
  • 解析:在mysql 工具 搜索或者插入數據時報下麵錯誤: ERROR 1055 (42000): Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'database_tl ...
  • 2019-12-11對varchar類型排序問題的解決 在mysql預設order by 只對數字與日期類型可以排序,但對於varchar字元型類型排序好像沒有用了,下麵我來給各位同學介紹varchar類型排序問題如何解決。 現象描述: select * from resultgroup where ...
  • #內連接select * from auth_user u inner join auth_group g on u.id = g.id; #左連接select * from auth_user a left join auth_group b on a.id = b.id; #右連接select ...
  • 問題描述:做scn恢復備庫的測試,吭哧了幾天,今天終於可以記錄一下,遇到了很多坑,作為初學者可以更好地理解DG,主要先關閉備庫,在主庫做歸檔丟失備庫無法同步,備庫產生GAP,然後增量備份恢復備庫,版本:SQL*Plus: Release 11.2.0.4.0 Production on Thu No ...
  • SELECT B.NAME,A.ROW_COUNT FROM SYS.DM_DB_PARTITION_STATS A,SYS.OBJECTS BWHERE A.OBJECT_ID=B.OBJECT_ID AND A.INDEX_ID<=1AND B.TYPE='U'AND A.ROW_COUNT>8 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...