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是為了使用方便。
好了,這樣就可以隨便移植你的程式而不用關心資料庫的路徑了,一勞永逸啊^_^,適合我這樣的懶人!