溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP的數(shù)據(jù)庫接口和技術(shù)介紹

發(fā)布時間:2021-09-01 21:18:41 來源:億速云 閱讀:125 作者:chen 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“PHP的數(shù)據(jù)庫接口和技術(shù)介紹”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“PHP的數(shù)據(jù)庫接口和技術(shù)介紹”吧!

1、php支持哪些數(shù)據(jù)庫(擁有哪些數(shù)據(jù)庫接口)

Adabas D ,InterBase ,PostgreSQL ,dBase ,F(xiàn)rontBase ,SQLite ,Empress ,mSQL ,Solid ,F(xiàn)ilePro(只讀),Direct MS-SQL ,Sybase ,Hyperwave ,MySQL ,Velocis ,IBM DB2 ,ODBC ,Unix dbm ,informix ,Oracle(OCI7 和 OCI8),Ingres ,Ovrimos

以上數(shù)據(jù)庫都支持,簡言之,支持絕大多數(shù)主流數(shù)據(jù)庫

2、php原生操作mysql數(shù)據(jù)庫方法

<?php
//數(shù)據(jù)庫操作
//1.導入數(shù)據(jù)庫
require("../../public/dbconfig.php");
//2.連接數(shù)據(jù)庫
$link=mysql_connect(HOST,USER,PASS) or die("數(shù)據(jù)庫連接失敗");
//3.選擇數(shù)據(jù)庫,設置字符集
mysql_select_db(DBNAME,$link);
mysql_set_charset("utf8");
//4.編寫sql語句,發(fā)送sql語句到數(shù)據(jù)庫
$sql="select * from users";
$res=mysql_query($sql,$link);
//5.解析結(jié)果集
while($user=mysql_fetch_assoc($res)){
echo "<tr align='center'>";
echo "<td>{$userstate[$user['state']]}</td>";
echo "<td>{$user['username']}</td>";
echo "<td>".date("Y-m-d",$user['addtime'])."</td>";
echo "<td>
<a href='edit.php?id={$user['id']}'>修改</a> 
<a href='action.php?a=del&id={$user['id']}'>刪除</a>
</td>";
echo "</tr>";
}
mysql_free_result($res);
mysql_close($link);
?>

3、php的PDO概念

PDO即PHP數(shù)據(jù)對象,將數(shù)據(jù)作為對象來操作,提高了操作數(shù)據(jù)的安全性和便捷性,從PHP5.1版本開始支持,例如預處理語句(prepared statements)、綁定參數(shù)(bound parameters)、可滾動游標(scrollable cursors)、定位更新(positioned updates)以及 LOB。

DAO(Data Access Object) 數(shù)據(jù)訪問對象是一個面向?qū)ο?PDO)的數(shù)據(jù)庫接口,在很多PHP框架中通過對原生的PDO封裝形成安全便捷的數(shù)據(jù)處理接口方法,下例為YII中的DAO方法:

http://www.yii-china.com/doc/guide/db_dao.html

<?php>
//在advanced\common\config\main-local.php的conponents中配置好db;
//連接數(shù)據(jù)庫
$connection = Yii::$app->db;
//編寫預處理查詢語句
$command = $connection->createCommand('SELECT * FROM post');
//執(zhí)行操作
$posts = $command->queryAll();
$post = $command->queryOne();
$titles = $command->queryColumn();
<?php>

4、活動記錄Active Record

ActiveRecord是一種設計模式,他的直接目的不是為了操作數(shù)據(jù)庫的,而是一種數(shù)據(jù)模型,相對于DAO是數(shù)據(jù)的更高級抽象。它提供了一個面向?qū)ο蟮慕y(tǒng)一接口,

用以訪問數(shù)據(jù)庫中的數(shù)據(jù)。

使用AR更大的簡化代碼,減少了出錯的可能,下例是YII中的AR操作方法

//數(shù)據(jù)表customer對象實例化
$customer = new Customer();
$customer->name = 'Qiang';
$customer->save(); // 一行新數(shù)據(jù)插入 customer 表

5、什么情況下使用DAO或AR了

復雜業(yè)務邏輯使用DOA, 反之用AR

到此,相信大家對“PHP的數(shù)據(jù)庫接口和技術(shù)介紹”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI