- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我看了很多同主题的帖子。但都没有帮助我。我想将 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/
我收到多行错误,指出它有重复的类 Duplicate class android.support.v4.accessibilityservice.AccessibilityServiceInfoCom
我的项目昨天运行良好,今天却出现以下错误。请帮忙。 出了什么问题:无法解析配置“:app:debugCompileClasspath”的所有文件。 Could not find support-v4.
错误:配置项目“:app”时出现问题。 Could not find support-v4.jar (com.android.support:support-v4:24.0.0). Searched
我正在使用 react-native-webrtc 运行示例应用程序模块。我正在尝试在 android 中运行该应用程序,但出现这样的错误... * What went wrong: A probl
错误:配置项目“:app”时出现问题。 Could not find support-v4.jar (com.android.support:support-v4:24.0.0). Searched
我克隆了我的项目并使用 Android studio 打开,但构建失败并出现以下错误并且同一个项目在其他项目上运行良好。 出了什么问题:无法解析配置“:app:flavorUnsignedReleas
我正在运行示例应用程序......我正在使用 this模块.....但是我收到这样的错误... FAILURE: Build failed with an exception. * What went
我有一个 Ionic 项目,在升级到 OSx Mojave 后,出于某种原因不再构建。 该项目基于 Ionic 3 构建。 我有 Cordova CLI 7.0.0 当我运行时 ionic cordo
我有一个 Ionic 项目,在升级到 OSx Mojave 后,出于某种原因不再构建。 该项目基于 Ionic 3 构建。 我有 Cordova CLI 7.0.0 当我运行时 ionic cordo
添加 Android 平台(ionic cordova platform add android)后,我构建了我的 Ionic 项目(ionic cordova build android),但出现错
这个问题在这里已经有了答案: Manifest merger failed : Attribute application@appComponentFactory - Androidx (14 个答
关于我的 Gradle 文件中的以下“complie”: dependencies { compile 'com.android.support:support-v4:25.3.1' }
有些困惑。 我想更频繁地使用@supports 但是...我不关心浏览器如何看待它。希望您能说清楚,如果可以的话谢谢您。 如果浏览器本身不理解@supports,它如何计算@support 'not'
我刚刚升级到 Dart 2 和最新版本的 Flutter,现在我无法构建我的应用程序。我在互联网上环顾四周,但仍然不明白为什么会发生这种情况。 我得到的错误是: FAILURE: Build fail
我正在学习 Firebase,但由于以下错误而陷入困境: Error:Failed to resolve: com.android.support:customtabs:25.4.0 Error:Fa
我在构建本周时出于某种原因尝试使用Cordova进行项目时遇到问题: cordova build android gradle获取com.android.support:support alpha而不
对应的androidx是什么com.android.support:support-compat 的图书馆实现push notifications ? 他们说here它是 androidx 的一部分,
我正在尝试为我的应用设置插桩单元测试。并且我已根据以下开发者站点链接添加了依赖项。 https://developer.android.com/training/testing/unit-testin
当我想使用 Proguard 规则生成签名的 APK(发布)时,我收到了以下错误消息: Cannot find a version of 'com.android.support:support-an
这个问题在这里已经有了答案: Failed to resolve: com.android.support:appcompat-v7:26.0.0 (14 个答案) Failed to resolv
我是一名优秀的程序员,十分优秀!