ThinkPHP連接ORACLE數據庫教程

目錄

  • 概念
  • 基本步驟
  • 詳細操作
  • 問題排除
  • 參考

概念

  • 要連接Oracle數據庫,必須有兩個東西,一個PHP官方寫的擴展,一個Oracle官方寫的客戶端
  • PHP是通過擴展去操作oralce客戶端連接的服務端數據庫,所以兩個都不能少,而且版本必須一致
  • PHP官方寫的Oracle擴展:oci8,有很多版本,還有32位和64位,每個版本官網有寫對于的oracle版本
  • Ocracle官方寫的客戶端:Instant Client,也分為32位和64位,需要根據PHP匹配,下面會講

基本步驟

  1. 下載并配置oci8擴展
  2. 下載并配置oracle客戶端
  3. 配置thinkphp

詳細操作

  1. 下載并配置oci8擴展
  • 下載地址:http://pecl.php.net/package/oci8
    oci8包含很多版本
  • 如何選擇版本:
  • 打開phpstudy環境,打開首頁phpinfo.php,查看PHP版本
    在這里插入圖片描述
  • 這里7.0.12選擇32位的oci8擴展+32位的Instant Client
  • 下載對于版本
  • 在這里插入圖片描述
  • 7.3以上的PHP要選擇2.2.0以上版本,這里選擇7.0對于的版本,因為使用的phpstudy2016,使用的PHP版本是php-7.0.12-nts
  • 注意對應版本的位數,32和64不能兼容
  • 解壓后把這些全部拷貝到PHP的ext目錄下D:\phpStudy\php\php-7.0.12-nts\ext
  • 在這里插入圖片描述
  • 打開php.ini,找到extension所在,填寫以下內容
extension=php_pdo_oci.dll
extension=php_oci8.dll
;;extension=php_oci8_11g.dll
extension=php_oci8_12c.dll
  • 說明:
    php_pdo_oci.dll:這個是phpstudy自帶的,使用pdo方法去連接oci8,這個必須打開
    php_oci8.dll:這個是拷貝進入的oci8基本擴展,必須打開
    php_oci8_11g.dll / php_oci8_12c.dll:這個是擴展版本,實測任意打開一個,都可以連接oracle 11g和oracle 19c,后面一個感覺速度更快
  • 重啟phpstudy
  • 出現oci8擴展,說明安裝成功
    在這里插入圖片描述
  • 新安裝的Oracle Run-time Client Library Version可能出現0.0.0.0,等配置Instant Client后再刷新會出現版本信息
  1. 下載并配置oracle客戶端
  • 下載地址:https://www.oracle.com/database/technologies/instant-client/downloads.html
  • 在這里插入圖片描述
  • 這里也有版本選擇,不管phpinfo是32還是64,這里都下載32位,實測32位可以匹配64和32的PHP(phpstudy_pro中PHP7.3.4版本測試)
  • 下載需登錄,注冊一個賬號即可
  • 這里選擇phpinfo中提示的instantclient_12_1
    在這里插入圖片描述

在這里插入圖片描述

  • 解壓到任意沒有中文路徑的地方,如D:/instantclient_12_1
  • 配置環境變量,這個和JAVA類似,就是可以在任何地方執行instantclient_12_1中功能
  • 在這里插入圖片描述
  • 這個必須要配置,最終連接Oracle數據庫的是instant client客戶端,這個和oracle不匹配直接導致無法連接,實測32位可以匹配PHP64或者32(instant client版本還和oracle服務端版本有關,32位不行就換一個試試)
  1. 配置thinkphp
  • common->config中配置
<?php
return array(//連接oracle 11g r2'DB_TYPE' =>  'oracle',      // 數據庫類型'DB_HOST' =>  '127.0.0.1',   // 服務器地址'DB_NAME' =>  'orcl',    // 數據庫名'DB_USER' =>  'usr',          // 用戶名'DB_PWD'  =>  'pwd', // 密碼'DB_PORT' =>  '1521',        // 端口//連接oracle 19c CBD模式// 'DB_TYPE' =>  'oracle',      // 數據庫類型// 'DB_HOST' =>  '127.0.0.1',   // 服務器地址// 'DB_NAME' =>  'orcl',    // 數據庫名// 'DB_USER' =>  'C##usr',          // 用戶名// 'DB_PWD'  =>  'pwd', // 密碼// 'DB_PORT' =>  '1521',        // 端口
);
  • 書寫測試連接方法
<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {public function index(){$sql = " select * from tablea where rownum <10 ";$rs = M()->query($sql);var_dump($rs);}
}
  • 經實測,11G和19C都可以連接

