不带参数运行INSERT INTO语句

时间:2014-04-23 15:13:29

标签: c# sql

我目前在按钮点击时有一个功能INSERT INTO语句,完全正常。由于此项目的其他要求,我有第二个INSERT INTO查询,但现在我需要它们两个相互协作。我如何同时使用两个INSERT查询并使它们只是一个INSERT INTO语句,因为另一种方法是复制行(由于添加了两个新列,这是预期的)。我在下面发布了以下查询:

从gridview到Informix数据库的当前INSERT INTO

private void btnInsert_Click(object sender, EventArgs e)
{
OdbcDataAdapter da2 = new OdbcDataAdapter();

for (int i = 0; i < dataGridView2.Rows.Count; i++)
{
String insertData = "INSERT INTO brev_efile_user_doc_stats (trans_nbr, sequence_id, received_on, description, register_action) VALUES (?,?,?,?,?)";

OdbcCommand cmd = new OdbcCommand(insertData, connection);
cmd.Parameters.AddWithValue("@trans_nbr", dataGridView2.Rows[i].Cells[0].Value);
cmd.Parameters.AddWithValue("@sequence_id", dataGridView2.Rows[i].Cells[1].Value);
cmd.Parameters.AddWithValue("@received_on", dataGridView2.Rows[i].Cells[2].Value);
cmd.Parameters.AddWithValue("@description", dataGridView2.Rows[i].Cells[3].Value);
cmd.Parameters.AddWithValue("@register_action", dataGridView2.Rows[i].Cells[4].Value);

  da2.InsertCommand = cmd;

  try
    {
    connection.Open();
    cmd.ExecuteNonQuery();
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }

            finally
            {
                connection.Close();
            }
        }
    }

第二个INSERT INTO用于显示来自XML的更正序列(并不总是正确的):

INSERT INTO brev_efile_user_doc_stats
SELECT trans_nbr,received_on,description,register_action,sequence_id, reviewed_event_code,     
ROW_NUMBER() OVER(PARTITION BY trans_nbr 
ORDER BY trans_nbr,sequence_id) AS corrected_seq_id
FROM brev_efile_user_doc_stats
WHERE trans_nbr IS NOT NULL 
ORDER BY trans_nbr,sequence_id

1 个答案:

答案 0 :(得分:1)

我相信您应该能够通过使用UNION ALL在一个语句中完成插入。只需确保第一个select与第二个select语句具有相同的列数(在本例中为参数)。我为@reviewed_event_code和@corrected_seq_id添加了其他参数。您需要以与在ODBCCommand对象上设置其他参数值相同的方式设置参数值。我希望这有帮助!

INSERT INTO brev_efile_user_doc_stats
SELECT @trans_nbr, @received_on, @description, @register_action, @sequence_id, @reviewed_event_code, @corrected_seq_id
UNION ALL
SELECT trans_nbr,received_on,description,register_action,sequence_id, reviewed_event_code,
ROW_NUMBER() OVER(PARTITION BY trans_nbr ORDER BY trans_nbr, received_on) AS corrected_seq_id
FROM brev_efile_user_doc_stats
WHERE trans_nbr IS NOT NULL 
ORDER BY trans_nbr,corrected_seq_id