gpt4 book ai didi

C# SqlConnection 异常 : Keyword not Supported 'Port'

转载 作者:行者123 更新时间:2023-12-05 09:15:52 26 4
gpt4 key购买 nike

我看了很多同主题的帖子。但都没有帮助我。我想将 Postgresql 与 CrossPlatform-App 一起使用。稍后我将使用云中的服务器,但为了尝试,我认为使用本地数据库更容易。因此,我安装了数据库本身和带有“NuGet”的“npgsql”包,就像 Postgres 人员推荐的那样。在连接时总是出现相同的错误之后,我将代码缩减为一个只有十行代码的控制台应用程序。

namespace SqlTester_ConsolApp
{
class Program
{
static void Main(string[] args)
{
string MyConnection = "Server=127.0.0.1;Port=5432;Database=sample;UserId=Postgresql;Password=zzzzzzzzz;";

try
{
SqlConnection Connection = new SqlConnection(MyConnection);
}
catch (Exception ex)
{
System.Diagnostics.Debug.WriteLine("---------------------------------------------------------------------");
System.Diagnostics.Debug.WriteLine(ex.ToString());
}
System.Diagnostics.Debug.WriteLine("Ready");
}
}
}

new SqlConnection 总是以 System.ArgumentException 终止,告诉 Keyword not supported 'port'。原因很明显,.Net Framework 尝试使用 SQL Server 而不是将我的字符串传递给 npgsql 驱动程序。因此,从字符串中删除“端口”是没有意义的。

我的问题是如何将字符串解析更改为 Progresql 提供程序?主动地我没有为那个错误的选择做任何事情,这显然是 .Net Framework 的默认行为的一部分,它要么是错误或仅支持 MS 产品的意图。

我尝试了一些改变行为的方法。澄清更新:因为“NpgsqlConnection”的用法对我来说是 Not Acceptable 。我的代码应该独立于提供商。

正如我在 Postgresql-Docu 中找到的 npgsql 和另一个 question遇到同样的问题,我将以下行添加到 Console-App 的 App.Config 文件中。

<system.data>
<DbProviderFactories>
<add name="Npgsql Data Provider" invariant="Npgsql" description=".Net Data Provider for PostgreSQL" type="Npgsql.NpgsqlFactory, Npgsql, Culture=neutral, PublicKeyToken=5d8b90d52f46fda7"/>
</DbProviderFactories>
<defaultConnectionFactory type="Npgsql.NpgsqlFactory, Npgsql, Culture=neutral, PublicKeyToken=5d8b90d52f46fda7"></defaultConnectionFactory>
</system.data>

它没有帮助。另一件事是,如果它对 App.Config 有帮助,我该如何将其传输到我的跨平台应用程序。没有 App.Config。

我的问题是环境而不是编程本身。在从事其他工作多年后,我再次开始编程。所以所有的环境对我来说都是全新的。在那之前,Visual Studio 会自动处理任何事情。所以我不必了解很多细节。我试图找到一些有关 DbProviderFactories 的 .Net 内部结构和应用程序配置的信息。但是没有找到有用的信息,多半是不会搜索。所以任何帮助对我都有用。提前致谢。

最佳答案

SqlConnection 特定于 SQL Server。您将需要使用 NpgsqlConnection 来使用 Postgres 连接,这意味着您将需要对 Postgres 程序集的引用。

但您打算在未来转移到不同的提供者,因此为了尽量减少该转移的影响,请尝试在您的代码中使用通用基类。例如:

var connString = "Host=myserver;Username=mylogin;Password=mypass;Database=mydatabase";
using (DbConnection conn = new NpgsqlConnection(connString))
{
conn.Open()
using (DbCommand command = conn.CreateCommand())
{
// etc
}
}

这样,当您交换时,您需要做的就是用 SqlConnection 替换整个解决方案中的 NpgsqlConnection。如果你想使用 DbProviderFactory (那里有一个很好的例子)然后你就可以了,但基本上你只是在为自己保存这个单一的搜索/替换,删除引用,并发布一个新版本的代码。

我建议 putting the connection string in the config file而不是代码(如问题中所示)以避免在多个地方使用它,并使其更容易在不重建的情况下进行更改。

当然,您可能必须修复 SQL 本身中的任何特定于实现的细节。

关于C# SqlConnection 异常 : Keyword not Supported 'Port' ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51576264/

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