-1

我只想遍历数据库中的结果。这就是我现在要做的所有事情!这是我尝试调试时遇到的错误:

建立与 SQL Server 的连接时发生与网络相关或特定于实例的错误。服务器未找到或无法访问。验证实例名称是否正确以及 SQL Server 是否配置为允许远程连接。(提供者:SQL 网络接口,错误:26 - 错误定位服务器/指定的实例)

它指向这一行:

// fill dataset into named table
myAdapter.Fill(myDataSet, "Sent");

这是我的整个代码:

    // get connection strings from app.config
    string conString = ConfigurationManager.ConnectionStrings["Database1ConnectionString"].ConnectionString;

    // connection object
    SqlConnection myConn = new SqlConnection(conString);

    // create adapter
    SqlDataAdapter myAdapter = new SqlDataAdapter("select * from `Sent`", myConn);

    // create command builder
    SqlCommandBuilder myCommandBuilder = new SqlCommandBuilder(myAdapter);

    // create dataset
    DataSet myDataSet = new DataSet();

    // fill dataset into named table
    myAdapter.Fill(myDataSet, "Sent");

    // query using linq
    IEnumerable<DataRow> results
        = from row in myDataSet.Tables["Sent"].AsEnumerable()
          select row;

    // enumerate through results
    foreach (DataRow row in results)
    {
        MessageBox.Show(row.ToString());
    }

我能做些什么来解决这个问题?另外,如果有人有更简单的方法在 C# 中使用数据库,我愿意接受你的想法,因为这对我来说很荒谬(在 C# 中操作数据库)。感谢您的帮助。

2012 年 6 月 29 日更新:

以下代码适用于我:

        // get connection strings from app.config
        string conString = ConfigurationManager.ConnectionStrings["Database1ConnectionString"].ConnectionString;

        // connection object
        SqlCeConnection myConn = new SqlCeConnection(conString);

        // create adapter
        SqlCeDataAdapter myAdapter = new SqlCeDataAdapter("select * from [Sent]", myConn);

        // create command builder
        SqlCeCommandBuilder myCommandBuilder = new SqlCeCommandBuilder(myAdapter);

        // create dataset
        DataSet myDataSet = new DataSet();

        // fill dataset into named table
        myAdapter.Fill(myDataSet, "Sent");

        // create new row
        DataRow newRow = myDataSet.Tables["Sent"].NewRow();

        // set field vals
        newRow["sendTo"] = sendTo;
        newRow["subject"] = subject;
        newRow["message"] = message;

        // add new row to table
        myDataSet.Tables["Sent"].Rows.Add(newRow);

        // update database
        myAdapter.UpdateCommand = myCommandBuilder.GetUpdateCommand();
        int updatedRows = myAdapter.Update(myDataSet, "Sent");
        //MessageBox.Show("There were "+updatedRows.ToString()+" updated rows");

        // close connection
        myConn.Close();
4

5 回答 5

1

首先:检查您的连接字符串错误是否直接告诉您“嘿,我无法连接到您的数据库”

第二:(select * from Sent 不带撇号)

于 2012-06-23T21:43:40.033 回答
1

您是否更改了安装 SQL Server 的机器中使用的密码?我之前遇到过这种情况,我所做的是将我的新密码反映到 SQL Server 配置中,然后重新启动服务。

还请确保在 SQL 配置设置中启用了 TCP/IP 设置。

于 2012-12-14T02:04:16.563 回答
0

当我们没有更改sql server配置管理器中的tcp/ip设置时会出现这种错误。所以我们需要启用tcp/ip属性来解决这个错误

于 2012-07-02T07:31:39.187 回答
0

可能在这里说明了显而易见的问题,但您是否检查过 SqlExpress 服务正在运行?

https://stackoverflow.com/a/4650231/1095373

于 2012-09-30T03:08:12.023 回答
0

我没有使用正确的代码(它与任何连接的东西没有任何关系)。这是我第一次尝试使用 PHP 以外的语言连接到数据库。现在,我可能会使用 LINQ 或 Lambda 表达式而不是这段代码。但这是我使用的有效的方法:

    // get connection strings from app.config
    string conString = ConfigurationManager.ConnectionStrings["Database1ConnectionString"].ConnectionString;

    // connection object
    SqlCeConnection myConn = new SqlCeConnection(conString);

    // create adapter
    SqlCeDataAdapter myAdapter = new SqlCeDataAdapter("select * from [Sent]", myConn);

    // create command builder
    SqlCeCommandBuilder myCommandBuilder = new SqlCeCommandBuilder(myAdapter);

    // create dataset
    DataSet myDataSet = new DataSet();

    // fill dataset into named table
    myAdapter.Fill(myDataSet, "Sent");

    // create new row
    DataRow newRow = myDataSet.Tables["Sent"].NewRow();

    // set field vals
    newRow["sendTo"] = sendTo;
    newRow["subject"] = subject;
    newRow["message"] = message;

    // add new row to table
    myDataSet.Tables["Sent"].Rows.Add(newRow);

    // update database
    myAdapter.UpdateCommand = myCommandBuilder.GetUpdateCommand();
    int updatedRows = myAdapter.Update(myDataSet, "Sent");
    //MessageBox.Show("There were "+updatedRows.ToString()+" updated rows");

    // close connection
    myConn.Close();
于 2012-09-30T11:42:42.393 回答