c#数据库写入表不工作

本文关键字:工作 数据库 | 更新日期: 2023-09-27 18:07:59

我在使用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;
        }
    }

c#数据库写入表不工作

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

整个 User InstanceAttachDbFileName= 方法是有缺陷的-充其量!当在Visual Studio中运行您的应用程序时,它将在.mdf文件周围复制(从您的App_Data目录到输出目录-通常是.'bin'debug -您的应用程序运行的地方)和最有可能,您的INSERT工作得很好-但您只是在看错误的。mdf文件结束!

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

在我看来,真正的解决方案
  1. 安装SQL Server Express(你已经这样做了)

  2. install SQL Server Management Studio Express

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

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

    Data Source=.''SQLEXPRESS;Database=MyDatabase;Integrated Security=True
    

    和其他的都是和以前完全一样的