問題排除

oci_connect(): OCIEnvNlsCreate() failed. There is something wrong with your system - please check that PATH includes the directory with Oracle Instant Client libraries

  • 解決方案:Instant Client沒有配置在環境變量中,配置一下即可

SQLSTATE[HY000]: OCIEnvNlsCreate: Check the character set is valid and that PHP has access to Oracle libraries and NLS data (ext\pdo_oci\oci_driver.c:688)

  • 解決方案:Instant Client版本不匹配,如果是64位的,換成32位的試一試

參考

  • https://blog.csdn.net/qq_35372797/article/details/120791792 按照這篇文章配置出現編碼錯誤,實際上是Instant Client版本不匹配,換成32位的就可以了

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/215959.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/215959.shtml
英文地址,請注明出處:http://en.pswp.cn/news/215959.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【數組】-Lc34-在排序數組中查找元素的第一個和最后一個位置(二分查找 + 兩邊擴展)

寫在前面 最近想復習一下數據結構與算法相關的內容&#xff0c;找一些題來做一做。如有更好思路&#xff0c;歡迎指正。 目錄 寫在前面一、場景描述二、具體步驟1.環境說明2.代碼 寫在后面 一、場景描述 給定一個按照升序排列的整數數組 nums&#xff0c;和一個目標值 target。…

大數據講課筆記1.4 進程管理

文章目錄 零、學習目標一、導入新課二、新課講解&#xff08;一&#xff09;進程概述1、基本概念2、三維度看待進程3、引入多道編程模型&#xff08;1&#xff09;CPU利用率與進程數關系&#xff08;2&#xff09;從三個視角看多進程 4、進程的產生和消亡&#xff08;1&#xf…

5V低壓步進電機驅動芯片GC6150,應用于攝像機,機器人 醫療器械等產品中。具有低噪聲、低振動的特點

GC6150是雙通道5V低壓步進電機驅動器&#xff0c;具有低噪聲、低振動的特點&#xff0c;特別適用于相機變焦對焦系統、萬向架、搖頭機等精度、低噪聲STM控制系統&#xff0c;該芯片為每個通道集成了一個256微步的驅動器。通過SPI & T2C接口&#xff0c;客戶可以方使地調整驅…

Python+Appium自動化測試之元素等待方法與重新封裝元素定位方法

在appium自動化測試腳本運行的過程中&#xff0c;因為網絡不穩定、測試機或模擬器卡頓等原因&#xff0c;有時候會出現頁面元素加載超時元素定位失敗的情況&#xff0c;但實際這又不是bug&#xff0c;只是元素加載較慢&#xff0c;這個時候我們就會使用元素等待的方法來避免這種…

C++ c_str()用法

標準庫的string類提供了3個成員函數來從一個string得到c類型的字符數組&#xff1a;c_str()、data()、copy(p,n)。 c_str()是Borland封裝的String類中的一個函數&#xff0c;它返回當前字符串的首字符地址。換種說法&#xff0c;c_str()函數返回一個指向正規C字符串的常量指針(…

下降路徑最小和/最小路徑和(dp問題)

1.狀態表示 2.狀態轉移方程 3.初始化 4.填表 從上往下 5.返回值 dp表最后一行的最小值 ------------------------------------------------------------------------------------------------------------------------------- 1.狀態表示 2.狀態轉移方程 3.初始化 4.填表 上…

【CVPR 2022】解讀 Controllable Animation of Fluid Elements in Still Images:光流法視頻生成

Diffusion Models視頻生成-博客匯總 前言:用戶輸入箭頭,就能讓圖像動起來,這是經典的Animating任務。CVPR 2022中的一篇經典論文《Controllable Animation of Fluid Elements in Still Images》使用光流法做這種image-to-video任務,很多做法值得借鑒,這篇博客詳細這篇論文…

【教程】app備案流程簡單三部曲即可完成

APP備案流程包括以下步驟&#xff1a; 1. 開發者實名認證&#xff1a;在提交備案申請之前&#xff0c;開發者需要通過移動應用開發平臺進行實名認證。這個步驟需要提供身份證號碼、姓名、聯系方式等信息&#xff0c;并上傳相關證件照片或掃描件。 2. 應用信息登記&#xff1a…

使用 PyTorch 完全分片數據并行技術加速大模型訓練

本文&#xff0c;我們將了解如何基于 PyTorch 最新的 完全分片數據并行 (Fully Sharded Data Parallel&#xff0c;FSDP) 功能用 Accelerate 庫來訓練大模型。 動機 隨著機器學習 (ML) 模型的規模、大小和參數量的不斷增加&#xff0c;ML 從業者發現在自己的硬件上訓練甚至加…

