- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
问题:Linux CentOS/Oracle 11g/InstantClient/PHP 5.3.3
错误:oci_connect():OCIEnvNlsCreate() 失败。您的系统有问题 - 请检查 ORACLE_HOME 和 LD_LIBRARY_PATH 是否已设置并指向正确的目录
phpinfo() 相关部分:
如您所见,环境变量已正确设置,我可以使用 getenv()
在页面上回应它们。我还检查了读取权限,我可以从网页上读取这些目录中的所有文件。客户端库文件在那里(我安装并重新安装了两次)完全安装。这些库是可读和可加载的。
ldd 没有显示任何错误。
这是来自 php 文件的调用:
$test = getenv('LD_LIBRARY_PATH')." ".getenv('ORACLE_HOME');
$this->dbconn = oci_connect("myuser","mypassword", "localhost/orcl") or die("<b>Connection Failed: $test </b>").oci_error();
我尝试了通过谷歌搜索找到的所有技巧,但没有任何效果。
感谢您的帮助。
最佳答案
OCIEnvNlsCreate() 失败了吗?欢迎来到 hell ...
我知道线程是旧的,但问题仍然存在。通常这个问题的答案会重定向到第三方站点,通常是 404s。
让我们从问题开始。错误本身非常普遍。它的文档总结为“lib crashed...dunno why”。有多种解决方案,包括但不限于配置、重新安装和祈祷“在此处插入随机神名”。
以下是最常见解决方案的简短列表:
<强>1。将变量放入您的 .php 文件中。
putenv("LD_LIBRARY_PATH=$newld");
where $newld is the link to your library.
<强>2。删除变量 LD_LIBRARY_PATH,如果存在(是的,它在 1. 中显示的方式),从您的 php 文件并将其放入您的 apache2.conf 或 httpd.conf 或/etc/environment 或您的发行版的任何文件/version 用于环境变量。可以找到一个简单的指南 here或互联网上的任何地方。为什么?
Do not set Oracle environment variables using putenv() in a PHP script because Oracle libraries may be loaded and initialized before your script runs. Variables set with putenv() may then cause conflicts, crashes, or unpredictable behavior. Some functions may work but others might give subtle errors. The variables should be set up before the web server is started.
如安装文档中所述。之后还要重新启动apache。它是基于发行版/版本的,但最有可能的命令是 service httpd restart
。
重新安装 oci8。需要多少次。不要强制它。强制只会让事情变得更糟。另外,尝试编译它(也就是使用 ./configure -'all the fancy commands you'll need to use'
然后 make install
下载包)。
确保您获得了正确的 LD_LIBRARY_PATH
。有趣的是,对吧?您可能没有注意到 oracle 在 N 个不同的位置 创建了文件夹 client/lib/
,其中包含或多或少相同的文件,它们之间唯一的区别是,是选择除其中一个以外的所有文件夹都会导致上述错误。完整性检查?
重新安装 php/apache。您可能有一些导致问题的旧安装。因此,使用 apt-get purge php*
或 yum remove php*
或任何对您的分发具有相同技巧的方法,将是一个好的开始。
编辑PHP 升级后问题再次出现,这次使用了不同的解决方案。
EDIT SYSCONFIG 编辑文件/etc/sysconfig/httpd.在末尾添加这两行:
导出 LD_LIBRARY_PATH=/path/to.lib导出 ORACLE_HOME=/path/to/home
放弃并阅读手册可以找到here .
如果这些都没有帮助,请随时浏览 wall of sorrow , 一个解决方案...
关于php - Oracle 11g PHP oci_connect 失败 OCIEnvNlsCreate(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16345515/
Oracle 即时客户端和 Oracle 客户端有什么区别?你能给我解释一下吗?谢谢 最佳答案 Oracle 客户端带有安装程序和许多可执行文件,例如 sqlplus,tnsping,它是完整而庞大的
我正在寻找一个Delphi组件来直接连接到ORACLE数据库服务器,而无需安装oracle客户端。 我知道Oracle Data Access (ODAC)来自DevArt 。还有其他组件具有此功能吗
如何编写 Oracle 存储过程,以表 (X) 作为输入参数,并在过程内部使用表 X 来与另一个表 Y 联接? 表 X 将包含数千条记录。 不希望将表名作为 varchar 传递,然后使用动态 SQL
如何编写 Oracle 存储过程,以表 (X) 作为输入参数,并在过程内部使用表 X 来与另一个表 Y 联接? 表 X 将包含数千条记录。 不希望将表名作为 varchar 传递,然后使用动态 SQL
我要过滤COMMENTS属性为空的记录 我试过了 SELECT TABLE_NAME, COMMENTS FROM (SELECT TABLE_NAME, COMMENTS FROM (sel
我要下载 Oracle Instant Client for Linux x86-64 (64-bit)现在有一段时间了。 现在我注意到该网站在过去几个月中一直遇到技术问题。 要从 Oracle 下载
有什么方法可以将我的 Delphi 应用程序 (FireDac) 直接连接到 Oracle 数据库? 目前可以连接,但需要安装Oracle Client 在 embarcadero 站点 ( http
我有一张表,其中日期列的数据格式如下:“7/25/2014 12:14:27 AM”。我需要通过放入 where 子句来获取此日期。有人可以建议我该怎么做吗? 最佳答案 日期(存储在表中)是 repr
如果两个事务试图同时修改同一行会发生什么?通常,一旦行被修改,另一个事务等待直到第一个事务执行提交或回滚。但是,如果他们恰好在同一时刻发送更新请求怎么办? 最佳答案 答案是否定的。两个事务不能同时修改
我想知道为什么我不能在 Oracle 模式中有两个同名的索引?它抛出一个错误,指出该名称已被使用。我的印象是,由于索引在一个特定的表上,这应该不会导致任何错误,除非我们对同一个表上的两个不同列使用相同
我需要构建一个查询来按成员和到期日期检索信息组,但我需要为每个成员提供一个序列号.. 例如: 如果成员“A”有 3 条记录要过期,“B”只有 1 条,“C”有 2 条,我需要这样的结果: Number
独立程序 create procedure proc1 ( begin end; ) 存储过程 create package pkg1 ( procedure proc2 begin end; ) 最
在 Oracle 9i 中声明 FK 时遇到问题。我在这里查看了许多关于 SO 和一些在线文档(例如 http://www.techonthenet.com/oracle/foreign_keys/f
我和我的同事维护的应用程序在后端有一个 Oracle 数据库。我们正在考虑偶尔以“受限”模式运行应用程序,其中一个数据库表空间设置为只读。我们可以轻松地将必要的表和索引移动到单独的表空间,这些表空间将
我想实现一个自定义的回归聚合函数,类似于现有的 REGR_SLOPE . 我要定义的函数需要获取两列作为参数,例如 select T.EMPLOYEE_ID, CUSTOM_REGR_SL
我已经尝试解决这个问题一段时间了,我认为是时候寻求帮助了。我正在构建一个架构配置脚本,我想添加一些脚本输出和错误处理。这个想法是脚本输出窗口只会向我显示关键消息而没有所有噪音。 Create Temp
在旧的 Oracle 服务器(我被告知是 8i)上使用 JDBC 时,我遇到了一个非常令人困惑和奇怪的问题。我在那里准备了一个表,其中包含大约 10 列、数字、varchars、一个 raw(255)
我有一张 table Customer_Chronics在 Oracle 11g 中。 该表具有三个关键列,如下所示: 分支代码 客户 ID 期 我已按 branch_code 列表按表分区,现在我进
是否有存储用户自定义异常的oracle表? 最佳答案 没有。 与其他变量一样,用户定义的异常在 PL/SQL block 中定义,并且具有 PL/SQL 变量将具有的任何范围。所以,例如 DECLAR
在 oracle 中使用序列并使用 Before insert trigger 自动递增列或使用标识列是否更好,因为它在 Oracle 12 c 中可用? 最佳答案 无论哪种方式,您都将使用序列。 1
我是一名优秀的程序员,十分优秀!