【问题标题】:How to form a correct MySQL connection string? [closed]如何形成正确的 MySQL 连接字符串? [关闭]
【发布时间】:2012-05-17 08:52:43
【问题描述】:

我正在使用 C#,我正在尝试连接到 00webhost 托管的 MySQL 数据库。

我在connection.Open()线上遇到错误:

没有具有此参数的 mysql 主机。

我已经检查过,一切似乎都很好。

string MyConString = "SERVER=mysql7.000webhost.com;" +
        "DATABASE=a455555_test;" +
        "UID=a455555_me;" +
        "PASSWORD=something;";
         MySqlConnection connection = new MySqlConnection(MyConString);
         MySqlCommand command = connection.CreateCommand();
         MySqlDataReader Reader;
         command.CommandText = "INSERT Test SET lat=" + 
             OSGconv.deciLat + ",long=" + OSGconv.deciLon;
         connection.Open();
         Reader = command.ExecuteReader();
         connection.Close();

这个连接字符串有什么问题?

【问题讨论】:

  • 网站名称或连接字符串是否有错字?
  • 在调试器中打印MyConString 是否正确?
  • 我认为你应该使用 command.executenonquery 而不是 reader = command.ExecuteReader();关于你的 sqlcommand ,我认为它应该是 'Insert Into Test(lat,long) Values ('"+OSGconv.deciLat+"','"+OSGconv.deciLon+"')'
  • @Hiren 你能给我一个如何写这个的例子吗?谢谢
  • @p.campbell 错误在于打开命令

标签: c# mysql database-connection


【解决方案1】:

尝试以这种方式创建连接字符串:

MySqlConnectionStringBuilder conn_string = new MySqlConnectionStringBuilder();
conn_string.Server = "mysql7.000webhost.com";
conn_string.UserID = "a455555_test";
conn_string.Password = "a455555_me";
conn_string.Database = "xxxxxxxx";

using (MySqlConnection conn = new MySqlConnection(conn_string.ToString()))
using (MySqlCommand cmd = conn.CreateCommand())
{    //watch out for this SQL injection vulnerability below
     cmd.CommandText = string.Format("INSERT Test (lat, long) VALUES ({0},{1})",
                                    OSGconv.deciLat, OSGconv.deciLon);
     conn.Open();
     cmd.ExecuteNonQuery();
}

【讨论】:

  • 我仍然收到:无法连接到任何指定的 MySQL 主机
【解决方案2】:
string MyConString = "Data Source='mysql7.000webhost.com';" +
"Port=3306;" +
"Database='a455555_test';" +
"UID='a455555_me';" +
"PWD='something';";

【讨论】:

    【解决方案3】:

    这是一个例子:

    MySqlConnection con = new MySqlConnection(
        "Server=ServerName;Database=DataBaseName;UID=username;Password=password");
    
    MySqlCommand cmd = new MySqlCommand(
        " INSERT Into Test (lat, long) VALUES ('"+OSGconv.deciLat+"','"+
        OSGconv.deciLon+"')", con);
    
    con.Open();
    cmd.ExecuteNonQuery();
    con.Close();
    

    【讨论】:

    • 至少对于 C#,它是 Server 而不是 ServerName
    猜你喜欢
    • 2023-03-23
    • 2017-03-27
    • 2018-02-14
    • 1970-01-01
    • 1970-01-01
    • 2018-06-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多