mon code
string query = @"INSERT INTO representative_dev.representative_users
(Username, Password, FullName,
HomePhone, PhoneToCall,
CompanyEmail, PersonalEmail,
IsManager)
VALUES (@Username, @Password, @FullName,
@HomePhone, @PhoneToCall,
@CompanyEmail, @PersonalEmail,
@IsManager);";
mycon.Open();
int cnt = mycon.Execute(query,
new
{
txtUsername,
txtPassword,
txtFullName,
txtHomePhone,
txtPhoneToCall,
txtCompanyEmail,
txtPersonalEmail,
cbxIsManager
});
mycon.Close();
cela me donne "erreur fatale rencontrée lors de l'exécution de la commande".
Quand j'effectue une autre requête d'insertion dans un autre cas, cela fonctionne très bien, le différent est qu'ici j'ai cbxIsManager comme un bool et dans le db est un tinyint (1) et dans l'autre cas tout est des chaînes
si j'ajoute "Autoriser les variables utilisateur = true;" alors je ne reçois pas l'exception mais dans la base de données toutes les valeurs sont nulles (vérifie qu'il obtient des valeurs)
en utilisant ASP.NET à ce projet, console à l'autre, FW4, mysql est 6.somthing (think 3) l'autre code
string query = @"INSERT INTO representative_dev.potencial_contact
(Name, Company_ID, Phone, Email, Department, Notes, SuperFriend, UpdateDate)
VALUES (@Name, @Company_ID, @Phone, @Email, @Department, @Notes, @SuperFriend, @UpdateDate);";
mycon.Open();
int cnt = mycon.Execute(query,
new
{
con.Name,
con.Company_ID,
con.Phone,
con.Email,
con.Department,
con.Notes,
con.SuperFriend,
con.UpdateDate
});
mycon.Close();
Toute aide serait appréciée
thx, ariel
EDIT: quand cela a-t-il fonctionné
string query = @"INSERT INTO representative_dev.representative_users
(Username, Password, FullName,
HomePhone, PhoneToCall,
CompanyEmail, PersonalEmail,
IsManager)
VALUES ('" + txtUsername + @"', '" + txtPassword + @"', '" + txtFullName + @"',
'" + txtHomePhone + @"', '" + txtPhoneToCall + @"',
'" + txtCompanyEmail + @"', '" + txtPersonalEmail + @"',
" + cbxIsManager + ");";
int cnt = mysql.ExecuteInsert(query);
toujours à la recherche d'aide car je voudrais utiliser le pimpant ....
Essayez de remplacer le @
s par :
s. Cela semblait fonctionner pour moi:
string query = @"INSERT INTO representative_dev.representative_users
(Username, Password, FullName, HomePhone, PhoneToCall, CompanyEmail,
PersonalEmail, IsManager) VALUES (:Username, :Password, :FullName,
:HomePhone, :PhoneToCall, :CompanyEmail, :PersonalEmail, :IsManager);";