如何形成正确的 MySQL 连接字符串? [关闭]
Posted
技术标签:
【中文标题】如何形成正确的 MySQL 连接字符串? [关闭]【英文标题】:How to form a correct MySQL connection string? [closed] 【发布时间】: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 错误在于打开命令
【参考方案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以上是关于如何形成正确的 MySQL 连接字符串? [关闭]的主要内容,如果未能解决你的问题,请参考以下文章