Запрос не запускается из 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();

Кажется, больше похоже на то, что вы хотите.

Другие вопросы по тегам