C#数据库写入表不';行不通

C#数据库写入表不';行不通,c#,database,visual-studio-2010,C#,Database,Visual Studio 2010,我在使用Visual Studio 2010时遇到问题。我使用的是基于服务的数据库(.mdf)。 我在VisualStudio中手动创建了一个表,其中包含一些信息。我编写的代码可以从表中读取,但当我插入新信息时,数据似乎被添加到了其他数据库中 我可以从正确的表中读取信息,但是当我向表中添加信息时,在VisualStudio的服务器资源管理器中看不到更改 我不知道为什么要使用不同的数据库!有人知道这个问题吗 这是我的密码: public class DataAccess { private

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

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

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

这是我的密码:

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;
        }
    }

我还没有看到您的连接字符串-但从您的描述来看,这里可能存在以下问题:

整个
用户实例
AttachDbFileName=
方法是有缺陷的-最多!在Visual Studio中运行应用程序时,它将围绕
.mdf
文件进行复制(从
app\u Data
目录复制到输出目录-通常是
\bin\debug
-应用程序运行的地方)和最有可能是,您的
INSERT
工作正常-但您最后看到的是错误的.mdf文件

如果您想继续使用这种方法,请尝试在
myConnection.Close()
调用上放置一个断点,然后使用SQL Server Mgmt Studio Express检查
.mdf
文件,我几乎可以肯定您的数据在那里

我认为真正的解决办法是

  • 安装SQL Server Express(您已经完成了安装)

  • 安装SQL Server Management Studio Express

  • 在SSMS Express中创建数据库,并为其指定一个逻辑名称(例如,
    MyDatabase

  • 使用其逻辑数据库名称连接到它(在服务器上创建时提供),不要乱动物理数据库文件和用户实例。在这种情况下,您的连接字符串类似于:

    Data Source=.\\SQLEXPRESS;Database=MyDatabase;Integrated Security=True
    
    其他一切都和以前一样


  • 我还没有看到您的连接字符串-但从您的描述来看,这里可能存在以下问题:

    整个
    用户实例
    AttachDbFileName=
    方法是有缺陷的-最多!在Visual Studio中运行应用程序时,它将围绕
    .mdf
    文件进行复制(从
    app\u Data
    目录复制到输出目录-通常是
    \bin\debug
    -应用程序运行的地方)和最有可能是,您的
    INSERT
    工作正常-但您最后看到的是错误的.mdf文件

    如果您想继续使用这种方法,请尝试在
    myConnection.Close()
    调用上放置一个断点,然后使用SQL Server Mgmt Studio Express检查
    .mdf
    文件,我几乎可以肯定您的数据在那里

    我认为真正的解决办法是

  • 安装SQL Server Express(您已经完成了安装)

  • 安装SQL Server Management Studio Express

  • 在SSMS Express中创建数据库,并为其指定一个逻辑名称(例如,
    MyDatabase

  • 使用其逻辑数据库名称连接到它(在服务器上创建时提供),不要乱动物理数据库文件和用户实例。在这种情况下,您的连接字符串类似于:

    Data Source=.\\SQLEXPRESS;Database=MyDatabase;Integrated Security=True
    
    其他一切都和以前一样


  • 请给我们看一些你试过的代码。有什么例外吗?您确定该表中没有触发器吗?很可能是从两个不同的数据库读取。VS将在项目/解决方案中为您制作.mdf的副本。是这样吗?我只创建了一个数据库。但我的项目解决方案中也创建了一个数据库。你能给我们看看你的连接字符串吗?您是否在连接字符串中使用了
    AttachDbFileName=..
    方法?请向我们展示一些您尝试过的代码。是否有任何异常?您确定该表中没有触发器吗?很可能是从两个不同的数据库读取。VS将在项目/解决方案中为您制作.mdf的副本。是这样吗?我只创建了一个数据库。但我的项目解决方案中也创建了一个数据库。你能给我们看看你的连接字符串吗?您是否在连接字符串中使用
    AttachDbFileName=..
    方法??