C# для подключения к базе данных Progress
Я пытаюсь разработать программу, которая будет подключаться к базе данных Progress (9.1E) с использованием C# (Visual Studio 2010 Ultimate), но сначала мне нужно получить строку подключения к базе данных Progress из программы C#.
Я попробовал следующее, но мне не удалось установить соединение с базой данных Progress. Я не уверен, как должна выглядеть строка подключения, но вот что я имею, прежде чем начать все расширять. Кроме того, я не уверен, каким должно быть имя DSN.
private void downloadData_Click(object sender, RoutedEventArgs e)
{
try
{
string connectString = "DSN = QADDB; Host = ipaddress; DB = dbname; UID = user; PWD = password;";
IDbConnection dbConn = new OdbcConnection(connectString);
dbConn.Open();
IDbCommand dbCommand = dbConn.CreateCommand();
string sqlstr = "SELECT pt_part FROM pt_mstr";
dbCommand.CommandText = sqlstr;
IDataReader reader = dbCommand.ExecuteReader();
while (reader.Read())
{
string part = (string)reader["pt_part"];
gridview.Items.Add(part);
}
reader.Close();
reader = null;
dbCommand.Dispose();
dbCommand = null;
dbConn.Close();
dbConn = null;
}
catch (Exception ex)
{
MessageBox.Show(ex.ToString());
}
}
Сообщение об ошибке говорит:
System.Data.Odbc.OdbcException (0X80131937): ОШИБКА [IM002] [Microsoft][Диспетчер драйверов ODBC] Не найдено имя источника данных и не указан драйвер по умолчанию
2 ответа
string connectString = "DSN=QADDB;uid=username;pwd=password;host=hostname;port=port#;db=dbname;";
using (OdbcConnection dbConn = new OdbcConnection(connectString));
{
try
{
dbConn.Open();
} catch (Exception)
{
mRtnVar = "Couldn't Connect";
return mRtnVar
}
string sqlstr = string.Format(@"SELECT ""FieldName"" FROM PUB.DataBase WHERE ""FieldName"" = 'value'");
using (OdbcCommand comm = new OdbcCommand(sqlstr, dbConn))
{
using (OdbcDataReader reader = dbConn.ExecuteReader())
{
if (reader.Read())
{
mRtnVar = reader["FieldName"].ToString();
}
}
}
return mRtnVar
}
В строке подключения установите порт вашей базы данных Progress:
ПОРТ =20931;