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資料庫數據恢復報告
※免費家譜資料庫及相關資料