Table of Contents
WAMP environment configured by myself, extended oracle function library (oci), wampoci
Home Backend Development PHP Tutorial Configure your own WAMP environment, extend the oracle function library (oci), wampoci_PHP tutorial

Configure your own WAMP environment, extend the oracle function library (oci), wampoci_PHP tutorial

Jul 13, 2016 am 09:48 AM

WAMP environment configured by myself, extended oracle function library (oci), wampoci

A colleague received a task yesterday to use php to process the content of the oracle database, but php opened oracle The extension cannot be used directly like mysql. It requires something to open

The first step is to download an install client package from Oracle official, and find your zip corresponding to the system version under win (note here is the system version)

As of 2015-06-25, the download address is as follows http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html

For example, choose Instant Client for Microsoft Windows (x64). Because PHP extends OCI, you must choose the most complete corresponding version. Others do not have OCI. You may need an account to download here. You can download after verification. , it is not easy to download directly through the link. If not, just register it

In the second part, you need to download the expansion package in the win system, which is the .dll file. Download address http://pecl.php.net/package/oci8 The following nonsense will tell you how to find it

http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html Click on this address

official Instant Client site. Scroll to the end and click "PHP - OCI8 extension" in Related Developer Centers

Then tab downloads Click OCI8 to http://pecl.php.net/package/oci8

Then I won’t say much about how to download it

Go here to download the two zip packages, and then configure PHP

Third, decompress the first downloaded file to any directory on your computer. After decompression, you will get the file directory instantclient_12 _1. It is recommended to remove the "_12_1" at the end, so that you don't need to change the environment variables when changing the version in the future

Enter this directory and double-click to open adrci.exe

Get the following command line window to prove that this client is available locally

Copy the directory, mine is F:devinstantclient and configure it to the system’s path environment variable,

Fourth, unzip the downloaded dll compressed package and copy the php_oci8.dll php_oci8_11g.dll php_oci8_12c.dll. I currently have these three, to the php expansion package file, usually.../php /ext/ directory

In fact, you don’t need to replace it, but it is recommended to replace it,

Then open php.ini and open the extension. The last one was added later. PHP does not have it originally. Anyway, all the dll files in the package above have been written in. At most, a few more libraries can be loaded when running PHP.

extension=php_pdo_oci.dll

extension=php_oci8.dll ; Use with Oracle 10gR2 Instant Client
extension=php_oci8_11g.dll ; Use with Oracle 11gR2 Instant Client
extension=php_oci8_12c.dll ; Use with Oracle 12c Instant Client

Then restart the httpd service and open phpinfo(); you should be able to see

PDO support enabled
PDO drivers mysql, oci, odbc

OCI8 Support enabled
OCI8 DTrace Support disabled
OCI8 Version 2.0.8
Revision $Id: f04114d4d67cffea4cdc2ed3b7f0229c2caa5016 $
Oracle Run-time Client Library Version 12.1.0.2.0
Oracle Compile-time Instant Client Version 10.2

This means that the extension is opened successfully

The last step is to connect to the oracle database

Here is an example link. Original link http://www.orczhou.com/index.php/2010/09/php-oci8-oracle/

<span> 1</span> <?<span>php  
</span><span> 2</span> <span>//</span><span>配置信息</span>
<span> 3</span> <span>$ora_host</span> = "172.16.1.150"<span>;
</span><span> 4</span> <span>$ora_port</span>="1521"<span>;
</span><span> 5</span> <span>$ora_sid</span> = "cop"<span>;
</span><span> 6</span> <span>$ora_username</span> = "webdev"<span>;
</span><span> 7</span> <span>$ora_password</span> = "webdev"<span>;
</span><span> 8</span> <span>$charset</span> = "UTF8"; <span>#</span><span>## zhs16gbk ###
</span><span> 9</span> 
<span>10</span> <span>//构建Easy Connect string
</span><span>11</span> <span>//(如果tnsnames.ora中已经有了,可以直接使用Connect Name)</span>
<span>12</span> <span>$ora_connstr</span> = "<span>(description=(address=(protocol=tcp)
</span><span>13</span> (host=".<span>$ora_host</span>.")(port=".<span>$ora_port</span>."<span>))
</span><span>14</span> (connect_data=(service_name=".<span>$ora_sid</span>.")))"<span>;
</span><span>15</span> <span>//</span><span>连接数据库</span>
<span>16</span> <span>$conn</span> = oci_connect(<span>$ora_username</span>, <span>$ora_password</span>,<span>$ora_connstr</span><span>);
</span><span>17</span> <span>//</span><span>执行Query,这里$res接收的是一个boolean值</span>
<span>18</span> <span>$stid</span> = oci_parse(<span>$conn</span>, 'select * FROM dq_try_app'<span>);
</span><span>19</span> <span>$res</span> = oci_execute(<span>$stid</span><span>);
</span><span>20</span> 
<span>21</span> <span>//</span><span>在while循环中使用oci_fetch_array遍历结果。</span>
<span>22</span> <span>while</span> (<span>$row</span> = oci_fetch_array(<span>$stid</span>, OCI_ASSOC+<span>OCI_RETURN_NULLS)) {
</span><span>23</span>     
<span>24</span>     <span>foreach</span> (<span>$row</span> <span>as</span> <span>$item</span><span>) {
</span><span>25</span>         <span>echo</span> <span>$item</span>."***"<span>;
</span><span>26</span> <span>    }
</span><span>27</span>     <span>echo</span> "<br>"<span>;
</span><span>28</span>     
<span>29</span> <span>}
</span><span>30</span> <span>//</span><span>var_dump($stid);   </span>
<span>31</span> ?>
Copy after login

At this point, the entire extension and connection is completed

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/1021466.htmlTechArticleThe WAMP environment configured by myself, extending the oracle function library (oci), a wampoci colleague received a task yesterday to use PHP handles the contents of the Oracle database, but opening the Oracle extension in PHP is not as straightforward as MySQL...
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Explain JSON Web Tokens (JWT) and their use case in PHP APIs. Explain JSON Web Tokens (JWT) and their use case in PHP APIs. Apr 05, 2025 am 12:04 AM

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

How does session hijacking work and how can you mitigate it in PHP? How does session hijacking work and how can you mitigate it in PHP? Apr 06, 2025 am 12:02 AM

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.

Describe the SOLID principles and how they apply to PHP development. Describe the SOLID principles and how they apply to PHP development. Apr 03, 2025 am 12:04 AM

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

How to debug CLI mode in PHPStorm? How to debug CLI mode in PHPStorm? Apr 01, 2025 pm 02:57 PM

How to debug CLI mode in PHPStorm? When developing with PHPStorm, sometimes we need to debug PHP in command line interface (CLI) mode...

How to automatically set permissions of unixsocket after system restart? How to automatically set permissions of unixsocket after system restart? Mar 31, 2025 pm 11:54 PM

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...

Framework Security Features: Protecting against vulnerabilities. Framework Security Features: Protecting against vulnerabilities. Mar 28, 2025 pm 05:11 PM

Article discusses essential security features in frameworks to protect against vulnerabilities, including input validation, authentication, and regular updates.

Explain late static binding in PHP (static::). Explain late static binding in PHP (static::). Apr 03, 2025 am 12:04 AM

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

See all articles