国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 數據庫 > Access > 正文

將現有的Access數據庫升級為SQL

2024-09-07 19:05:04
字體:
來源:轉載
供稿:網友

很多access和SQL Server開發人員都經常面臨著將一個Access數據庫升級到SQL Server數據庫的問題。由于存在現有的Access升級向導,這一轉變的過程就會變得相當簡單,尤其是當你建立一個與SQL Server數據相聯系的ADP的時候。然而,向導并不是十全十美的,需要解決的問題還是大有存在。


首先,有些對象并不是簡單的升級,所以這時你不得不人為地處理。第二,很多Access特性──比如一些查詢類型,對象,以及特定的數據類型在你沒有做好升級之前的準備的情況下就會導致錯誤的產生。現在,讓我們討論一下在數據庫升級過程中可能面臨的問題,我將提供能夠解決問題的一些通用的指導方法,最后,你必須花一定的時間和精力將這些知識應用到開發之中。

哪些不能夠升級?
在處理實際的問題之前,讓我們看看不能隨意升級的對象,它們包括以下:

交叉表查詢
包含SQL DISTINCTROW關鍵字的任何查詢
所有的隱藏對象
作為參數的表格數據的查詢(這些表格可以升級,但它們卻不能正確的運行)
Pass-Through查詢
SQL數據定義語言查詢(比如CREATE TABLE, ALTER TABLE, 以及DROP語句)
這些Access對象需要特定的處理。具體的,你將建立一個可比較的SQL Server對象,除此之外,SQL Server不支持Jet安全特性,所以你必須使用Windows認證和/或SQL Server安全機制。

包括的問題點
在數據庫的升級之前,如果你已經知道哪些地方將可能導致錯誤并知道如何處理產生的錯誤,數據庫升級過程中導致的錯誤的可能性將大大地減少。我能夠提供的數據庫升級的最好的建議是在開發之前做好最完整的計劃。現在,我將列舉數據庫升級過程中可能會導致產生的問題──如果你沒有做好計劃之前的準備。

不支持的日期
 
關于日期,在Access和SQL Server之間都存在很大的差別。Access支持很大范圍的日期,從100年1月1日到9999年12月31日。相反,SQL Server支持的日期從1753年1月1日到9999年12月31日。數據庫的升級向導無法升級包含SQL Server不支持的日期的表格。這就意味著在升級之前你必須人工地處理這些日期。幸運的是,這一問題只影響少數的數據庫。

與表格控制相關的查詢
開發人員通常會使用表格控制的查詢來限制或詢問一個數據來源。一個表格可以提供將數據顯示在一個特定報告中的多種選擇。例如,SQL SELECT語句包含了用戶的輸入:

 SELECT Orders.RequiredDate, Orders.ShippedDate, Orders.Freight,
    Orders.ShipName, Orders.ShipAddress, Orders.OrderDate
FROM Orders
WHERE
 Orders.OrderDate Between [Forms]![DateFilter]![DateFrom] And [Forms]![DateFilter]![DateTo]));

為了限定報告中的數據,用戶可以輸入一個開始和結束的日期到列表(DateFrom 和DateTo)。其他的代碼可以打開并顯示滿足用戶輸入的兩個日期之間的記錄。

因為這種查詢方式被Jet處理,表格中產生的問題可以很快被解決。然而,當數據庫升級時,SQL Server不會涉及到表格控制,結果通常為查詢失敗。為了修正這一查詢方式,開發人員必須更改表格。我建議你使用輸入參數屬性,并將數值傳遞到SQL Server存儲程序。

交叉表查詢
SQL Server不支持Jet TRANSFORM語句──這一語句可以使一個交叉表查詢成為可能。例如,數據庫升級向導支持以下查詢方式:

TRANSFORM Sum(CCur([Order Details].UnitPRice*[Quantity]*(1-[Discount])/100)*100)
    AS ProductAmount
SELECT Products.ProductName, Orders.CustomerID, Year([OrderDate]) AS OrderYear
FROM Products INNER JOIN (Orders INNER JOIN [Order Details]
ON Orders.OrderID = [Order Details].OrderID) ON Products.ProductID =
    [Order Details].ProductID
WHERE Orders.OrderDate Between #1/1/1997# And #12/31/1997#
GROUP BY Products.ProductName, Orders.CustomerID, Year([OrderDate])
PIVOT "Qtr " & DatePart("q",[OrderDate],1,0) In ("Qtr 1","Qtr 2","Qtr 3","Qtr 4")

 

