PHP 資料庫方面

2021-08-24 18:32:14 字數 3956 閱讀 3502

php 在資料庫方面的豐富支援,也是它迅速走紅的原因之一,它支援下列的資料庫或是資料檔案:

· adabas d

· dba

· dbase

· dbm

· filepro

· informix

· interbase

· msql

· microsoft sql server

· mysql

· solid

· sybase

· odbc

· oracle 8

· oracle

· postgresql

而在 internet 上它也支援了相當多的通訊協議 (protocol),包括了與電子郵件相關的 imap, pop3;網管系統 snmp;網路新聞 nntp;帳號共用 nis;全球資訊網 http 及 apache 伺服器;目錄協議 ldap 以及其它網路的相關函式。

除此之外,用 php 寫出來的 web 後端 cgi 程式,可以很輕易的移植到不同的作業系統上。例如,先以 linux 架的**,在系統負荷過高時,可以快速地將整個系統移到 sun 工作站上,不用重新編譯 cgi 程式。面對快速發展的 internet,這是長期規劃的最好選擇。

變數型別:

php有好多種變數; 主要有這些:

- 數字 (integer - 例: 32)

- 布林值 (boolean - 例: true)

- 字串 (string - 例: 'a string of text')

- null

- 資源(resource)

- 陣列 (array - 例: arrayname[2])

-物件(object)

語法:語法有三種:

//comment

/* comment */

# comment

基本的 "control structures":

* if ... else

if (condition == true) ;

* if ... else then

if (condition == true)

else if (condition2 == true) ;

乙個php例項:

<?php

echo "hello world";

?>

請看:php官方**:www.php.net

php對物件導向的支援

物件導向程式設計的概念:

不同的作者之間說法可能不一樣,但是乙個oop語言必須有以下幾方面:

抽象資料型別和資訊封裝

繼承 多型

在php中是通過類來完成封裝的:

<?php

class something

function getx()

} 當然你可以按自己的喜好進行定義,但最好保持一種標準,這樣會更有效。資料成員在類中使用"var"宣告來定義,在給資料成員賦值之前,它們是沒有型別的。乙個資料成員可以是乙個整數,乙個陣列,乙個相關陣列(associative array)或者是乙個物件。方法在類中被定義成函式形式,在方法中訪問類成員變數時,你應該使用$this->name,否則對乙個方法來說,它只能是區域性變數。

使用new操作符來建立乙個物件:

$obj=new something;

然後你可以使用成員函式通過:

$obj->setx(5);

$see=$obj->getx();

在這個例子中,setx成員函式將5賦值給物件的成員變數x(不是類的),然後getx返回它的值5。可以象:$obj->x=6那樣通過類引用方式來訪問資料成員,這不是乙個很好的oop習慣。我強烈建議通過方法來訪問成員變數。如果你把成員變數看成是不可處理的,並且只通過物件控制代碼來使用方法,你將是乙個好的oop程式設計師。不幸的是,php不支援宣告私有成員變數,所以不良**在php中也是允許的。繼承在php中很容易實現,只要使用extend關鍵字。

<?php

class another extends something

function gety()

} "another"類的物件現在擁有了父類(something)的全部的資料成員及方法,而且還加上了自己的資料成員和方法。

你可以使用

$obj2=new something;

$obj2->setx(6);

$obj2->sety(7);

php現在還不支援多重繼承,所以你不能從兩個或兩個以上類派生出新的類來。你可以在派生類中重定義乙個方法,如果我們在"another"類中重定義了getx方法,我們就不能使 用"something"中的getx方法了。如果你在派生類中宣告了乙個與基派同名的資料成員,那麼當你處理它時, 它將「隱藏」基類的資料成員。

你可以在你的類中定義建構函式。建構函式是乙個與類名同名的方法,當你建立乙個類的物件時會被呼叫,例如:

<?php

class something

function setx($v)

function getx()

} 所以你可以建立乙個物件,通過:

