1. 動作環境構築
システム:Windows7 Ultimate 64bit
PHP環境:wampserver2.2e-php5.4.3-httpd2.2.22-mysql5.5.24 32- bit バージョン
ダウンロードアドレス: http://www.wampserver.com/en/
ThinkPHP: 3.0 正式版
ダウンロード アドレス: http://thinkphp.cn/down.html
Oracle: Orcale_11gR2 32 ビット版
ダウンロード アドレス: http://www.oracle.com/technetwork/cn/indexes/downloads/index.html
データベース操作ツール: PLSQL Developer 32-bit
ダウンロードアドレス: http://www.allroundautomations.com/plsqldev.html
開発ツール: NetBeans IDE 7.1.2
ダウンロード アドレス: http://netbeans.org/downloads/index.html PHP バージョンをダウンロードするだけです
注: ソフトウェアの「ビット」は非常に重要であるため、ここで繰り返し強調します。一般に、私たちのシステムは 64 ビットなので、64 ビットのソフトウェアを使用するのが最善ですが、システム以外はすべて存在します。 32 ビットを選択する理由は、PLSQL Developer および WAMP の PHP 拡張機能で動作するためです。 PLSQL Developerには64ビット版がないためです。 64 ビットの Oracle データベースを使用して 32 ビットのクライアントをインストールできると言う友人もいますが、私の操作方法が気に入らない場合は、それを避けてください。もちろん、PLSQL Developer を使用せずに Oracle 独自の SQL Developer を使用する場合は、64 ビットまたは 32 ビットのどちらをインストールするかはあなた次第です。 PHP は、Oracle データベースに接続するために対応する拡張機能を開く必要があります。PHP 拡張機能もデータベース クライアントのビット数に対応する必要があるため、この拡張機能にはデータベース クライアントのサポートも必要です。冗長の終わり。
2. 環境構成
1. Oracle のインストールについては説明しません。NetBeans IDE 7.1.2 も同様です。それ自体で解決します。
2. Wamp のインストールについては説明しません。方法がわからない場合は、DOS から学び直してください。
3. WAMP は、Wamp がインストールされているフォルダーの下の www に PHP Web ページのフォルダーを定義します。つまり、D ドライブにインストールしました。当面はその他のカスタム変更は行いません。 wamp を起動します。システム トレイ アイコンが緑色の場合は、起動が正常であることを意味します。
4. localhost を開くと、次のインターフェイスが表示されます。これは、環境設定が基本的に OK であることを意味します。なぜ基本的なのかというと、Oracle の構成がまだ設定されていないからです。
5. 図に示すように、PHP 拡張機能メニューを開き、[PHP 拡張機能] を左クリックし、php-oci8 の拡張機能をクリックします。再起動して緑色になるまで待ちます。これはOKを意味します。
6. もう一度 localhost ページを開きます。図 4 に示す表示が見つかった場合は、PHP が現在 Oracle をサポートしていることを意味します。
私が使用している wamp クライアントと oracle クライアントは両方とも 32 ビットであることに注意してください。一方が 64 ビットである場合、oci 拡張子を開くことができず、自動環境監視ページに oci8 が表示されません。 PL/SQLを使用しない前提で、32ビットOracleと32ビットWAMPの組み合わせ、または64ビットOracleと64ビットWAMPの組み合わせでなければなりません。それ以外の場合は避けてください。
3. ThinkPHP の構成
1. プロジェクト内に必要なのは、コアとなる ThinkPHP フォルダーだけです。
2. IDE を使用して新しいプロジェクトを作成します。他のフォルダーをカスタマイズする必要がある場合は、ここでは変更しません。
3. Thinkphp フォルダーをプロジェクト フォルダーにコピーし、新しい php ファイルを作成し、index.php という名前を付けます。
4. これらのファイルはすでに IDE に表示されています。index.php を開き、次の内容を記述します。
コードをコピーします。 コードは次のとおりです。 :
define('APP_DEBUG', true);
require './ThinkPHP/ThinkPHP.php';
コードをコピーします コードは次のとおりです。次のように:
return array(
'DB_TYPE' => 'Oracle', // データベース タイプ
'DB_HOST' => '192.168 .0.8', // サーバーアドレス
'DB_NAME' => 'orcl', // データベース名
'DB_USER' => 'test', // ユーザー名
'DB_PWD' => 'test ', // パスワード
'DB_PORT' => '1521', // ポート
);
Oracle数据库和mysql 的结构不同,一般默认安装的数据库名是orcl,如果你使用了多个数据库监听,那么就要根据具体的监听字段来设置。比如:我本机数据库坚挺是Orcl,同时监听另外一个外网的数据库,监听字符串为Orcl2,那么如果你需要连接这个外网数据库,那么需要写的数据库名就是orcl2。
7, 经过以上的配置,是已经可以连接oracle数据库了,但是在thinkphp的实际操作中有什么注意的地方,且接着往下看。
最近收集了一些关于THinkPHP连接Oracle数据库的问题,有很多朋友按照连接mysql的方法来操作,导致有一些方法在Oreale中无法正常使用。比如说:findAll,Select方法无法使用,获取不到需要的数据。Create和add方法无法创建和写入数据到数据库中。
其实根据以前问题我做了几天调试,找到了问题所在,并成功在我自己一个小项目练习中使用正常,那么现在就将我的经验分享给大家。
1,数据库的连接及配置文件的内容我就不说了, 上面已经做了解释。我这里只根据一个数据表的例子来说明我的操作。
2,表结构如下:
3,这个表中有3个字段,ID主键,用户名username和密码password,因为oracle数据库把表名和字段都是转成大写的,同时不支持ID主键自增,我只有使用另外的方法来实现这个功能,比如:ID自动序列+触发器实现ID自增。
4, ThinkPHP中,Action是控制器,Model是模型,视图是以模板方式体现的。
首先,说控制器,我只做增加和获取列表的方法介绍。
其次,说模型,这里才是成功的主要原因。为什么?ThinkPHP是有字段映射的,这个在对MYSQL的支持非常完美,基本不用写MODEL,但是对ORALCE就不行了,当使用M->add()来添加数据时,字段会被$this->_facade()方法过滤掉。这样生成的SQL语句就是没法执行的,肯定是错误的,导致数据添加不到数据库中,那么使用select()方法也是一样被过滤。
再次,当我单步调试时,断点被过滤的时候,过滤方法使用到了new出来的MODEL,这个MODEL会有一个字段映射的数组在里面,这个过滤方法就是和这个字段数组进行对比,如果不一致就过滤掉,结果我调试发现,new出来的MODEL根本没有把字段映射加进去,数组直接为空,当然就没法和添加的数据字段一一对应了。这就是错误的关键。
下面就来说解决方法,其实很简单,按照基本的MVC结构,不管是PHP还是JAVA还是.NET都有这样的结构,那么按照严格的标准,MODEL层的代码是必须写的,就是要和数据库的字段做映射。但是很多用mysql的,就直接没有去写MODEL里面的代码。这种习惯被用到了oracle中,就出了问题。
5, 下面针对我上面的数据表写出我的代码:
我的Action是这样的:UserAction.class.php。控制器我只对添加和查找做例子,因此代码如下:
复制代码 代码如下:
public function index() {
header("Content-Type:text/html; charset=utf-8");
$M_User = new UserModel();
$User_List = $M_User->select();
$this->assign('Title', '用户管理');
$this->assign('UserList', $User_List);
$this->display();
}
//添加用户提交处理
public function Create_Post() {
$M_User = new UserModel();
$data['username'] = $this->_post('username');
$data['password'] = md5($this->_post('pwd'));
if ($M_User->create()) {
$Query_Result = $M_User->add($data);
if (false !== $Query_Result) {
$this->success('用户添加成功');
} else {
$this->error('用户添加错误');
}
} else {
header("Content-Type:text/html; charset=utf-8");
exit($M_User->getError() . ' [ 返 回 ]');
}
}
$M_User=new UserModel();
这个方法最好这么写,因为做.NET的原因,一直都这么写的。针对具体的模型进行实例化,严格规定我就要对User表进行操作了。
获取POST数据的代码就不多解释了。
$M_User->create();
这是ThinkPHP的一个方法,很好,可以帮你过滤掉非法的东西,建议使用。
$Query_Result = $M_User->add($data);
このセクションはデータの追加に関するもので、このセクションは $M_User フィールドとフィルター フィールドに従ってインスタンス化する必要があるため、追加するデータを指定することに慣れています。もちろん、MODEL を適切にコーディングすれば問題ありません。以下のコードについては説明を省略します。公式文書はあります。
私のモデルは次のようなものです: UserModel.class.php
protected $fields = array( 'id', 'username', 'password' );
モデルの説明: これが重要なポイントです。この方法でのみ、new によって生成された $M_User のマッピング フィールド配列が POST データに対応し、フィルタリング メソッドがそれを認識できるようになります。通常はフィルタされません。
6. 上記の操作が完了すると、ThinkPHP が提供するページング (limit)、find()、findAll などのメソッドを使用してデータを操作できるようになります。
出典 http://www.cnblogs.com/aceliu/