我正在慢慢学习C#并对代码感到困惑。我这里有一个用于数据库连接设置的简化版本
public class DatabaseSettings
{
private static string connectionString = string.Empty;
public static string ConnectionString
{
get
{
return connectionString;
}
private set
{
connectionString = value;
}
}
public bool TestConnection()
{
bool _returnVal = false;
string _connectionString = String.Format("Data Source={0};Persist Security Info=False", databaseLocation);
using (SqlCeConnection connection = new SqlCeConnection(_connectionString))
{
try
{
connection.Open();
connectionString = _connectionString; // sets the value of the connection string here
_returnVal = true;
}
catch (SqlCeException e)
{
// other codes here
_returnVal = false;
}
finally
{
connection.Close();
}
}
return _returnVal;
}
// other methods here
}
现在我的Main Class
,我很困惑这里发生了什么。当我尝试这段代码时:
string _databaseLocation = "database path";
DatabaseSettings _dbaseSetting = new DatabaseSettings(_databaseLocation, true);
_dbaseSetting.TestConnection();
string newConnectionString = _dbaseSetting.ConnectionString;
// ^ i got an error here
// Member 'SQLCE_Sample.ClassList.DatabaseSettings.ConnectionString.get'
// cannot be accessed with an instance reference;
// qualify it with a type name instead
下面的这个没有错误,但问题是我得到一个空字符串:
string _databaseLocation = "database path";
DatabaseSettings _dbaseSetting = new DatabaseSettings(_databaseLocation, true);
string newConnectionString = DatabaseSettings.ConnectionString;
我真正想要的是我需要创建一个具有public method
的类,其中测试从应用程序到数据库的连接。在该方法内部包含设置连接字符串的值的语法。然后我还需要property
检索连接字符串的值而不实例化类(这就是我添加static
关键字的原因)。我怎么可能这样呢?
答案 0 :(得分:2)
您似乎想要(静态地)访问由您的类实例设置的属性的值。因此,您需要做的就是监听编译器错误 - 将属性作为静态引用而不是实例引用进行访问。变化:
string newConnectionString = _dbaseSetting.ConnectionString;
要:
string newConnectionString = DatabaseSettings.ConnectionString;
您当然需要确保在尝试以静态方式访问该属性之前在实例上调用TestConnection
;否则ConnectionString
将为空。
答案 1 :(得分:-2)
您的公共静态变量和静态属性具有相同的名称。重命名其中任何一个。