Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Como crio uma consulta segura para realizar uma inserção em massa no MySQL usando MySQLCommand em C # sem usar um proc armazenado?

const string QUERY = "INSERT INTO contacts (first_name,last_name) VALUES" + 
                      BuildQuery(c, contacts);

public string BuildQuery(MySQLCommand c, IEnumerable<contact> contacts)
{
    List<string> values = new List<string>();
    string query = null;
    int i = 0;
    foreach (var contact in contacts)
    {
       i++;
       query += "(@firstName" + i + ", @lastName" + i + ")";
       c.Parameters.AddWithValue("@firstName" + i, contact.first_name);
       c.Parameters.AddWithValue("@lastName" + i, contact.last_name);

       if(i < contacts.Count) 
          query += ",";
    }

    return query
}

Você pode ver um tópico relevante aqui !. Devo ter perdido algo trivial, mas isso é trivial para você corrigir. Claro que você sabe o que acontece quando contacts não tem elementos. Não vejo mais casos de borda. Btw, lembre-se de que há um limite para quantos desses parâmetros você pode adicionar dependendo do tamanho máximo do pacote permitido do mysql. Você pode alterá-lo ou tomar cuidado para não exceder esse limite. Felicidades! :)