我目前正在为我在大学的第二个编程课上做最后的练习,并且在通过数据库搜索特定员工姓名时遇到问题,如果用户输入的用户名不在数据库中,程序崩溃给出错误,而不是显示我创建的错误消息。搜索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