p第四天PHP和MYSQLWeb開發

來源:互聯網
上載者:User

儲存為inc檔案,放置在文檔樹之外的一個檔案夾中...

網上的說法是  
.inc.php  來表示被包含的檔案

require(),include()

如果一個檔案不希望被解析,使用readfile()..

在每一個頁面加上head和footer..

使用配置php.ini中的auto_prepend_file和auto_append_file來弄兩個檔案分別加入頭部和尾部.

 

定義函數的參數列表,給一個初值就說明是可選的

範圍

局部變數   函數中定義使用

全域變數   函數外部定義

超級全域變數  

require()和include()不影響範圍

使用global來修飾變數為全域變數

unset()刪除變數

很好的例子:

<?php
function doxx(){
 echo 'inner doxx $var='.$var;
 echo "<br
/>";
 $var = "doxx2";
 echo 'inner doxx $var='.$var;
 echo "<br
/>";
}
doxx();
$var = "doxx1";
echo 'outer doxx $var='.$var;
?>

inner doxx
$var=                   
doxx內的變數是新的,未賦值的
inner doxx
$var=doxx2              
局部變數賦值
outer doxx
$var=doxx1              
全域變數賦值

 

參數的引用傳遞和值傳遞

function addone(&$value){ 
//引用傳遞
  $value++;
}
$one = 0;
addone($one);
echo $one;
echo "<br />";
function addone2($value){  //新局部變數
 $value++;
}
$one = 0;
addone2($one);
echo $one;

顯示:1 0

名稱空間....

 

第六章

物件導向的PHP

建構函式  __construct()  兩個底線

解構函式
__destruct()   
兩個底線

使用類的屬性

在類內部用$this這個特殊指標,當有屬性attribute時,通過$this->attribute來訪問和或操作設定

封裝  

定義__get($name)和__set($name,$value)方法,當使用上的方法來設定擷取屬性時就會調用相應的方法.....

擦    
$執行個體->$屬性與$執行個體->屬性 
有什麼區別

類中的操作的調用    

 

感覺上就像是使用 -> 替代了 .

 

尼瑪,沒有重載,只有重寫,只有子類覆蓋父類方法.

 

使用物件導向的方式來編寫一個頁面類.

class page...

 

 

PHP物件導向進階特性....

1.使用Per-class常量.....

這個常量可以在不需要初始化該類的情況下使用,可以通過使用::操作符指定常量所屬的類來訪問Per-Class常量

2.靜態方法  static 
不能使用$this關鍵字

3.類型檢查和類型提示...    
參數前面加上 類名 限定 類或子類.

4.延遲靜態繫結  @&%^&%#^@&%^@%$8

5.複製對象  
使用clone關鍵字   
$a= clone $b;

類中有__clone()方法,使用clone關鍵字會調用該方法.主要是處理類中含有對象引用的情況

6.抽象類別

7.__call()用於重載(真正的重載....但是貌似沒什麼用)

__call(方法名,參數){裡面判斷怎麼調用方法,傳遞參數,實際上不需要實現 方法名代表的方法}

8.__autoload()方法單獨的函數,不是類的方法  
將在執行個體化一個未被申明的類時調用..

用來嘗試包含或請求人和用來初始化所需類的檔案

不使用包含檔案的require()和include().

直接寫 function __autoload($name){require_once $name.'.php';}

 http://www.php.net/autoload

9.實現迭代器和迭代.... 

http://www.php.net/iterator

10.將類轉換為字串   
__toString()函數....

11.反射.....

 

 

第七章

錯誤和異常處理

 ......

還是個新東西,,,主要是通過重寫__toString()來顯示...

 

第二章

使用MYsql.......

 

 

USING

用於表串連時給定串連條件(可以理解為簡寫形式),如

   SELECT *
FROM table1JOIN table2
ON table1.id = table2.id

使用 USING 可以寫為

   SELECT *
FROM table1JOIN table2
USING(id)

就這麼簡單

 

 

首先我們做兩張表:員工資訊表和部門資訊表,在此,表的建立只為講述串連的概念,所以欄位非常的簡單 
EmployeeTB(員工資訊表):

  employeeid employeename deptid 
0001 張三 01 
0002 李四 01 
0003 王五 02 
0004 趙六 02 
0005 鄭七 NULL

  DeptTB(部門資訊表) 
deptid deptname 
01 技術部 
02 市場部 
03 工程部

  我們現在需要進行串連查詢,串連兩張表檢索資料  。分別檢索員工資訊表的員工編號、員工姓名和部門資訊表中的部門名稱  。 

