Je suis en train d'essayer de créer et d'écrire dans le fichier de base de données.Chaîne de connexion à la base de données
Je ne sais pas pourquoi la chaîne de connexion est devenue telle:
Data Source=(LocalDB)\MSSQLLocalDB;AttachDbFilename=C:\Users\User\Documents\DATA_TEST.mdf;Integrated Security=True;Connect Timeout=30
Avec cette chaîne de connexion, je reçois cette erreur:
Error CS1009 Unrecognized escape sequence
XXX_DATABASE_TEST D:\FOLDER\XXX_DATABASE_TEST\Form1.cs
J'ai changé «/» à " \ ":
Data Source=(LocalDB)\MSSQLLocalDB;AttachDbFilename=C:/Users/User/Documents/DATA_TEST.mdf;Integrated Security=True;Connect Timeout=30
Erreur a disparu, la forme se charge, mais la base de données est vide, n'écrit pas. Pouvez-vous me aider à comprendre ce que je fais mal ici:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.Sql;
using System.Data.SqlClient;
namespace XXX_DATABASE_TEST
{
public partial class Form1 : Form
{
SqlCommand cmd;
SqlConnection con;
SqlDataAdapter da;
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
con = new SqlConnection("Data Source=(LocalDB)\MSSQLLocalDB;AttachDbFilename=C:\Users\User\Documents\DATA_TEST.mdf;Integrated Security=True;Connect Timeout=30");
con.Open();
cmd = new SqlCommand("INSERT INTO testdata VALUES (Name, IDo, Gender) VALUES (@Name,@IDo,@Gender)", con);
cmd.Parameters.Add("@Name", textBox1.Text);
cmd.Parameters.Add("@IDo", textBox1.Text);
cmd.Parameters.Add("@Gender", comboBox1.SelectedItem.ToString());
cmd.ExecuteNonQuery();
}
}
}
L'événement de clic du bouton est-il câblé? ExecuteNonQuery renvoie un entier pour le nombre d'enregistrements affectés. Vérifiez cette valeur. – LarsTech
http://www.connectionstrings.com. Vous avez besoin de guillemets autour du chemin, et remettez les antislashs dedans; Windows les utilise. –