還好,你無需在SQL Server中使用Transact-SQL (T-SQL) CASE關鍵詞重新編寫一個Access的交叉表查詢。下面的SELECT語句描述了使用T-SQL方式重新建立一個交叉表查詢的語法:

SELECT Customers.CustomerID, Customers.CustomerName
    SUM (Case When Orders.Orderdate BETWEEN '01-Jan-1990' AND '31-Dec-1996'
    Then [UnitPrice]*[Quantity] Else 0 End) as 1997)
FROM Customers INNER JOIN Orders
ON CustomerID=Orders.CustomerID

 

隱藏對象
所有的隱藏對象在數據庫升級過程中都被忽略。對此,你最好的處理方法是使用程序對象的GetHiddenAttribute屬性檢查對象。例如,以下代碼使用這一方法決定對象是否被隱藏。
Dim IsHidden As Boolean
If application.GetHiddenAttribute(objtype, objname) Then  
  IsHidden = True
End If

如果特定的對象被隱藏,IsHidden布爾變量將被為True。

包含索引的表格
 
數據庫升級向導不支持沒有索引或其他限制的表格。升級向導可以升級一個無索引的表格,但其轉換之后只能成為一個只讀的表格。幸運的是,解決這一問題很簡單:添加一個索引到每一個沒有索引的表格。一旦你已經完成升級數據庫,請記住將添加的索引刪除。

數據庫升級操作步驟
一旦你已經做好一切準備,并確定操作可以開始。數據庫升級向導可以為你提供三種選擇:

輸出Access表格到SQL Server并鏈接到Access數據庫
使用Pass-Through查詢與SQL Server的后臺服務器的表格相互通訊
將整個Access數據庫移動到一個Access數據庫工程(其只與SQL Server聯系)
為了啟動數據庫升級向導,先從工具菜單欄中選擇數據庫功能,然后從子菜單中選擇升級向導。向導的第一個面板提供兩種選擇:你可以建立一個新的SQL Server 數據庫來存放Access表格,如圖A所示,或者你可以在一個現成的SQL Server數據庫中添加表格。選擇一個現成的SQL Server數據庫將需要輸入一個數據服務名稱(DSN)。

圖 A

選擇建立一個新的數據庫或者使用一個現成的數據庫
 
第二個面板要求獲得SQL Server范例的信息。除此之外,你必須認證安全機制(如果存在)和為新的數據庫提供一個缺省的名稱,如圖B所示。
圖B
 

為一個新的數據庫命名

在這點上,你可以將需要的表格復制到SQL Server,你也可以指出完成的部分將成為一個完整的ADP或者一個被鏈接的表格,如圖C所示。

圖 C

指明一個ADP或者一個被鏈接的表格


避開麻煩

每一個開發人員都有不同的數據庫升級操作的經驗,所以無法保證第一次操作就能夠達到成功。然而,如果你遵循本文中提供的有關規則,你應該遇到更少的錯誤,即使碰到,你也可以很容易地修正錯誤,并繼續操作。


 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
