0

我在使用 Visual Studio 2010 时遇到问题。我正在使用基于服务的数据库 ( .mdf)。我在 Visual Studio 中手动创建了一个包含一些信息的表。我编写的代码可以从表中读取,但是当我插入新信息时,看起来数据已添加到其他数据库中。

我可以从正确的表中读取信息,但是当我向表中添加信息时,我在 Visual Studio 的服务器资源管理器中看不到更改。

我不知道为什么要使用不同的数据库!有人知道问题吗?

这是我的代码:

public class DataAccess
{
    private SqlConnection sqlConnection;
    private SqlCommand sqlCommand;
    private SqlDataAdapter dataAdapterAnimal;
    private DataSet dataset;
    private string connectionString = DBAccessLayer.Properties.Settings.Default.AnimalDBConnectionString;

    public DataSet LoadAnimalDataSet()
    {
        dataset = new DataSet();

        using (sqlConnection = new SqlConnection(connectionString))
        {
            sqlConnection.Open();
            dataAdapterAnimal = new SqlDataAdapter("SELECT * FROM AnimalTable", sqlConnection);
            dataAdapterAnimal.Fill(dataset, "AnimalTable");
            sqlConnection.Close();
            return dataset;
        }
    }

    public void AddAnimal(int animalID, string name, double age, string category, string gender, string extraAnimalInfo)
    {

        sqlConnection = new SqlConnection(connectionString);
        sqlCommand = new SqlCommand("INSERT INTO AnimalTable VALUES(@AnimalID, @Name, @Age, @Category, @Gender, @ExtraAnimalInfo)", sqlConnection);

        try
        {
            sqlConnection.Open();
            sqlCommand.Parameters.Add(new SqlParameter("@AnimalID", animalID));
            sqlCommand.Parameters.Add(new SqlParameter("@Name", name));
            sqlCommand.Parameters.Add(new SqlParameter("@Age", age));
            sqlCommand.Parameters.Add(new SqlParameter("@Category", category));
            sqlCommand.Parameters.Add(new SqlParameter("@Gender", gender));
            sqlCommand.Parameters.Add(new SqlParameter("@ExtraAnimalInfo", extraAnimalInfo));
            sqlCommand.ExecuteNonQuery();
            sqlConnection.Close();
        }
        catch (Exception ex)
        {
            throw;
        }
    }
4

1 回答 1

3

我还没有看到你的连接字符串 - 但从你的描述来看,这里可能是这个问题:

整体User InstanceAttachDbFileName=方法是有缺陷的 - 充其量!在 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
    

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

于 2013-04-07T16:08:23.310 回答