標籤:

Asp.net 2.0 Webpart 資料庫的遷移

作者:童振華 (轉載請注時作者)

Webpart是asp.net 2.0中一項非常出色的功能,但是非常遺憾的是,默認是使用sql express 2005作為後台資料庫。而且很多初學者在本機寫完程序遷移到伺服器上以後才如夢初醒,原來還要後台資料庫的,甚至WROX出的《Professional ASP.NET 2.0》在講webpart這節時都不曾提及後台資料庫的事,真是讓人失望之極(起碼我沒看到)。而目前主流的網站都是用MS SQLServer 2000或是Access作為資料庫,如何才能把Webpart的資料庫從SQL Express 2005遷移到SQLServer 2000和Access呢?

遷移到SQLServer 2000

微軟提供了一個資料庫配置程序,可以方便的在SQLServer2000和SQLServer2005上進行webpart的資料庫配置 。

1.首先運行SQLServer

2.然後運行C:WINDOWSMicrosoft.NETFrameworkv2.0.50727aspnet_regsql.exe 會出現一個圖形化的操作界面,根據提示便可自動生成一個名為aspnetdb的庫。

3.打開vs.net 2005,新建一個網站,往頁面上拖一個webpartmanager,運行一下,出錯。因為你還沒有配web.config呀,而且vs.net2005與vs.net2003有所不同,默認是沒有web.config文件的,需要我們自己增加,(當然你也可以直接修改C:WINDOWSMicrosoft.NETFrameworkv2.0.50727CONFIG下默認的web.config,但是我不推薦)。

4.在新加的web.config中把 <connectionStrings/>一行修改成如下

<connectionStrings>

<remove name="LocalSqlServer" />

<add name="LocalSqlServer" connectionString="Data Source=localhost;Initial Catalog=aspnetdb;Persist Security Info=True;User ID=sa;Password="

providerName="System.Data.SqlClient" />

</connectionStrings>

完成後的web.config為

<?xml version="1.0" encoding="utf-8"?>

<!--

注意: 除了手動編輯此文件以外,您還可以使用

Web 管理工具來配置應用程序的設置。可以使用 Visual Studio 中的

「網站」->「Asp.Net 配置」選項。

設置和注釋的完整列表在

machine.config.comments 中,該文件通常位於

WindowsMicrosoft.NetFrameworkv2.xConfig 中

-->

<configuration>

<appSettings/>

<connectionStrings/>

<system.web>

<!--

設置 compilation debug="true" 將調試符號插入

已編譯的頁面中。但由於這會

影響性能,因此只在開發過程中將此值

設置為 true。

-->

<compilation debug="false" />

<!--

通過 <authentication> 節可以配置 ASP.NET 使用的

安全身份驗證模式,

以標識傳入的用戶。

-->

<authentication mode="Windows" />

<!--

如果在執行請求的過程中出現未處理的錯誤,

則通過 <customErrors> 節可以配置相應的處理步驟。具體說來,

開發人員通過該節可以配置

要顯示的 html 錯誤頁

以代替錯誤堆棧跟蹤。

<customErrors mode="RemoteOnly" defaultRedirect="GenericErrorPage.htm">

<error statusCode="403" redirect="NoAccess.htm" />

<error statusCode="404" redirect="FileNotFound.htm" />

</customErrors>

-->

</system.web>

</configuration>

遷移到Access

將webpart的資料庫遷移到sqlserver是一件非常方便的事,但是對於很多小型網站來說,access才是最佳選擇。但是要將資料庫遷移到Access卻是一件非常的複雜的事情, 而且網上也沒有查到這方面現成的中文資料,之前在微軟英文asp.net新聞組發了個貼子也沒人回答,有些英文資料也是語焉不詳,不成系統。

下面我來說一下詳細的過程。

首先你需要一個access的Provider以及相對應的資料庫。之前我曾經從網上找了一個access的provider,並嘗試把SQLServer版的表導出成Access,結果發現這條路是行不通的,因為不匹配。

目前在英文google里能找到兩個access的Provide

一個是AccessPersonalizationProvider,下載地址是

http://www.kowitz.net/files/AccessPersonalizationProvider.zip

命名空間為MarkItUp.SingleUserBlog.Web.WebParts.AccessProviders 雖然在源代碼注釋里也寫著copyright是微軟的,但是下載時沒有對應的資料庫。

另外一個是微軟官方網站上的以前Beta1時出的 SampleAccessProviders,解壓後自帶一個access資料庫,而且還有web.config的樣例。下載地址是

http://msdn.microsoft.com/vstudio/eula.aspx?id=96713a8e-b8d4-4d6e-bb8f-027e6c8e15d8

我用的是後者。

下載後,名字是SampleAccessProviders.vsi,解壓縮後可以在C:Documents and SettingsAdministratorMy DocumentsVisual Studio 2005TemplatesProjectTemplatesVisual Web DeveloperStarter KitsASP.NET Access Providers 找到。

你可以用vs.net2005打開Access.csproj編譯出dll,名字為SampleAccessProviders.dll,然後把ASPNetDB.mdb複製到App_Data目錄,然後在自己的網站中引用SampleAccessProviders.dll,並參考那個web.config修改自己的配置文件。

關於其他資料庫

由於SampleAccessProviders是開放源代碼的,所以參照著自己擴展Provider。目前網上可以找到XmlFilePersonalizationProvider。對於Oracle,mysql等資料庫可以自己寫擴展Provider,但是目前我們已有了access這種資料庫獨立的方式,所以可以通過混用來實現更為方便。

後記:來到衣索比亞當志願者已有近兩個月了,工作一點挑戰也沒有,又打戰了,在這種網路只有56K的鳥地方,真是一種痛苦。百無聊賴之際,想想以前在國內一直沒有時間空下來好好研究一下vs.net2005,(主要是更喜歡vs.net 2003的小巧),特寫此文,結果寫完了,一直上了不博客園,直到今天才打開,真是鬱悶呀。

推薦閱讀:

分庫分表基礎
通過MySQL驅動連接MySQL資料庫
Linux安裝MySQL資料庫操作手冊
SqlServer資料庫數據恢復報告
免費家譜資料庫及相關資料

TAG:資料庫 | 遷移 |