我目前在按钮点击时有一个功能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
答案 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