$obj=new something(6);

建構函式會自動地把6賦值給資料變數x。建構函式和方法都是普通的php函式,所以你可以使用預設引數。

function something($x="3",$y="5")

接著:

$obj=new something(); // x=3 and y=5

$obj=new something(8); // x=8 and y=5

$obj=new something(8,9); // x=8 and y=9

預設引數使用c++的方式,所以你不能忽略y的值,而給x乙個預設引數,引數是從左到右賦值的,如果傳入的引數少於要求的引數時,其作的將使用預設引數。

當乙個派生類的物件被建立時,只有它的建構函式被呼叫,父類的建構函式沒被呼叫,如果你想呼叫基類的建構函式,你必須要在派生類的建構函式中顯示呼叫。可以這樣做是因為在派生類中所有父類的方法都是可用的。

<?php

function another()

oop的乙個很好的機制是使用抽象類。抽象類是不能例項化,只能提供給派生類乙個介面。設計者通常使用抽象類來強迫程式設計師從基類派生,這樣可以確保新的類包含一些期待的功能。在php中沒有標準的方法,但是:如果你需要這個特性,可以通過定義基類,並在它的建構函式後加上"die" 的呼叫,這樣就可以保證基類是不可例項化的,現在在每乙個方法(介面)後面加上"die" 語句,所以,如果乙個程式設計師在派生類中沒有覆蓋方法,將引發乙個錯誤。而且因為php 是無型別的,你可能需要確認乙個物件是來自於你的基類的派生類,那麼在基類中增加乙個方法來實義類的身份(返回某種標識id),並且在你接收到乙個物件引數時校驗這個值。當然,如果乙個**不好的程式設計師在派生類中覆蓋了這個方法,這種方法就不起作用了,不過一般問題多發現在懶惰的程式設計師身上,而不是**的程式設計師。

當然,能夠讓基類對程式設計師無法看到是很好的,只要將介面列印出來做他們的工作就可以了。在php中沒有析構函式。

過載(與覆蓋不同)在php中不支援。在oop中,你可以過載乙個方法來實現兩個或重多的方法具有相同的名字,但是有不同數量或型別的引數(這要看語言)。php 是一種鬆散型別的語言,所以通過型別過載不起作用,然而通過引數的個數不同來過載也不起作用。

有時在oop中過載建構函式非常好,這樣你可以通過不同的方法建立物件(傳遞不同數量的引數)。在php中實現它的技巧是:

<?php

class myclass

function myclass1($x)

function myclass2($x,$y)

} 通過在類中的額外的處理,使用這個類對使用者是透明的:

$obj1=new myclass('1'); //將呼叫myclass1

$obj2=new myclass('1','2'); //將呼叫myclass2

有時這個非常好用。

資料庫方面

1.儲存過程和函式的區別 儲存過程是使用者定義的一系列sql語句的集合,涉及特定表或其它物件的任務,使用者可以呼叫儲存過程,而函式通常是資料庫已定義的方法,它接收引數並返回某種型別的值並且不涉及特定使用者表。2.事務是什麼?事務是作為乙個邏輯單元執行的一系列操作,乙個邏輯工作單元必須有四個屬性,稱為...

資料庫方面

一 分頁 1.mysql的分頁查詢 sql 可以是單錶的查詢語句,也可以是多表的聯合查詢語句 firstindex 其實的索引 pagesize 每頁顯示的記錄數 select o.from sql o limit firstindex,pagesize 示例如下 select from t ani...

資料庫方面總結

sql效能優化對於程式設計師來說是乙個很大的挑戰,因為我們往往會遇到這樣的問題 當我們開發完乙個專案,感覺功能上自己測試的體驗真的很不錯,但真正專案上線後,隨著資料的海量增加,系統的客戶體驗越來越差。當然除過框架,不夠合理外,主要還是sql沒能優化,而導致系統越來越慢。因為我在乙個小公司,所以什麼都...