sql >> Databáze >  >> RDS >> Oracle

Volání nedefinované funkce oci_connect, php_oci8_12c.dll, windows 8.1, php5.6.6

Upravit: Hmm. Při pokusu o to ve Windows 8 se zdá, že generuje stejnou chybu, jakou jste zadali. Momentálně vyšetřuji...

Moje chyba (povolil jsem nesprávný extension_dir čára). Funguje ve Win8, jak je zdokumentováno níže.

Následující kroky by měly být vše, co potřebujete k tomu, aby OCI fungovalo s PHP (právě jsem to ověřil na čerstvě nainstalovaném virtuálním počítači Windows 2008 R2 Standard x64):

  • Stáhněte a rozbalte PHP (použil jsem C:\php z php-5.6.7-nts-Win32-VC11-x86.zip ).
  • Stáhněte a rozbalte InstantClient (použil jsem C:\instantclient_12_1 z instantclient-basic-nt-12.1.0.2.0.zip ).
  • Přidejte výše uvedené cesty k systémové cestě.
  • Zkopírujte c:\php\php.ini-production do c:\php\php.ini .
  • v php.ini :
    • povolen řádek extension_dir = "ext" .
    • povolen řádek extension=php_oci8_12c.dll .
  • Nainstalujte Microsoft Visual C++ 2010 Runtime (x86). To je potřeba pro rozšíření OCI8.
  • Nainstalujte Microsoft Visual C++ 2012 Runtime (x86). To je potřeba pro PHP.

V tomto okamžiku spusťte php --ri oci8 v příkazovém řádku mi zobrazí následující výstup:

C:\>php --ri oci8

oci8

OCI8 Support => enabled
OCI8 DTrace Support => disabled
OCI8 Version => 2.0.9
Revision => $Id: f5a3ee1083d1ffa6adb5143efda6eafa210b8414 $
Oracle Run-time Client Library Version => 12.1.0.2.0
Oracle Compile-time Instant Client Version => 12.1

Directive => Local Value => Master Value
oci8.max_persistent => -1 => -1
oci8.persistent_timeout => -1 => -1
oci8.ping_interval => 60 => 60
oci8.privileged_connect => Off => Off
oci8.statement_cache_size => 20 => 20
oci8.default_prefetch => 100 => 100
oci8.old_oci_close_semantics => Off => Off
oci8.connection_class => no value => no value
oci8.events => Off => Off

Statistics =>
Active Persistent Connections => 0
Active Connections => 0

A kontrola oci_connect funkce:

C:\>php -r "var_dump(function_exists('oci_connect'));"
bool(true)


  1. Jak LAST_DAY() funguje v MariaDB

  2. Nelze najít klientskou knihovnu PostgreSQL (libpq)

  3. Osvědčené postupy při škálování databází:Část druhá

  4. Vypočítejte časový rozdíl mezi dvěma řadami