gpt4 book ai didi

c# - 根据连接字符串判断是否存在 SQL Server CE 4.0 数据库文件

转载 作者:行者123 更新时间:2023-11-30 18:41:31 25 4
gpt4 key购买 nike

给定以下连接字符串(对于 SQL Server CE 4.0)

Data Source=|DataDirectory|IntegrationTests.sdf

如何判断文件是否存在?

(我知道我可以在对 File.Exists() 的调用中对路径进行硬编码,但我不想这样做。如果我决定更改连接字符串怎么办?)

最佳答案

也许使用 SqlConnectionStringBuilder将您的连接字符串解析为其组成部分的类:

class Program
{
static void Main()
{
// Create a new SqlConnectionStringBuilder and
// initialize it with a few name/value pairs.
SqlConnectionStringBuilder builder =
new SqlConnectionStringBuilder(GetConnectionString());

// The input connection string used the
// Server key, but the new connection string uses
// the well-known Data Source key instead.
Console.WriteLine(builder.ConnectionString);

// Pass the SqlConnectionStringBuilder an existing
// connection string, and you can retrieve and
// modify any of the elements.
builder.ConnectionString = "server=(local);user id=ab;" +
"password= a!Pass113;initial catalog=AdventureWorks";

// Now that the connection string has been parsed,
// you can work with individual items.
Console.WriteLine(builder.Password);
builder.Password = "new@1Password";
builder.AsynchronousProcessing = true;

// You can refer to connection keys using strings,
// as well. When you use this technique (the default
// Item property in Visual Basic, or the indexer in C#),
// you can specify any synonym for the connection string key
// name.
builder["Server"] = ".";
builder["Connect Timeout"] = 1000;
builder["Trusted_Connection"] = true;
Console.WriteLine(builder.ConnectionString);

Console.WriteLine("Press Enter to finish.");
Console.ReadLine();
}

private static string GetConnectionString()
{
// To avoid storing the connection string in your code,
// you can retrieve it from a configuration file.
return "Server=(local);Integrated Security=SSPI;" +
"Initial Catalog=AdventureWorks";
}
}

在这种情况下,您可以使用 DataSource 属性:

SqlConnectionStringBuilder builder = new SqlConnectionStringBuilder("Data Source=|DataDirectory|IntegrationTests.sdf");
Console.WriteLine(builder.DataSource);

关于c# - 根据连接字符串判断是否存在 SQL Server CE 4.0 数据库文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6704618/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com