为什么插入表中不起作用?

mod*_*irl 2 c# sql-server

我想知道为什么这段代码不起作用?

SqlCommand comand = new SqlCommand();
//string myConnectionString = "Data Source=.\SQLEXPRESS;Initial Catalog=try;Integrated Security=True;Pooling=False";
SqlConnection conn = new SqlConnection(@"server=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\mydatabase.mdf;Integrated Security=True;User Instance=True");
comand.Connection = conn;
conn.Open();

comand.CommandText = "INSERT INTO TableProduct (productID,productName) VALUES ('1','M')";

comand.ExecuteNonQuery();
conn.Close();
Run Code Online (Sandbox Code Playgroud)

mar*_*c_s 5

整个User Instance和AttachDbFileName =方法存在缺陷 - 充其量!在Visual Studio中运行应用程序时,它将复制.mdf文件(从您的App_Data目录到输出目录 - 通常是.\bin\debug应用程序运行的地方),而且很可能,您的INSERT工作正常 - 但您只是看错了. mdf文件到底了!

如果你想坚持这种方法,那么尝试在myConnection.Close()调用上设置一个断点- 然后.mdf用SQL Server Mgmt Studio Express 检查文件 - 我几乎可以肯定你的数据就在那里.

真正的解决办法在我看来,将

  1. 安装SQL Server Express(你已经完成了)

  2. 安装SQL Server Management Studio Express

  3. SSMS Express中创建数据库,给它一个逻辑名称(例如mydatabase)

  4. 使用其逻辑数据库名称(在服务器上创建时给定)连接到它- 并且不要乱用物理数据库文件和用户实例.在这种情况下,您的连接字符串将类似于:

    Data Source=.\\SQLEXPRESS;Database=mydatabase;Integrated Security=True
    
    Run Code Online (Sandbox Code Playgroud)

    其他一切都和以前完全一样......

  • 我想知道有多少关于SO的其他问题都得到了回答......再一个我无法想象的功能曾经被测试过. (2认同)