Запрос не запускается из npgsql, но запускается на postgresql pgAdmin
У меня проблема с запуском простого запроса вставки из моего приложения на C# в базу данных Postrges.
Это функция, которая строит запрос:
string push = "INSERT INTO \"Tasks\"( \"TName\", \"Desc\", \"TType\", \"DCreated\", \"DEnd\") VALUES (\'" + this.Name + "\',\'" + this.Descr + "\'," + this.Type + ",\'" + this.StartDate + "\', \'" + this.EndDate + "\');";
GenericDbClass.ExecutePush(push);
И эта строка передается в БД:
INSERT INTO "Tasks"( "TName", "Desc", "TType", "DCreated", "DEnd") VALUES ('dddddd','dddddddddddd',3,'13.04.2015 17:00', '24.04.2015 16:42');
Если я копирую строку и запускаю ее внутри pgAdmin, она работает сразу же, но отсюда она ничего не делает - никаких исключений, никаких ошибок, ничего в журналах, как будто она просто не достигает сервера.
Кроме того, вот метод push:
public static void ExecutePush(string sql)
{
try
{
NpgsqlConnection conn = new NpgsqlConnection(GenericDbClass.GetDbConnString());
conn.Open();
NpgsqlDataAdapter da = new NpgsqlDataAdapter(sql, conn);
conn.Close();
}
catch (Exception msg)
{
MessageBox.Show(msg.ToString());
throw;
}
}
Изменить: это рабочее решение, которое я нашел
public static void ExecutePush(string sql)
{
try
{
NpgsqlConnection conn = new NpgsqlConnection(GenericDbClass.GetDbConnString());
conn.Open();
NpgsqlCommand nc = new NpgsqlCommand(sql, conn);
nc.ExecuteNonQuery();
conn.Close();
}
catch (Exception msg)
{
MessageBox.Show(msg.ToString());
throw;
}
}
1 ответ
Решение
NpgsqlDataAdapter da = new NpgsqlDataAdapter(sql, conn);
Означает "Пожалуйста, создайте адаптер данных, который использует INSERT
SQL принят как sql
делать выбор ". Это не имеет особого смысла, и тогда вы ничего не делаете с этим, в любом случае.
conn.CreateCommand(sql).ExecuteNonQuery();
Кажется, больше похоже на то, что вы хотите.