Вставка нескольких строк с помощью DB2Command.ExecuteNonQuery - PullRequest
3 голосов
/ 17 апреля 2009

Я пытаюсь вставить несколько строк в базу данных DB2, используя код C #, например:

string query = 
"INSERT INTO TESTDB2.RG_Table (V,E,L,N,Q,B,S,P) values" +
"('abc', 'def', '2009-03-27 12:01:19', 'ghi', 'jkl', NULL, NULL, NULL)," +
"('abc', 'def', '2009-03-27 12:01:19', 'ghi', 'jkl', NULL, NULL, NULL)";

DB2Command cmd = new DB2Command(query, this.connection, this.transaction);

cmd.ExecuteNonQuery();

Если я перестану строить строку запроса после первого набора значений, она будет выполнена без ошибок. Попытка загрузить несколько значений с помощью этого метода приводит к следующей ошибке:

Upload error : ERROR [42601] [IBM][DB2] SQL0104N  
An unexpected token "," was found following "".  
Expected tokens may include:  "<END-OF-STATEMENT>".  SQLSTATE=42601

Синтаксис SQL совпадает с тем, который я прочитал в другом месте , и документация IBM приводит этот пример:

cmd = conn.CreateCommand();
cmd.Transaction = trans;

cmd.CommandText =
"INSERT INTO company_a VALUES(5275, 'Sanders', 20, 'Mgr', 15, 18357.50), " +
"(5265, 'Pernal', 20, 'Sales', NULL, 18171.25), " +
"(5791, 'O''Brien', 38, 'Sales', 9, 18006.00)";

cmd.ExecuteNonQuery();

Может кто-нибудь объяснить, что может объяснить это?

Ответы [ 4 ]

1 голос
/ 13 января 2016

Я понимаю, что это действительно старый вопрос, но до сих пор ни один из ответов не дошел до истинного корня проблемы. Поскольку он не может использовать несколько предложений VALUES, я предполагаю, что он работает в z / OS, которая этого не поддерживает. См. мой другой ответ здесь для получения дополнительной информации.

Однако существует альтернатива, поскольку он, по-видимому, использует .NET, что является способностью "100" * цепочки драйвера. Это позволяет группировать несколько вставок / обновлений / удалений, и когда вы «заканчиваете» цепочку, драйвер отправляет все операторы одновременно. Вот пример кода:

<!-- language: lang-cs --> //Code parser seems to be going crazy here...
public void InsertToDatabase(IEnumerable<Row> rows)
{
    using (var conn = new DB2Connection())
    using (var trans = conn.BeginTransaction())
    using (var cmd = conn.CreateCommand())
    {
        cmd.Transaction = trans;
        cmd.CommandText =
            "INSERT INTO company_a VALUES " +
            "(@field1,@field2,@field3,@field4,@field5,@field6)";

        conn.BeginChain();
        foreach (var row in rows)
        {
            cmd.Parameters.Clear();
            cmd.Parameters.Add("@field1", row.Field1);
            cmd.Parameters.Add("@field2", row.Field2);
            cmd.Parameters.Add("@field3", row.Field3);
            cmd.Parameters.Add("@field4", row.Field4);
            cmd.Parameters.Add("@field5", row.Field5);
            cmd.Parameters.Add("@field6", row.Field6);
            cmd.ExecuteNonQuery();
        }
        conn.EndChain();
        trans.Commit();
    }
}

Если DB2 выдает какие-либо исключения, вы получите их только при запуске EndChain, и все они появятся сразу.

0 голосов
/ 20 июля 2009

ваш синтаксис выглядит в целом правильно.

  • это работает с Кли?
  • Вы смотрели на пакетное обновление JDBC. Я думаю, что вы найдете это почти так же быстро, и гораздо более читабельным и поддерживаемым.
0 голосов
/ 07 декабря 2009

Я почти уверен, что вставка строк с множеством не работает, если вы укажете список строк; в этом случае

(V,E,L,N,Q,B,S,P)

Чтобы вставить несколько строк, вы должны указать значения в собственном порядке столбцов таблицы.

Попробуйте изменить свой SQL на:

string query = "INSERT INTO TESTDB2.RG_Table values" +   
"('abc', 'def', '2009-03-27 12:01:19', 'ghi', 'jkl', NULL, NULL, NULL)," +
"('abc', 'def', '2009-03-27 12:01:19', 'ghi', 'jkl', NULL, NULL, NULL)"; 
0 голосов
/ 20 апреля 2009

Вы пробовали вставить через командную строку? Синтаксис кажется правильным по этой ссылке .

...