2016-08-24 1 views
0

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(); 
     } 
    } 
} 
+0

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

+0

http://www.connectionstrings.com. Vous avez besoin de guillemets autour du chemin, et remettez les antislashs dedans; Windows les utilise. –

Répondre

0

Je pense que votre chaîne de connexion doit être comme ceci:

con = new SqlConnection("Data Source=(LocalDB)\\MSSQLLocalDB;AttachDbFilename=C:\\Users\\User\\Documents\\DATA_TEST.mdf;Integrated Security=True;Connect Timeout=30"); 

Et pour localdb, vous pouvez faire quelque chose comme ça aussi:

con = new SqlConnection("Data Source = .;Initial Catalog = DATA_TEST;Integrated Security = True")