Pues después de haberme creado mi clase BD donde manejo toda la base de datos mysql, me dispongo a probarla. Y para ello utilizo el método registrar de la clase usuarios.
Código C++:
Ver original
public static Usuario registrar(string login, string password, string nombre, DateTime cumpreanos) { MySqlCommand sql = new MySqlCommand("insert into gp_usuarios (login, password, nombre) values (@login,@password,@nombre)"); sql.Parameters.Add(new MySqlParameter("login", System.Data.SqlDbType.VarChar)); sql.Parameters.Add(new MySqlParameter("password", System.Data.SqlDbType.VarChar)); sql.Parameters.Add(new MySqlParameter("nombre", System.Data.SqlDbType.VarChar)); //sql.Parameters.Add(new MySqlParameter("cumpreanos", System.Data.SqlDbType.VarChar)); sql.Parameters["login"].Value = login; sql.Parameters["password"].Value = password; sql.Parameters["nombre"].Value = nombre; //sql.Parameters["cumpreanos"].Value = cumpreanos; MySqlConnection conexion = BD.Conexion(); MySqlTransaction t = conexion.BeginTransaction(); if (!(BD.ejecuta(sql, t) == 1)) { t.Rollback(); return null; } Usuario u = new Usuario(); u.login = login; u.password = password; u.nombre = nombre; u.cumpreanos = cumpreanos; t.Commit(); return u; }
Pues parece ser que los MySqlCommand.Parameters no funcionan...es decir, no insertan el valor que se les pasa. Y porqué digo esto?
Porque he probado a sustituir los @ directamente por el valor que quería y comentado la parte de los parameters y me ha insertado la línea perfectamente.
Además, en el control de excepciones que he puesto en en la clase BD, me arroja una que me dice que el campo Login no puede ser NULL...
Alguien tiene idea de como solucionar esto o porqué pasa esto?
Estoy desesperado ya con el MySQL la verdad...
Esta misma clase la importé directamente de una que ya tenía hecha en SQL Server y funcionaba perfectamente...
Gracias por la ayuda y un Saludo!
Muchísimas gracias!