[原創] Access資料庫在asp.net程式中相對路徑的解決方案

來源:互聯網
上載者:User
好多朋友被ACCESS資料庫在.net程式中相對路徑的問題困擾,搞得每次移動程式都要去修改web.config

中資料庫連接字串的資料庫路徑。

好多人的web.config中的寫法如下:

 

<appSettings>
<add key="OLEDBCONNECTIONSTRING" value="Provider=Microsoft.Jet.OLEDB.4.0;Data

Source=E:\web\App_Data\Data.mdb)"></add>
</appSettings>

程式中這樣寫:

 

MyConn = new OleDbConnection(System.Configuration.ConfigurationManager.AppSettings["OLEDBCONNECTIONSTRING"]);//注釋一下:VS2005和VS2003中的ConfigurationSettings寫法不一樣,具體區別自己查吧

這樣程式運行時經常提示諸如以下的錯誤:
'C:\WINDOWS\system32\~\App_Data\Data.mdb'不是一個有效路徑。 確定路徑名稱拼字是否正確,以及是否串連到檔案存放的伺服器。 Data Source=~\App_Data\Data.mdb
就算用絕對路徑正確,那麼移植程式時還要去修改web.config,所以比較麻煩。

也有在web.config中使用象ASP那樣的Server.MapPath取資料庫路徑的,但web.config不認識Server.MapPath,此方法也行不通。

後來通過摸索、參考其它程式,總結出如下方法,可以方便的移植程式路徑而不必再去修改ACCESS資料庫路徑。

我在web.config中的寫法如下:

<appSettings>
<add key="SQLConnString" value="provider=microsoft.jet.oledb.4.0;data source="/>
<add key="dbPath" value="~/App_Data/mydata.mdb"/>
</appSettings>

程式中的資料訪問類中我把"SQLConnString"和"dbPath"取出來串連成一個字串"CONN_STRING_NON_DTC"

public static readonly string CONN_STRING_NON_DTC = System.Configuration.ConfigurationManager.AppSettings["SQLConnString"].ToString() + System.Web.HttpContext.Current.Server.MapPath(ConfigurationManager.AppSettings["dbPath"]) + ";";
這是VS2005中的寫法

我把CONN_STRING_NON_DTC定義成static readonly是為了使用方便。
好了,這樣就可以隨便移植你的程式而不用關心資料庫的路徑了,一勞永逸啊^_^,適合我這樣的懶人!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.