c# - ubuntu中vscode中的oracle连接
问题描述
无法加载共享库“oci”或其依赖项之一
您好,我正在用 C#、Ubuntu 16.04 和 vscode 开发一个访问 ORACLE 数据库的程序。有问题的程序部分如下:
Console.WriteLine("*******************************************");
Console.WriteLine("*PopulaFuncionário");
OracleConnection ora = new OracleConnection(connStr);
ora.Open();
Console.WriteLine("*Conectou na versão:" + ora.ServerVersion );
Console.WriteLine("*******************************************");
上面的 Open 返回以下错误。
Unable to load shared library 'oci' or one of its dependencies.
我的计算机上安装了 ORACLE 客户端和 OCI 库,但我不知道如何引用它们。请,如果有人有解决方案...谢谢。
Microsoft.AspNetCore.Diagnostics.DeveloperExceptionPageMiddleware[1]
An unhandled exception has occurred while executing the request.
System.DllNotFoundException: Unable to load shared library 'oci' or one of its dependencies. In order to help diagnose loading problems, consider setting the LD_DEBUG environment variable: liboci: cannot open shared object file: No such file or directory
at System.Data.OracleClient.Oci.OciCalls.OciNativeCalls.OCIEnvCreate(IntPtr& envhpp, OciEnvironmentMode mode, IntPtr ctxp, IntPtr malocfp, IntPtr ralocfp, IntPtr mfreep, Int32 xtramem_sz, IntPtr usrmempp)
at System.Data.OracleClient.Oci.OciEnvironmentHandle..ctor(OciEnvironmentMode mode)
at System.Data.OracleClient.Oci.OciGlue.CreateConnection(OracleConnectionInfo conInfo)
at System.Data.OracleClient.OracleConnectionPoolManager.CreateConnection(OracleConnectionInfo info)
at System.Data.OracleClient.OracleConnectionPool.GetConnection()
at System.Data.OracleClient.OracleConnection.Open()
at app1.Models.PopulaFuncionario..ctor() in /home/w0513263/Desenv/C#/app1/Models/PopulaFuncionario.cs:line 23
--- End of stack trace from previous location where exception was thrown ---
at Microsoft.Extensions.DependencyInjection.ServiceLookup.CallSiteRuntimeResolver.VisitCreateInstance(CreateInstanceCallSite createInstanceCallSite, ServiceProviderEngineScope scope)
at Microsoft.Extensions.DependencyInjection.ServiceLookup.CallSiteVisitor`2.VisitCallSite(IServiceCallSite callSite, TArgument argument)
at Microsoft.Extensions.DependencyInjection.ServiceLookup.CallSiteRuntimeResolver.VisitTransient(TransientCallSite transientCallSite, ServiceProviderEngineScope scope)
at Microsoft.Extensions.DependencyInjection.ServiceLookup.CallSiteVisitor`2.VisitCallSite(IServiceCallSite callSite, TArgument argument)
at Microsoft.Extensions.DependencyInjection.ServiceLookup.DynamicServiceProviderEngine.<>c__DisplayClass1_0.<RealizeService>b__0(ServiceProviderEngineScope scope)
at Microsoft.Extensions.DependencyInjection.ServiceLookup.ServiceProviderEngine.GetService(Type serviceType, ServiceProviderEngineScope serviceProviderEngineScope)
at Microsoft.Extensions.DependencyInjection.ServiceLookup.ServiceProviderEngineScope.GetService(Type serviceType)
at Microsoft.Extensions.DependencyInjection.ActivatorUtilities.GetService(IServiceProvider sp, Type type, Type requiredBy, Boolean isDefaultParameterRequired)
at lambda_method(Closure , IServiceProvider , Object[] )
at Microsoft.AspNetCore.Mvc.Controllers.ControllerActivatorProvider.<>c__DisplayClass4_0.<CreateActivator>b__0(ControllerContext controllerContext)
at Microsoft.AspNetCore.Mvc.Controllers.ControllerFactoryProvider.<>c__DisplayClass5_0.<CreateControllerFactory>g__CreateController|0(ControllerContext controllerContext)
at Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
at Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker.InvokeInnerFilterAsync()
at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeNextResourceFilter()
at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.Rethrow(ResourceExecutedContext context)
at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeFilterPipelineAsync()
at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeAsync()
at Microsoft.AspNetCore.Routing.EndpointMiddleware.Invoke(HttpContext httpContext)
at Microsoft.AspNetCore.Routing.EndpointRoutingMiddleware.Invoke(HttpContext httpContext)
at Microsoft.AspNetCore.StaticFiles.StaticFileMiddleware.Invoke(HttpContext context)
at Microsoft.AspNetCore.Diagnostics.DeveloperExceptionPageMiddleware.Invoke(HttpContext context)
解决方案
After much searching, I found the solution. Just add the packages:
- Oracle.ManagedDataAccess
and everything worked perfectly ...
推荐阅读
- typescript - 打字稿嵌套类型变量
- ios - nextTriggerDate() 不返回“预期”值,是否有另一种方法可以获得重复本地通知的下一个触发日期?
- node.js - 使用 Cloud Functions for Firebase 的无服务器通知
- javascript - 通过更改 Oracle Apex 中的复选框来正确提交
- javascript - 如何在字符串中获取 javascript 变量的值?
- node.js - Nodejs 中的并发
- python - Python - 大文件名重命名错误(Win 错误 3)
- javascript - JQuery width() 方法返回不正确的值
- sql - 在 MS Access 中,创建动态查询后,如何使用记录集中的相应值更新表单上的文本框?
- c - (libwebsocket) 如何在客户端连接上发送数据包