具體的概念區(qū)別你可以查看php幫助手冊,我說下個人的理解:
陽朔網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站開發(fā)等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)2013年至今到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
通常來說,array是數(shù)組,而object是對象,兩者有很大的區(qū)別,最主要的區(qū)別我覺得對象一般要定義行為,其目的是為了封裝,而數(shù)組主要定義數(shù)據(jù)結(jié)構(gòu)。
但這兩種在php語言里區(qū)別比較模糊,因為php是支持范數(shù)據(jù)類型,所以array可以是object,反之亦然。
我們都知道如何從Mysql獲取我們需要的行(記錄),讀取數(shù)據(jù),然后存取一些改動。很明顯也很直接,在這個過程背后也沒有什么拐彎抹角的。然而對于我們使用面對對象的程序設(shè)計(OOP)來管理我們數(shù)據(jù)庫中的數(shù)據(jù)時,這個過程就需要大大改進一下了。這篇文章將對如何設(shè)計一個面對對象的方式來管理數(shù)據(jù)庫的記錄做一個簡單的描述。你的數(shù)據(jù)當中的所有內(nèi)部邏輯關(guān)系將被封裝到一個非常條理的記錄對象,這個對象能夠提供專門(專一)的確認代碼系統(tǒng),轉(zhuǎn)化以及數(shù)據(jù)處理。隨著Zend Engine2 和PHP5的發(fā)布,PHP開發(fā)者將會擁有更強大的面對對象的工具來輔助工作,這將使這個過程(面對對象地管理數(shù)據(jù)庫)更有吸引力。 以下列出了一些使用對象來描敘你的數(shù)據(jù)庫的有利方面: 存取方法(Accessor methods)將會使你對屬性的讀取和寫入過程做到完全的控制 每一級的每個記錄和屬性(的操作)都有確認過程 從關(guān)系表中智能的獲取對象 重復使用的邏輯方法意味著所有的數(shù)據(jù)交互都要通過相同的基礎(chǔ)代碼(codebase),這將使維護變得更加簡單 代碼簡單,因為不同的記錄的內(nèi)部邏輯都已經(jīng)包含在各自所處的類(class)當中,而不是繁瑣的庫(lib)文件 在手工編寫代碼和SQL查詢語句時,出錯的機會將更少 存取方法(Accessor methods) 存取方式是通過類給實例(instance)的變量賦值。一個例子,我有一個叫User的類,并且有一個實例$username,我會寫這樣的存取方法(函數(shù)),User-username()和User-setUsername()用來返回和給實例賦值。 ?php class User { var $username; function username() { return $this-username; } function setUsername($newUsername) { $this-username = $newUsername; } } ? 這里有很好的理由讓我們編寫這樣的“特別的代碼”。它將使開發(fā)者更靈活的改變類的繁瑣的工作,因為這一過程將不需要其他的使用類的php代碼。讓我們來看看下面這個更加完善的可信賴的User類。 變量$username將不復存在,所有的東西都被整合的放在數(shù)組$_data當中 如果username是空的話,username()函數(shù)將提供一個缺?。J)的值給它 setUsername()過程將在接受值之前確認username是否合乎標準格式(如字長等) ?php class User { var $_data = array(); // associative array containing all the attributes for the User function username() { return !empty($this-_data['username']) ? $this-_data['username'] : '(no name!)'; } function setUsername($newUsername) { if ($this-validateUsername($newUsername)) { $this-_data['username'] = $newUsername; } } function validateUsername($someName) { if (strlen($someName) 12) { throw new Exception('Your username is too long'); // PHP5 only } return true; } } ? 顯而易見,這對我們控制存取對象的數(shù)據(jù)有很大幫助。如果一個程序員已經(jīng)直接地存取username的信息,以上代碼的變化將會破壞他的代碼。然而我們可以使用(類的)存取方法,就像上面代碼中注釋的那樣,添加一個驗證的功能而不需要改變?nèi)魏纹渌臇|西。注意username的驗證(例子當中是不能超過12字節(jié))代碼是獨立在setUsername()方法之外的。從驗證到存儲到數(shù)據(jù)庫的過程輕而易舉。而且,這是個非常好的單憑經(jīng)驗的方法,一個方法或一個類需要做的越少,它的重復使用的機會將會越大。這在你開始寫一個子類時更加明顯,假如你需要一個子類,并且又要跳過(忽略)父類方法(行為)中的一些特殊的細節(jié),如果(針對這個細節(jié)的)方法很小而又精細,(修改它)只是一瞬間的過程,而如果這個方法非常臃腫,針對多種目的,你可能將在復制子類中大量代碼中郁悶而終。 比方說,假如Admin是User類的一個子類。我們對adamin的用戶可能會有不同的,相對苛刻一些的密碼驗證方法。最好是跨過父類的驗證方法和整個setUsername()方法(在子類中重寫)。 更多關(guān)于存取器(Accessor) 下面是一些其他的例子來說明如何使存取器用的更有效果。很多時候我們可能要計算結(jié)果,而不是簡單的返回數(shù)組中的靜態(tài)數(shù)據(jù)。存取方法還能做的一個有用的事情就是更新(updating)緩存中的值。當所有的變動(對數(shù)據(jù)的所有操作)都要通過setX()方法的時候,這正是我們根據(jù)X來重置緩存中的值的時刻。 于是我們的這個類層次變得更加明了: 內(nèi)部變量$_data的處理被替換成受保護的私有方法(private methods)_getData()和_setData() 這類方法被轉(zhuǎn)移到被稱作記錄(Record)的抽象的超級類(super class),當然它是User類下的子類 這個記錄類(Record class)掌握所有存取數(shù)組$_data的細節(jié),在內(nèi)容被修改之前調(diào)用驗證的方法,以及將變更的通知發(fā)給記錄(Records),就像發(fā)給中心對象存儲(ObjectStore)實例。 ?php class User extends Record { // --- OMITTED CODE --- // /** * Do not show the actual password for the user, only some asterixes with the same strlen as the password value. */ function password() { $passLength = strlen($this-_getData('password')); return str_repeat('*', $passLength); } /** * Setting the user password is not affected. */ function setPassword($newPassword) { $this-_setData('password', $newPassword); } /** * fullName is a derived attribute from firstName and lastName * and does not need to be stored as a variable. * It is therefore read-only, and has no 'setFullname()' accessor method. */ function fullName() { return $this-firstName() . " " . $this-lastName(); } /** * Spending limit returns the currency value of the user's spending limit. * This value is stored as an INT in the database, eliminating the need * for more expensive DECIMAL or DOUBLE column types. */ function spendingLimit() { return $this-_getData('spendingLimit') / 100; } /** * The set accessor multiplies the currency value by 100, so it can be stored in the database again * as an INT value. */ function setSpendingLimit($newSpendLimit) { $this-_setData('spendingLimit', $newSpendLimit * 100); } /** * The validateSpendingLimit is not called in this class, but is called automatically by the _setData() method * in the Record superclass, which in turn is called by the setSpendingLimit() method. */ function validateSpendingLimit($someLimit) { if (is_numeric($someLimit) AND $someLimit = 0) { return true; } else { throw new Exception("Spending limit must be a non-negative integer"); //PHP5 only } } } /** * Record is the superclass for all database objects. */ abstract class Record { var $_data = array(); var $_modifiedKeys = array(); // keeps track of which fields have changed since record was created/fetched /** * Returns an element from the $_data associative array. */ function _getData($attributeName) { return $this-_data[$attributeName]; } /** * If the supplied value passes validation, this * sets the value in the $_data associative array. */ function _setData($attributeName, $value) { if ($this-validateAttribute($attributeName, $value)) { if ($value != $this-_data[$attributeName]) { $this-_data[$attributeName] = $value; $this-_modifiedKeys[] = $attributeName; $this-didChange(); } else { // the new value is identical to the current one // no change necessary } } } /** * For an attribute named "foo", this looks for a method named "validateFoo()" * and calls it if it exists. Otherwise this returns true (meaning validation passed). */ function validateAttribute($attributeName, $value) { $methodName = 'validate' . $attributeName; if (method_exists($this, $methodName)) { return $this-$methodName($value); } else { return true; } } function didChange() { // notify the objectStore that this record changed } } ? 現(xiàn)在我們擁有了一個抽象的超級類(Record),我們可以將User類里面大量的代碼轉(zhuǎn)移出來,而讓這個User的子類來關(guān)注User的特殊項目如存取和驗證方法。你可能已經(jīng)注意到在我們的這個紀錄類(Record class)沒有任何的SQL代碼。這并不是疏忽或者遺漏!對象存儲類(ObjectStore class)(隱藏在第二部分)將負責所有和數(shù)據(jù)庫的交互,還有我們的超級類Record的實例化。這樣使我們的Record類更加瘦小而又有效率,而這對于評價我們處理大量對象的效率的時候是個重要因素。
PDO(PHP Data Objects)是一種在PHP里連接數(shù)據(jù)庫的使用接口。PDO與mysqli曾經(jīng)被建議用來取代原本PHP在用的mysql相關(guān)函數(shù),基于數(shù)據(jù)庫使用的安全性,因為后者欠缺對于SQL注入的防護。
PHP 數(shù)據(jù)對象(PDO) 擴展為PHP訪問數(shù)據(jù)庫定義了一個輕量級的一致接口。實現(xiàn) PDO 接口的每個數(shù)據(jù)庫驅(qū)動可以公開具體數(shù)據(jù)庫的特性作為標準擴展功能。 注意利用 PDO 擴展自身并不能實現(xiàn)任何數(shù)據(jù)庫功能;必須使用一個具體數(shù)據(jù)庫的 PDO 驅(qū)動來訪問數(shù)據(jù)庫服務(wù)。
相關(guān)信息:
PDO 提供了一個數(shù)據(jù)訪問抽象層,這意味著,不管使用哪種數(shù)據(jù)庫,都可以用相同的函數(shù)(方法)來查詢和獲取數(shù)據(jù)。 PDO不提供數(shù)據(jù)庫抽象層;它不會重寫 SQL,也不會模擬缺失的特性。如果需要的話,應(yīng)該使用一個成熟的抽象層。
從 PHP 5.1開始附帶了 PDO,在 PHP 5.0 中是作為一個 PECL 擴展使用。 PDO 需要PHP 5核心的新OO特性,因此不能在較早版本的 PHP 上運行。
你是說用 php 獲取 遠程的網(wǎng)頁?
你去看這個函數(shù):file_get_contents
---------------------------------------------
你的事: 后臺要查詢出一個用戶(用戶名,用戶ID等一些信息)再把這些信息返回到前臺顯示。
但是前臺現(xiàn)在我只要一個用戶名,這樣的話,最好用 json 格式。
比如,后臺這樣寫 :
echo '{"name":'. json_encode('前端攻城師') .',"id":1000,"area":'. json_encode('中國') .'}';
然后前臺代碼:
script
$.post("index.php?a=diary_view2action=first" , function(data){
alert(data.name);
},'json');
/script
這樣,就可以獲取 名字啦。。。
如果還有問題,設(shè)我為最佳,然后去 jQuery 愛好者論壇 去提問。。。
有高手幫你回答。。。
這是連接mysql數(shù)據(jù)庫的簡單代碼:
$conn=new?PDO("mysql:host=localhost;dbname=webdata","user","pwd");
$sth=$conn-prepare("select?*?from?books");
$sth-execute();
while($res=$sth-fetch(PDO::FETCH_ASSOC))
{
echo("div".$res["id"].":".$res["title"]."--".$res["author"]);
}
PDO一是PHP數(shù)據(jù)對象(PHP Data Object)的縮寫。
并不能使用PDO擴展本身執(zhí)行任何數(shù)據(jù)庫操作,必須使用一個database-specific PDO driver(針對特定數(shù)據(jù)庫的PDO驅(qū)動)訪問數(shù)據(jù)庫服務(wù)器。
PDO并不提供數(shù)據(jù)庫抽象,它并不會重寫SQL或提供數(shù)據(jù)庫本身缺失的功能,如果你需要這種功能,你需要使用一個更加成熟的抽象層。
PDO需要PHP5核心OO特性的支持,所以它無法運行于之前的PHP版本。