我目前正在爲我在大學的第二個編程課上做最後的練習,並且在通過數據庫搜索特定員工姓名時遇到問題,如果用戶輸入的用戶名不在數據庫中,程序崩潰給出錯誤,而不是顯示我創建的錯誤消息。搜索C#數據庫查詢錯誤信息?
方法:
public void searchNameDbMethod()
{
OleDbConnection Myconnection = null;
OleDbDataReader dbReader = null;
string selectionText = "";
bool errorFlag = true;
do
{
string searchName = "";
Console.Write("Search for Employee Name: ");
searchName = Console.ReadLine();
searchName = searchName.ToUpper();
Console.WriteLine("\n");
Myconnection = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0; Data Source= payrolldb.accdb");
Myconnection.Open();
selectionText = "SELECT * FROM Table1;";
OleDbCommand cmd = Myconnection.CreateCommand();
cmd.CommandText = selectionText;
dbReader = cmd.ExecuteReader();
if (dbReader.HasRows)
{
while (dbReader.Read())
{
// since the query produces one column, the GetValue(0)
//must be set
// with multiple column queries, you have to know which
//column holds
// the value that you are looking for
//field 0 = ID
dbName = dbReader.GetValue(1).ToString(); //1 is field 1 of the db
if (dbName == searchName)
{
dbName = dbReader.GetValue(1).ToString(); //1 is field 1 of the db
dbID = dbReader.GetValue(2).ToString(); //2 is field 2 of the db
dbHourlyWage = dbReader.GetValue(3).ToString();
dbDependents = dbReader.GetValue(4).ToString();
Console.Clear();
Console.ResetColor();
Console.ForegroundColor = ConsoleColor.Green;
Console.WriteLine("*******************************************************");
Console.WriteLine("**************** {0} *****************", date);
Console.WriteLine("*******************************************************");
Console.WriteLine("Employee Name: ", dbName);
Console.WriteLine("Employee ID: {0}", dbID);
Console.WriteLine("Hourly Wage: {0}", dbHourlyWage);
Console.WriteLine("Number of Dependents: {0}", dbDependents);
Console.WriteLine("*******************************************************");
Console.ResetColor();
Console.Write("\n\n");
errorFlag = false;
}//closes if
}// end of while
}// end of if
if (errorFlag == true)
{
Console.ResetColor();
Console.ForegroundColor = ConsoleColor.Red;
Console.WriteLine("Name is not in our database!");//shows the data accumulated from above
Console.ResetColor();
}//closes if
dbReader.Close();
Myconnection.Close();
}//close do
while (errorFlag == true);
}//closes searchNameDbMethod
請記住,我使用的Microsoft Access我的數據庫爲這個項目(不知道它的問題) 。
我該如何做到這一點,以便如果在數據庫中找不到名稱,它將顯示我創建的錯誤消息,而不是在鏈接的圖像中顯示錯誤(崩潰程序)?
請參閱此鏈接http://social.msdn.microsoft.com/Forums/en-US/1d5c04c7-157f-4955-a14b-41d912d50a64/how-to-fix-error-the-microsoftaceoledb120-provider-未在本地機器上註冊 –
您安裝了哪種版本的訪問? – Gonzix
@Gonzix Access 2010 – Meta