小程序域名SSL證書能用免費的嗎?

眾所周知&#xff0c;目前小程序要求域名強制使用https協議&#xff0c;否則無法上線。但是對于大多數開發者來說&#xff0c;為每一個小程序都使用上付費的SSL證書&#xff0c;也是一筆不小的支出。那么小程序能使用免費的SSL證書嗎&#xff1f; 答案是肯定的。目前市面上可選…

HCIP---RSTP/MSTP

文章目錄 目錄 文章目錄 前言 一.RSTP誕生背景 二.RSTP對比STP的快速收斂機制 端口角色變化 接口狀態變化 RSTP-BPDU 指定端口- P/A機制 BPDU發送變化 端口狀態快速切換 優化拓撲變更機制 三.MSTP MSTP誕生背景 MSTP相關概念 MSTP配置 總結 前言 STP協議雖然能夠解決環…

TypeScript中的函數注釋

一. 概覽 函數注釋主要分為顯示注釋、類型推斷、隱式的any&#xff0c;現在來詳細總結下 二. 顯示注釋 舉個例子 let str1: string hello,jacklet intArr: number[] [1,2,3] let strArr&#xff1a;Array<string> [1,2,3]function test(a: number,b: number): num…

記錄 | xftp遠程連接兩臺windows

1、打開openssh 設置 -> 應用 -> 可選功能 -> 添加功能 -> OpenSSH 客戶端&#xff0c;將 ssh 客戶端安裝將兩臺電腦的 ssh 開啟&#xff0c;cmd 中輸入 net start sshd2、配置 win10 賬號密碼 3、進行 xftp 連接

MATLAB安裝

親自驗證有效&#xff0c;多謝這位網友的分享&#xff1a; https://blog.csdn.net/xiajinbiaolove/article/details/88907232

租一臺服務器多少錢決定服務器的價格因素有哪些

租一臺服務器多少錢決定服務器的價格因素有哪些 大家好我是艾西&#xff0c;服務器這個名詞對于不從業網絡行業的人們看說肯定還是比較陌生的。在21世紀這個時代發展迅速的年代服務器在現實生活中是不可缺少的一環&#xff0c;平時大家上網瀏覽自己想要查詢的信息等都是需要服…

加減乘除簡單嗎?不,一點都不,利用位運算實現加減乘除(代碼中不含+ - * /)

文章目錄 &#x1f680;前言&#x1f680;異或運算以及與運算&#x1f680;加法的實現&#x1f680;減法的實現&#x1f680;乘法的實現&#x1f680;除法的實現 &#x1f680;前言 這也是阿輝開的新專欄&#xff0c;知識將會很零散不成體系&#xff0c;不過絕對干貨滿滿&…

華為鴻蒙HarmonyOS應用開發者高級認證試題及答案

判斷 1只要使用端云一體化的云端資源就需要支付費用&#xff08;錯&#xff09; 2所有使用Component修飾的自定義組件都支持onPageShow&#xff0c;onBackPress和onPageHide生命周期函數。&#xff08;錯&#xff09; 3 HarmonyOS應用可以兼容OpenHarmony生態&#xff08;對…

多維時序 | MATLAB實現SAO-CNN-BiGRU-Multihead-Attention多頭注意力機制多變量時間序列預測

多維時序 | MATLAB實現SAO-CNN-BiGRU-Multihead-Attention多頭注意力機制多變量時間序列預測 目錄 多維時序 | MATLAB實現SAO-CNN-BiGRU-Multihead-Attention多頭注意力機制多變量時間序列預測預測效果基本介紹模型描述程序設計參考資料 預測效果 基本介紹 MATLAB實現SAO-CNN-B…

CommonJs模塊化實現原理ES Module模塊化原理

CommonJs模塊化實現原理 首先看一個案例 初始化項目 npm init npm i webpack -D目錄結構如下&#xff1a; webpack.config.js const path require("path"); module.exports {mode: "development",entry: "./src/index.js",output: {path: p…

硬件開發筆記(十六):RK3568底板電路mipi攝像頭接口原理圖分析、mipi攝像頭詳解

若該文為原創文章&#xff0c;轉載請注明原文出處 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/134922307 紅胖子網絡科技博文大全&#xff1a;開發技術集合&#xff08;包含Qt實用技術、樹莓派、三維、OpenCV、OpenGL、ffmpeg、OSG、單片機、軟硬…