欧美aaa一级片| 在线免费观看污| 国产一级免费在线观看| 久草网在线视频| 欧美性猛交xxxxbbbb| 日韩国产成人| 国产美女自拍视频| 国产免费黄网站| 国产精品美女一区二区三区四区| 国产精品yjizz视频网一二区| 激情综合丁香| 国产乱在线观看视频| 国产丝袜在线| 天天干天天操天天爽| 丁香综合在线| 国产激情视频一区二区三区| 在线观看av网站永久| 快射av在线播放一区| 日本中文字幕在线视频| 91av福利| 午夜视频在线免费| 中文资源在线网| 国产美女高潮一区二区三区| 国产超碰97| 日日夜夜中文字幕| 激情六月丁香| 亚洲网站一区| 69精品视频| 国产精品第八页| 不卡av免费观看| 国产黄色片在线播放| 任你操在线观看| 97影院理论午夜| 黄网在线免费| 精灵使的剑舞无删减版在线观看| 国产福利免费在线观看| 亚洲人成电影| 亚洲免费国产| √天堂中文在线| 超碰国产在线| 国产黄视频网站| 国产真实伦在线观看| 一本大道香蕉8中文在线视频| 国产免费av高清在线| 狠狠插狠狠操| 天天操夜夜摸| 国产人成在线观看| 91国内在线| eeuss影院在线观看| а√最新版地址在线天堂| 在线中文字幕观看| 亚洲图区综合| 老鸭窝av在线| 国产偷倩在线播放| 国产porny蝌蚪视频| 精品国产免费观看一区| 中文字幕在线播放网址| 国产一区久久精品| 国产二级c片l毛片| 亚洲欧美日韩成人网| 欧美亚洲另类在线观看| 黄色毛片在线| 91欧美在线视频| 69视频在线观看| 超碰在线中文| 69堂视频在线观看国产| 不卡av免费观看| 国产精品臀控福利在线观看| 国产日本在线观看| 亚洲高清在线免费| 国产字幕在线看| 天天av天天爽| 四虎久久影院| 2019年中文字幕| 成在线人视频免费视频| 91资源在线观看| 国产美女自拍视频| 亚洲综合在线网| 国产午夜在线| 久热免费在线视频| 99久久精品免费观看国产| 丁香婷婷在线观看| xxx国产精品| 在线观看免费高清完整| 国产无遮挡又黄又爽免费软件| 在线免费国产| 中文字幕av中文字幕| 青青草免费在线观看| 精品偷拍激情视频在线观看| 黄色电影网站在线观看| 在线国产小视频| 精品免费视频一卡2卡三卡4卡不卡| 激情丁香婷婷| 九九精品视频在线观看九九| 亚洲妇熟xxxx妇色黄| 国产精品久久久精品a级小说| 青青久在线视频免费观看| 精品国内一区二区三区免费视频| 国产一区二区三区福利| 国产九色porn网址| 国产一级免费黄色片| 久久一本精品| 国产乱子视频| 国产一级黄色| 国产私人尤物无码不卡| 中文字幕中文字幕在线中高清免费版| 青青青青在线| 国产美女自拍视频| 最近中文字幕mv免费高清电影| 黄色av免费看| 国产天堂在线播放视频| 国产人成高清视频观看| 国产馆av播放| 精精国产xxxx视频在线中文版 | 99在线免费观看| 中文一区在线观看| 精品极品三级久久久久| 精品美女调教视频| 亚洲国产日韩在线人成电影| a视频免费看| 国产在线色视频| 国产视频二区| 99在线播放| 久久久久久77777| 国产福利小视频在线| av日韩国产| 日本欧洲一区| 91超碰在线免费| 999国产在线视频| 黄色毛片在线看| 国产经典av| 九九热视频免费在线观看| 国产一二区视频| www在线视频| 国产成+人+亚洲+欧美+综合| www在线视频| 国产95在线|亚洲| 国产在线免费观看| 精品一二三四| 国产一级网站视频在线| 亚洲欧美综合乱码精品成人网| 欧美日韩在线中文字幕| 国产精品bbw一区二区三区| a级片国产精品自在拍在线播放| 天堂中文资源在线| 玖玖在线视频| 日本高清中文字幕二区在线| 国产精品69一区二区三区| 国产中文第一页| 欧美精品日韩少妇| 天天插天天操| 四虎精品视频| 天天操夜夜做| av网址在线播放| 国产aa视频| 91麻豆精品国产91久久| 九七电影韩国女主播在线观看| 在线影视一区| 2019年中文字幕| 国产精品久久久久久精| 国产乱视频在线观看| 九九色在线观看| 另类专区欧美| 国内自拍视频在线看免费观看| 亚洲成av人影片在线观看| 99中文字幕一区| 尤物在线精品视频| 羞羞视频在线免费看| 日韩亚洲一区中文字幕| 日本福利午夜视频在线| 超碰免费在线播放| 丁香婷婷激情| 国产欧美日韩精品综合| 国产精品你懂的在线观看| 国产寡妇树林野战在线播放| aaa大片在线观看| 欧洲亚洲精品视频| 天天操天天艹| √天堂资源中文www| 在线一区二区三区精品| av在线free| 国产在线超碰| 国产成人亚洲综合小说区| 伊人国产在线看一| 国产专区在线播放| 精品国产99久久久久久| 夜夜爽视频导航| 懂色一区二区三区| 精品欧美日韩一区二区| 美女免费视频黄| 国产三级做爰在线观看| 在线一区观看| 黄污在线观看| 亚洲尤物在线视频| 国产欧美在线观看视频| gogo在线高清视频| 国产一区二区三区不卡在线| 性色视频在线| 国产精美视频| 最好2018中文免费视频|