顯然,兩個表的串連條件是 員工表的部門編號=部門表的部門編號 
注意:鄭七不屬於任何部門(新來的員工,還沒有分配到任何的部門),而工程部不存在任何的員工(比如是一個新成立的部門,還沒有員工)

  MySQL串連查詢:

  1、內串連查詢 
我們可以有兩種方式,這兩種是等效的 
一種是:SELECT e.employeeid,e.employeename,d.deptname FROM
EmployeeTB AS e,DeptTB AS d WHERE
e.deptid=d.deptid 
另外一個是:SELECT e.employeeid,e.employeename,d.deptname FROM EmployeeTB
AS e INNER JOIN DeptTB AS d ON
e.deptid=d.deptid 
檢索的結果都是:

  employeeid employeename deptname 
0001 張三 技術部 
0002 李四 技術部 
0003 王五 市場部 
0004 趙六 市場部

  而“鄭七”和“工程部”的資訊是不會檢索出來  。因為採用內串連計算的時候必須要保證串連的條件e.deptid=d.deptid匹配,結果才會被檢索出來  。當我們串連兩張檢索資料的時候,檢索的方式是首先漸進式掃描“員工資訊表”中的記錄,然後根據串連條件來決定此記錄是否被檢索  。比如對於張三,這條記錄的deptid是01(部門編號),它在部門表中能找到和它匹配的編號01,而編號01的部門名稱(deptname)是“技術部”所以張三這條記錄會被檢索,最終的結果肯定是:

  0001 張三 技術部

  同樣,李四、王五、趙六也能  。但是鄭七的部門編號是NULL,它在部門資訊表中找不到匹配的項(因為部門資訊表中不存在部門編號為NULL的部門),所以鄭七不會被檢索  。 

同理,沒有任何人員的部門編號為03,所以工程部的記錄也不會被檢索

  2、左外連接 
但是有些情況下,我們需要知道所有員工的資訊,即使他不屬於任何部門  。這樣我們就可以採用外串連,在這裡為左外串連,也就是串連中的左表的表中的記錄,無論能不能在右表中找到匹配的項,都要檢索,如果沒有匹配的項目,那麼右表中的欄位值為NULL(空),在這裡就代表,此員工不屬於任何部門  。 

檢索語句為: 
SELECT e.employeeid,e.employeename,d.deptname FROM EmployeeTB AS e
LEFT OUTER JOIN DeptTB AS d ON
e.deptid=d.deptid 
檢索的結果都是:

  employeeid employeename deptname 
0001 張三 技術部 
0002 李四 技術部 
0003 王五 市場部 
0004 趙六 市場部 
0005 鄭七 NULL

  但是在這裡,工程部同樣不會被檢索,因為,deptname是在串連的右邊的表中,“工程部”在左表中不存在任何的記錄,所以不會被檢索  。這裡關注的是“串連中的左邊的表”

  3、右外串連 
有時,我們需要知道,全部部門的資訊,即使它沒有任何的員工  。在我們的查詢中部門表在串連的右邊,如果我們想知道右邊表中的所有記錄資訊,那麼就可以採用右外串連,如果此記錄在左邊的表中找不到匹配項,則相應欄位(employeeid,employeename)為NULL 

檢索語句為: 
SELECT e.employeeid,e.employeename,d.deptname FROM EmployeeTB AS e
RIGHT OUTER JOIN DeptTB AS d ON
e.deptid=d.deptid 
檢索的結果都是:

  employeeid employeename deptname 
0001 張三 技術部 
0002 李四 技術部 
0003 王五 市場部 
0004 趙六 市場部 
NULL NULL 工程部

  但在這裡,鄭七是不會被檢索了,因為它在右表中找不到匹配項,這裡關注的是“串連中的右邊的表”

  4、完全外串連 
如果我們想知道所有的記錄呢?無論員工有沒有部門,部門有沒有員工,我們都需要檢索  。這裡就可以使用完全外串連  。關注串連中的兩部分  。如果沒有部門,部門為空白,沒有員工,員工資訊為空白  。 

檢索語句為: 
SELECT e.employeeid,e.employeename,d.deptname FROM EmployeeTB AS e
FULL OUTER JOIN DeptTB AS d ON
e.deptid=d.deptid 
檢索的結果都是:

  employeeid employeename deptname 
0001 張三 技術部 
0002 李四 技術部 
0003 王五 市場部 
0004 趙六 市場部 
0005 鄭七 NULL 
NULL NULL 工程部

----------------------------------------------------------------------------------------------

來自http://hi.baidu.com/linuxjs/blog/item/dafde4f3f8e1430eb9382013.html

----------------------------------------------------------------------------------------------

修改表

alter tablename doxx

change 修改列名

modify 修改資料類型

add 

drop

我的更多文章:
  • _call(2012-05-24 19:21:32)
  • page.php(2012-05-24 16:17:27)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.