我目前有一个小应用程序向服务器发送了很多不同的MySQL查询。我的想法是将连接,查询和读取仅包含实际查询作为参数。关闭MySQL连接功能
这里是我的了:
public static MySqlDataReader mySqlRead(string cmdText)
{
string connString = "server=" + ORVars.sqlServerAddr + ";port=" + ORVars.sqlServerPort + ";uid=" + ORVars.sqlServerUID + ";pwd=" + ORVars.sqlServerPass + ";database=" + ORVars.sqlServerDB + ";";
MySqlConnection conn = new MySqlConnection(connString);
MySqlCommand command = conn.CreateCommand();
command.CommandText = cmdText;
try
{
conn.Open();
MySqlDataReader reader = command.ExecuteReader();
return reader;
}
catch (MySqlException)
{
throw;
}
}
我连接,并在此发送查询:
private void btnLogin_Click(object sender, EventArgs e)
{
string username = txtLogin.Text;
string password = ORFunc.GetMD5Hash(txtPassword.Text);
MySqlDataReader orRead = ORFunc.mySqlRead("SELECT * FROM orUsers WHERE username = '" + username + "' AND pass = '" + password + "'");
while (orRead.Read())
{
MessageBox.Show(orRead["id"].ToString());
}
}
作品就像一个魅力......但是,你可以在上面看到,连接从未关闭。当我在.ExecuteReader()后面添加conn.Close()时,读者是空的,返回后的所有内容当然是无用的。
也许这是一个愚蠢的问题,但我相当新的C#所以请慷慨,任何暗示赞赏。
欢呼声,
PRIMUS
伟大的,理解和使用...还要感谢罗素! – PrimuS