无法连接到本地数据库
本文关键字:数据库 连接 | 更新日期: 2023-09-27 18:26:22
我正在玩C#和本地数据库(An empty SQL Server Compact Edition database for local data
)
但我无法连接到数据库并获取数据。
这就是我尝试的:
// Properties.Settings.Default.DatabaseConnectionString = Data Source=|DataDirectory|'Database.sdf
// I guess Visual Studio put it there after I created my database...
using(SqlConnection sqlConnection = new SqlConnection(Properties.Settings.Default.DatabaseConnectionString)) {
using(SqlCommand sqlCommand = new SqlCommand("SELECT * FROM users WHERE id = @id", sqlConnection)) {
sqlCommand.CommandType = CommandType.StoredProcedure;
sqlCommand.Parameters.AddWithValue("@id", 1);
try {
sqlConnection.Open();
SqlDataReader reader = sqlCommand.ExecuteReader(CommandBehavior.SingleRow);
if(reader.Read()) {
System.Console.WriteLine(reader);
System.Console.WriteLine(reader["id"]);
System.Console.WriteLine(reader["name"]);
}
}
catch(Exception e) {
System.Console.WriteLine(e.GetBaseException());
}
finally {
sqlConnection.Close();
}
}
}
我的整个程序挂了一段时间,暂停后我得到了这样的消息:
建立与SQL Server的连接时,发生了与网络相关或特定于实例的错误。找不到或无法访问服务器。请验证实例名称是否正确,以及SQL Server是否已配置为允许远程连接。(提供程序:SQL网络接口,错误:26-定位指定的服务器/实例时出错)
我正在玩C#和一个本地数据库(本地数据)
您使用的是Sql Server Compact
文件,而不是Sql Server Local DB
要处理SqlServerCompact,需要使用System.Data.SqlServerCe
命名空间,而不是System.Data.SqlServer
。
更换SqlConnection
、SqlCommand
。。。
使用SqlceConnection
、SqlCeCommand
。。。
Sql Server Compact中不支持存储过程(如何在SqlCE中使用存储过程),因此sqlCeCommand.CommandType
不能是CommandType.StoredProcedure
。
您需要使用带有命令参数的commandType.Text。
using(SqlCeConnection sqlCeConnection = new SqlCeConnection(Properties.Settings.Default.DatabaseConnectionString)) {
using(SqlCeCommand sqlCeCommand = new SqlCeCommand("SELECT * FROM users WHERE id = @id", sqlCeConnection)) {
sqlCeCommand.CommandType = CommandType.Text;
sqlCeCommand.Parameters.AddWithValue("@id", 1);
try {
sqlCeConnection.Open();
SqlCeDataReader reader = sqlCeCommand.ExecuteReader(CommandBehavior.SingleRow);
if(reader.Read()) {
System.Console.WriteLine(reader);
System.Console.WriteLine(reader["id"]);
System.Console.WriteLine(reader["name"]);
}
}
catch(Exception e) {
System.Console.WriteLine(e.GetBaseException());
}
finally {
sqlCeConnection.Close();
}
}
}
您需要使用:
using System.Data.SqlServerCe;
然后
using (SqlCeConnection sqlConnection = new SqlCeConnection(Properties.Settings.Default.DatabaseConnectionString))
{
using (SqlCeCommand sqlCommand = new SqlCeCommand("SELECT * FROM users WHERE id = @id", sqlConnection))
{
sqlCommand.CommandType = CommandType.Text;
sqlCommand.Parameters.AddWithValue("@id", 1);
try
{
sqlConnection.Open();
SqlCeDataReader reader = sqlCommand.ExecuteReader(CommandBehavior.SingleRow);
if (reader.Read())
{
System.Console.WriteLine(reader);
System.Console.WriteLine(reader["id"]);
System.Console.WriteLine(reader["name"]);
}
}
catch (Exception e)
{
System.Console.WriteLine(e.GetBaseException());
}
finally
{
sqlConnection.Close();
}
}
}