C# 操縱Access 常見的資料庫訪問 解決辦法

來源:互聯網
上載者:User

1、asp + Access 常見的資料庫訪問失敗問題 Microsoft JET Database Engine 錯誤 '80004005' 解決辦法
開啟 FileMonitor 這個監視軟體,因為預設情況下它跟蹤的資訊太多,造成查錯如同大海撈針。
這裡有個技巧就是先開啟監視,然後選擇你不需要監控的那些進程,或者一個目錄。
點菜單裡的: Edit -> Exclude Process 或 Edit -> Exclude Path 排除掉不需要監控的內容。
然後就會發現產生的資訊大大減少了。
清空輸出,重新開始監控,刷一下網頁,再停止監控。很快看到一個資訊:

115 15:59:40 DLLHOST.EXE:2804 CREATE C:\WINNT\TEMP\JET5EA6.tmp ACCESS DENIED CR\IUSR_CR 

可見是因為 C:\winnt\temp 目錄沒有對 CR\IUSER_CR 賬戶開放許可權,導致沒法建立臨時檔案(奇怪的是 CR\USER_CR 這個帳號訪問 Access 的時候需要產生臨時檔案)。

找到這個目錄,設定一下許可權。然後重新整理網頁就會發現好了。
當然具體情況下目錄名可能不一定就是這個,但是查錯方法就是這樣的了,一般都可以解決。

2、 用C#訪問ACCESS資料庫問題

最近這個項目中用到是ACCESS的資料庫,開始沒有使用密碼進行串連:

String connectionString = "Provider=Microsoft.Jet.OleDb.4.0;Data Source=";
connectionString += @"c:\data\db\db.mdb";
OleDbConnection con = new OleDbConnection(connectionString);
con.Open();

是沒有任何問題。

為了要使資料庫安全一點,不能被使用者直接開啟編輯,所以想到給Access資料庫設定個密碼:從菜單“工具”->"安全"->"設定資料庫密碼",這樣設定後就不能正常訪問這個資料庫了,在連接字串中加上User ID與Password欄位還是不行。最後在"工具"->"安全"->"使用者與組的賬戶"設定好密碼,直接不用更改連接字串就可以串連了。這樣處理後,使用者開啟時提示需要輸入密碼,也就達到了保護Access庫的目的。

轉:http://rchen.cnblogs.com/archive/2005/09/19/239785.html

3、  NTFS許可權問題
      磁碟分割為NTFS時,只能從access資料庫中讀取資料,添加修改和刪除都出現錯誤。需要設定access資料庫的存取權限,在檔案夾的屬性中的安全性裡添加asp.net帳戶,並為其添加寫入修改許可權。改過之後OK了

4、Access資料庫在asp.net程式中相對路徑的解決方案

好多朋友被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.