質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

7380閲覧

[CentOS6] php-oci8とPDO-OCIについて

Reiku

総合スコア40

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2017/02/15 07:20

環境

CentOS6 64bit
php 7.0.15

確認したいこと

当方知識浅く、ざっくり、それぞれの違いと役割だけ確認したいのですが、

CentOSのサーバーからOracleへ、
PHPを用いてOracleへ接続し各種操作がしたいと考えています。

その際、
php-oci8というものだけで済むのかと思ったのですが、
調べていると、PDO-OCIなるものも必要との情報も上がってきました。
しかしPDO-OCIはphp5.3までしかサポートしていない(?)とも書かれていたような気がします。
(これはちらっと見ただけでろくに確認はしていないのですが・・・)

そこで確認したいのですが、
「php-oci8」と「PDO-OCI」とはそれぞれ
どのようなもので、どういった役割があるのかを知りたいです。
CentOS6環境からOracleへ接続する場合、
双方とも導入しなければならないのでしょうか。。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

php-oci8 について

OCI8 機能拡張(php-oci8)はOracleのクライアントライブラリを直接呼び出して、Oracle DBに接続するための PHP 関数群を提供するものです。

導入すると oci_ で始まる関数たちが使用できるようになり、それらを用いて Oracle にアクセスします。

OCI8 の PHPマニュアル

PDO_OCI について

PDO は、各種の DB アクセスのためにそれぞれ独自の関数を使うのではなく、同じ呼び出し方にしようという発想のもとに開発されたライブラリです。開発者は PDO に DB のタイプを指定するだけで同じやり方でアクセスできます。各 DB アクセス方法の違いは PDO 用のドライバモジュールが吸収してくれます。その PDO 用の Oracle ドライバが PDO_OCI というわけです。

PDO_OCI の PHPマニュアル

それぞれの違い

それぞれのモジュールは上記のように意味合いが違いますので、お互いに干渉することなく共存して導入することができます。どちらかの実行のためにもう片方が必要になるということもありません。ただしどちらも Oracle のクライアントライブラリ (SDK) が必要なことは同じです。

php-oci8 と PDO_OCI では PHP からの呼び出し方が全く異なりますので、自分がどちらを使ってプログラムを書きたいのかを考えてから、必要な方を導入すれば良いと思います。

投稿2017/02/23 07:57

編集2017/02/24 02:14
koyhoge

総合スコア268

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問