儲存為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)