有关ExecuteScalar的错误,我无法弄清楚

Alt*_*tex 1 c# sql-server

我正在使用visual C#编写一个程序,我将数据拉入dataGridView.这一切都很好,但是如果我之后尝试提取更多数据(我希望将数据放入textBox中),则会出现错误.

这是我正在提取数据并将其放入dataGridView的部分:

SqlConnection connect;
DataSet ds1 = new DataSet();
SqlDataAdapter da;

connect = new SqlConnection();
connect.ConnectionString = "Data Source=THEPC-PC\\SQLExpress;Initial Catalog=DataBase;Integrated Security=True";

string sql = "SELECT * FROM table WHERE column = '" + comboBox.Text + "'";
da = new SqlDataAdapter(sql, connect);
da.Fill(ds1, "table");
the_data_dataGridView.AutoGenerateColumns = false;
the_data_dataGridView.DataSource = ds1.Tables["table"];
connect.Open();
connect.Close();
Run Code Online (Sandbox Code Playgroud)

下面的代码是我正在尝试在前一个查询之后进行的下一个查询.并且它在第3行显示此错误,其中显示"ExecuteScalar":

'string'不包含'ExecuteScalar'的定义,并且没有扩展方法'ExecuteScalar'可以找到接受类型'string'的第一个参数(你是否缺少using指令或汇编引用?)

SqlCommand sql2 = new SqlCommand("SELECT COUNT(column) FROM table WHERE column = '" + comboBox.Text + "'", connect);
connect.Open();
int the_result = System.Convert.ToInt32(sql.ExecuteScalar());
the_result_textBox.Text = the_result.ToString();
connect.Close();
Run Code Online (Sandbox Code Playgroud)

这两段代码在不同的表单中都可以正常工作.但显然不会一个接一个地工作.现在我确定我在这里做了一些非常愚蠢的事情但是无法弄明白.

Rya*_*ett 6

那是因为sql是一个类型字符串.您在第一个示例中声明它.

string sql = "SELECT * FROM table WHERE column = '" + comboBox.Text + "'"; 
Run Code Online (Sandbox Code Playgroud)

你想在sql2上调用ExecuteScalar我想.