這個問題其實簡單,你可以在foreach外先設(shè)置一個空數(shù)組,作用是把2016-11-29作為鍵 出現(xiàn)的次數(shù)作為value存儲起來, 代碼
創(chuàng)新互聯(lián)建站專注于網(wǎng)站建設(shè)|成都網(wǎng)站維護|優(yōu)化|托管以及網(wǎng)絡(luò)推廣,積累了大量的網(wǎng)站設(shè)計與制作經(jīng)驗,為許多企業(yè)提供了網(wǎng)站定制設(shè)計服務(wù),案例作品覆蓋護欄打樁機等行業(yè)。能根據(jù)企業(yè)所處的行業(yè)與銷售的產(chǎn)品,結(jié)合品牌形象的塑造,量身建設(shè)品質(zhì)網(wǎng)站。
$tmpArr = array();
foreach($ips as $key = $value)
{
$tmpArr[explode('_',$key)[0]] ++;
}
foreach($tmpArr as $key = $tmp)
{
echo $key." ".$tmp."br";
}
但是具體的數(shù)據(jù)結(jié)構(gòu)要根據(jù)你自己情況來定。
1.首先要全面分析一下你的系統(tǒng)涉及到哪些事物對象,一般來說是為每種對象建立一張表。
2.然后是分析每個事物都有哪些屬性,每個屬性是什么特點,反映在數(shù)據(jù)庫中這個字段是什么類型。
2.然后分析各個事物之間的關(guān)系,哪個是“一”,哪個是“多”。如班級是“一”,學(xué)生是“多”,則要在學(xué)生表中添加一個字段來保存他所屬的班級。
最基本的就是這樣,其他就是一些優(yōu)化的問題。
建議你在網(wǎng)上找一些相關(guān)電子書進行系統(tǒng)的學(xué)些;然后就是可以下載一些程序,想dz,ecshop之類,如果讓你自己來設(shè)計數(shù)據(jù)庫你會怎樣做,然后打開程序看別人是怎么設(shè)計的;看多了就熟悉了。
PHP入門基礎(chǔ)教程大全
PHP于1994年由Rasmus Lerdorf創(chuàng)建,剛剛開始是Rasmus Lerdorf為了要維護個人網(wǎng)頁而制作的一個簡單的用Perl語言編寫的程序。這些工具程序用來顯示 Rasmus Lerdorf 的個人履歷,以及統(tǒng)計網(wǎng)頁流量。后來又用C語言重新編寫,包括可以訪問數(shù)據(jù)庫。他將這些程序和一些表單直譯器整合起來,稱為 PHP/FI。PHP/FI 可以和數(shù)據(jù)庫連接,產(chǎn)生簡單的動態(tài)網(wǎng)頁程序。為幫助大家入門學(xué)習(xí)php,我為大家分享PHP入門知識教程如下:
1、嵌入方法:
類似ASP的%,PHP可以是?php或者是?,結(jié)束符號是?,當(dāng)然您也可以自己指定。
2、引用文件:
引用文件的方法有兩種:require 及 include。
require 的使用方法如 require("MyRequireFile.php"); 。這個函數(shù)通常放在 PHP 程序的最前面,PHP 程序在執(zhí)行前,就會先讀入 require 所指定引入的文件,使它變成 PHP 程序網(wǎng)頁的一部份。常用的函數(shù),亦可以這個方法將它引入網(wǎng)頁中。
include 使用方法如 include("MyIncludeFile.php"); 。這個函數(shù)一般是放在流程控制的處理部分中。PHP 程序網(wǎng)頁在讀到 include 的文件時,才將它讀進來。這種方式,可以把程序執(zhí)行時的流程簡單化。
3、注釋方法:
?php
echo "這是第一種例子。\n" ; // 本例是 C++ 語法的注釋 (PHP的注釋跟C差不多?。?/p>
/* 本例采用多行的
注釋方式 */
echo "這是第二種例子。\n" ;
echo "這是第三種例子。\n" ; # 本例使用 UNIX Shell 語法注釋
?
4、變量類型:
$mystring = "我是字符串" ;
$NewLine = "換行了\n" ;
$int1 = 38 ;
$float1 = 1.732 ;
$float2 = 1.4E+2 ;
$MyArray1 = array( "子" , "丑" , "寅" , "卯" );
這里引出兩個問題,首先PHP變量以$開頭,第二PHP語句以;結(jié)尾,可能ASP程序員會不適應(yīng)。這兩個遺漏也是程序上大多錯誤所在。
5、運算符號:
數(shù)**非法字眼已被屏蔽**算:
符號 ? ? 意義
+ ? ? ? 加法運算
- ? ? ? ?減法運算
* ? ? ? ?乘法運算
/ ? ? ? ?除法運算
% ? ? ?取余數(shù)
++ ? ? 累加
-- ? ? ? 遞減
字符串運算:
運算符號只有一個,就是英文的句號。它可以將字符串連接起來,變成合并的新字符串。類似ASP中的
?
$a = "PHP 4" ;
$b = "功能強大" ;
echo $a.$b;
?
這里也引出兩個問題,首先PHP中輸出語句是echo,第二類似ASP中的%=變量%,PHP中也可以?=變量?。
邏輯運算:
符號 意義
小于
大于
= 小于或等于
= 大于或等于
== 等于
!= 不等于
而且 (And)
and 而且 (And)
或者 (Or)
or 或者 (Or)
xor 異或 (Xor)
! 不 (Not)
學(xué)習(xí)目的:掌握php的流程控制
1、if..else 循環(huán)有三種結(jié)構(gòu)
第一種是只有用到 if 條件,當(dāng)作單純的判斷。解釋成 "若發(fā)生了某事則怎樣處理"。語法如下:
if (expr) { statement }
其中的 expr 為判斷的條件,通常都是用邏輯運算符號當(dāng)判斷的條件。而 statement 為符合條件的執(zhí)行部分程序,若程序只有一行,可以省略大括號 {}。
范例:本例省略大括號。
?php
if ($state==1)echo "哈哈" ;
?
這里特別注意的是,判斷是否相等是==而不是=,ASP程序員可能常犯這個錯誤,= 是賦值。
范例:本例的執(zhí)行部分有三行,不可省略大括號。
?php
if ($state==1) {
echo "哈哈 ;
echo "br" ;
}
?
第兩種是除了 if 之外,加上了 else 的條件,可解釋成 "若發(fā)生了某事則怎樣處理,否則該如何解決"。語法如下
if (expr) { statement1 } else { statement2 } 范例:上面的例子來修改成更完整的處理。其中的 else 由于只有一行執(zhí)行的指令,因此不用加上大括號。
?php
if ($state==1) {
echo "哈哈" ;
echo "br";
}
else{
echo "呵呵";
echo "br";
}
?
第三種就是遞歸的 if..else 循環(huán),通常用在多種決策判斷時。它將數(shù)個 if..else 拿來合并運用處理。
直接看下面的例子
?php
if ( $a $b ) {
echo "a 比 b 大" ;
} elseif ( $a == $b ) {
echo "a 等于 b" ;
} else {
echo "a 比 b 小" ;
}
?
上例只用二層的 if..else 循環(huán),用來比較 a 和 b 兩個變量。實際要使用這種遞歸 if..else 循環(huán)時,請小心使用,因為太多層的循環(huán)容易使設(shè)計的邏輯出問題,或者少打了大括號等,都會造成程序出現(xiàn)莫名其妙的問題。
2、 for 循環(huán)就單純只有一種,沒有變化,它的語法如下
for (expr1; expr2; expr3) { statement }
其中的 expr1 為條件的`初始值。expr2 為判斷的條件,通常都是用邏輯運算符號 (logical operators) 當(dāng)判斷的條件。expr3 為執(zhí)行 statement 后要執(zhí)行的部份,用來改變條件,供下次的循環(huán)判斷,如加一..等等。而 statement 為符合條件的執(zhí)行部分程序,若程序只有一行,可以省略大括號 {}。
下例是用 for 循環(huán)寫的的例子。
?php
for ( $i = 1 ; $i = 10 ; $i ++) {
echo "這是第".$i."次循環(huán)br" ;
}
?
3、 switch 循環(huán),通常處理復(fù)合式的條件判斷,每個子條件,都是 case 指令部分。在實作上若使用許多類似的 if 指令,可以將它綜合成 switch 循環(huán)。
語法如下
switch (expr) { case expr1: statement1; break; case expr2: statement2; break; default: statementN; break; }
其中的 expr 條件,通常為變量名稱。而 case 后的 exprN,通常表示變量值。冒號后則為符合該條件要執(zhí)行的部分。注意要用 break 跳離循環(huán)。
?php
switch ( date ( "D" )) {
case "Mon" :
echo "今天星期一" ;
break;
case "Tue" :
echo "今天星期二" ;
break;
case "Wed" :
echo "今天星期三" ;
break;
case "Thu" :
echo "今天星期四" ;
break;
case "Fri" :
echo "今天星期五" ;
break;
default:
echo "今天放假" ;
break;
}
?
這里需要注意的是break;別遺漏了,default,省略是可以的。
很明顯的,上述的例子用 if 循環(huán)就很麻煩了。當(dāng)然在設(shè)計時,要將出現(xiàn)機率最大的條件放在最前面,最少出現(xiàn)的條件放在最后面,可以增加程序的執(zhí)行效率。上例由于每天出現(xiàn)的機率相同,所以不用注意條件的順序。
學(xué)會構(gòu)建數(shù)據(jù)庫
在PHP中,MY SQL的命令行編輯可能會令初學(xué)者感到很麻煩,不要緊,你下載一個PHPMYADMIN安裝一下,以后建立編輯數(shù)據(jù)庫可以靠它了。
下面說一下它的使用。
進入了phpmyadmin后,我們首先需要建立一個數(shù)據(jù)庫,
Language (*) 這里選擇中文簡體,然后在左邊的 創(chuàng)建一個新的數(shù)據(jù)庫 這里填寫數(shù)據(jù)庫名字,點擊創(chuàng)建即可。
然后在左邊下拉菜單中選擇那個已經(jīng)創(chuàng)建的數(shù)據(jù)庫。在下面的
在數(shù)據(jù)庫 shop 中創(chuàng)建一個新表 :
名字 :
字段數(shù) :
中填寫表名字和大致你認(rèn)為的字段數(shù)(不夠或者多了都不要緊,以后可以再添加或者缺?。?,按執(zhí)行。
然后就可以開始建立表了。
第一欄是字段的名字;第二欄選擇字段類型:
我們常用的是以下幾個:
1)VARCHAR,文本類型
2)INT,整數(shù)類型
3)FLOAT,浮點數(shù)類型
4)DATE,日期型
5)大家或許會問,自動添加的ID在哪里?這個只要選擇INT類型,在后面的額外中選擇 auto_increment 就可以了。
建立了表以后,可以在左邊看到你建立的表,點擊以后,你可以:
1)按右邊的結(jié)構(gòu):查看修改表結(jié)構(gòu)
2)按右邊的瀏覽:查看表中的數(shù)據(jù)
3)按右邊的SQL:運行SQL語句
4)按右邊的插入:插入一行記錄
5)按右邊的清空:刪除表中所有記錄
6)按右邊的刪除:刪除表
還有一個很重要的功能就是導(dǎo)入和導(dǎo)出,當(dāng)我們本機做好了程序和數(shù)據(jù)庫的時候,需要在服務(wù)器上也有一個本地鏡像,如果是ASP的ACCESS簡單了,直接上傳MDB文件即可,如果是SQL SERVER也可以連接遠(yuǎn)端服務(wù)器進行導(dǎo)入。那么MY SQL中你可以導(dǎo)出所有的SQL語句,到了遠(yuǎn)端服務(wù)器的PHPMYADMIN上,創(chuàng)建數(shù)據(jù)庫后按SQL,粘帖你剛才復(fù)制下來的所有本級生成的SQL語句即可。
學(xué)會連接數(shù)據(jù)庫
PHP簡直就是一個函數(shù)庫,豐富的函數(shù)使PHP的某些地方相當(dāng)簡單。建議大家down一本PHP的函數(shù)手冊,總用的到。
我這里就簡單說一下連接MYSQL數(shù)據(jù)庫。
1、mysql_connect
打開 MySQL 服務(wù)器連接。
語法: int mysql_connect(string [hostname] [:port], string [username], string [password]); 返回值: 整數(shù)
本函數(shù)建立與 MySQL 服務(wù)器的連接。其中所有的參數(shù)都可省略。當(dāng)使用本函數(shù)卻不加任何參數(shù)時,參數(shù) hostname 的默認(rèn)值為 localhost、參數(shù) username 的默認(rèn)值為 PHP 執(zhí)行行程的擁有者、參數(shù) password 則為空字符串 (即沒有密碼)。而參數(shù) hostname 后面可以加冒號與端口號,代表使用哪個端口與 MySQL 連接。當(dāng)然在使用數(shù)據(jù)庫時,早點使用 mysql_close() 將連接關(guān)掉可以節(jié)省資源。
2、 mysql_select_db
選擇一個數(shù)據(jù)庫。
語法: int mysql_select_db(string database_name, int [link_identifier]); 返回值: 整數(shù)
本函數(shù)選擇 MySQL 服務(wù)器中的數(shù)據(jù)庫以供之后的資料查詢作業(yè) (query) 處理。成功返回 true,失敗則返回 false。
最簡單的例子就是:
$conn=mysql_connect ("127.0.0.1", "", "");
mysql_select_db("shop");
連接機MY SQL數(shù)據(jù)庫,打開SHOP數(shù)據(jù)庫。在實際應(yīng)用中應(yīng)當(dāng)加強點錯誤判斷。
學(xué)會讀取數(shù)據(jù)
先看兩個函數(shù):
1、mysql_query
送出一個 query 字符串。 語法: int mysql_query(string query, int [link_identifier]); 返回值: 整數(shù)
本函數(shù)送出 query 字符串供 MySQL 做相關(guān)的處理或者執(zhí)行。若沒有指定 link_identifier 參數(shù),則程序會自動尋找最近打開的 ID。當(dāng) query 查詢字符串是 UPDATE、INSERT 及 DELETE 時,返回的可能是 true 或者 false;查詢的字符串是 SELECT 則返回新的 ID 值,當(dāng)返回 false 時,并不是執(zhí)行成功但無返回值,而是查詢的字符串有錯誤。
2、mysql_fetch_object 返回類資料。 語法: object mysql_fetch_object(int result, int [result_typ]); 返回值: 類
本函數(shù)用來將查詢結(jié)果 result 拆到類變量中。若 result 沒有資料,則返回 false 值。
看一個簡單的例子:
?
$exec="select * from user";
$result=mysql_query($exec);
while($rs=mysql_fetch_object($result))
{
echo "username:".$rs-username."br";
}
?
當(dāng)然,表user中有一個username的字段,這就類似asp中的
%
exec="select * from user"
set rs=server.createobject("adodb.recordset")
rs.open exec,conn,1,1
do while not rs.eof
response.write "username:"rs("username")"br"
rs.movenext
loop
%
當(dāng)然先要連接數(shù)據(jù)庫,一般我們 require_once('conn.php');而conn.php里面就是上一次說的連接數(shù)據(jù)庫的代碼。
小小的兩條命令可以完成讀取數(shù)據(jù)的工作了
學(xué)會添加刪除修改數(shù)據(jù)
mysql_query($exec);
單這個語句就可以執(zhí)行所有的操作了,不同的就是$exec這個sql語句
添加:$exec="insert into tablename (item1,item2) values ('".$_POST['item1']."',".$_POST['item1'].")";
刪除:$exec="delete from tablename where...";
修改:$exec="update tablename set item1='".$_POST['item1']."' where ...";
說到這里就要說一下表單和php變量傳遞,如果表單中的一個 input name="item1" type="text" id="item1"
表單以POST提交的,那么處理表單文件就可以用$_POST['item1']得到變量值,同樣以GET提交的就是$_GET['item1']
是不是很簡單?但是通常$exec會有問題,因為可能您的SQL語句會很長,您會遺漏.連接符,或者'來包圍字符型字段。
我們可以注釋mysql_query($exec);語句用echo $exec;代替來輸出$exec以檢查正確性。如果您還不能察覺$exec有什么錯誤的話,可以復(fù)制這個sql語句到phpmyadmin中執(zhí)行,看看它的出錯信息。還有需要注意的是,我們不要使用一些敏感的字符串作為字段名字,否則很可能會出現(xiàn)問題,比如說date什么的。變量的命名,字段的命名遵循一點規(guī)律有的時候?qū)ψ约菏且环N好處,初學(xué)者并不可忽視其重要性。
學(xué)會SESSION的使用
SESSION的作用很多,最多用的就是站點內(nèi)頁面間變量傳遞。
在頁面開始我們要session_start();開啟SESSION;
然后就可以使用SESSION變量了,比如說要賦值就是:$_SESSION['item']="item1";要得到值就是$item1=$_SESSION['item'];,很簡單吧。這里我們可能會使用到一些函數(shù),比如說判斷是不是某SESSION變量為空,可以這么寫:empty($_SESSION['inum'])返回true or false。
下面綜合一下前面所說的我們來看一個登陸程序,判斷用戶名密碼是否正確。
登陸表單是這樣:login.php
table width="100%" height="100%" border="0" align="center" cellpadding="0" cellspacing="0"
tr
form action="checklogin.php" method="post"td align="center" valign="middle"table width="400" border="0" cellpadding="5" cellspacing="1" class="tablebg"
tr class="tdbg"
td colspan="2"p align="center"Administrators Login/p/td
/tr
tr class="tdbg"
tdp align="center"Username/p/td
tdp align="center"
input name="username" type="text" id="username"
/p/td
/tr
tr class="tdbg"
tdp align="center"Password/p/td
tdp align="center"
input name="password" type="password" id="password"
/p/td
/tr
tr class="tdbg"
td colspan="2"p align="center"
input type="submit" name="Submit" value="Submit"
input type="reset" name="Submit2" value="Clear"
/p/td
/tr
/table/td/form
/tr
/table
處理文件是這樣
?php
require_once('conn.php');
session_start();
$username=$_POST['username'];
$password=$_POST['password'];
$exec="select * from admin where username='".$username."'";
if($result=mysql_query($exec))
{
if($rs=mysql_fetch_object($result))
{
if($rs-password==$password)
{
$_SESSION['adminname']=$username;
header("location:index.php");
}
else
{
echo "scriptalert('Password Check Error!');location.href='login.php';/script";
}
}
else
{
echo "scriptalert('Username Check Error!');location.href='login.php';/script";
}
}
else
{
echo "scriptalert('Database Connection Error!');location.href='login.php';/script";
}
?
conn.php是這樣:
?php
$conn=mysql_connect ("127.0.0.1", "", "");
mysql_select_db("shop");
?
由于 $_SESSION['adminname']=$username;我們可以這樣寫驗證是否登陸語句的文件:checkadmin.php
?php
session_start();
if($_SESSION['adminname']=='')
{
echo "scriptalert('Please Login First');location.href='login.php';/script";
}
?
做一個分頁顯示
關(guān)鍵就是用到了SQL語句中的limit來限定顯示的記錄從幾到幾。我們需要一個記錄當(dāng)前頁的變量$page,還需要總共的記錄數(shù)$num
對于$page如果沒有我們就讓它=0,如果有0就讓它也=0,如果超過了總的頁數(shù)就讓他=總的頁數(shù)。
$execc="select count(*) from tablename ";
$resultc=mysql_query($execc);
$rsc=mysql_fetch_array($resultc);
$num=$rsc[0];
這樣可以得到記錄總數(shù)
ceil($num/10))如果一頁10記錄的話,這個就是總的頁數(shù)
所以可以這么寫
if(empty($_GET['page']))
{
$page=0;
}
else
{
$page=$_GET['page'];
if($page0)$page=0;
if($page=ceil($num/10))$page=ceil($num/10)-1;//因為page是從0開始的,所以要-1
}
這樣$exec可以這么寫 $exec="select * from tablename limit ".($page*10).",10";
//一頁是10記錄的
最后我們需要做的就是幾個連接:
a href="xxx.php?page=0"FirstPage/a
a href="xxx.php?page=?=($page-1)?"PrevPage/a
a href="xxx.php?page=?=($page+1)?"NextPage/a
a href="xxx.php?page=?=ceil($num/10)-1?"LastPage/a
注意事項
1、注意不要漏了分號
2、注意不要漏了變量前的$
3、使用SESSION的時候注意不要遺漏session_start();
如果發(fā)生錯誤的時候,可以采用以下方法:
1、如果是SQL語句出錯,就注釋了然后輸出SQL語句,注意也要注釋調(diào)后續(xù)的執(zhí)行SQL語句
2、如果是變量為空,大多是沒有傳遞到位,輸出變量檢查一下,檢查一下表單的id和name
3、如果是數(shù)據(jù)庫連接出錯,檢查是否正確打開MY SQL和是否遺漏了連接語句
4、注意縮進,排除括號不區(qū)配的錯誤
在做大網(wǎng)站的時候,我的思路是先構(gòu)建數(shù)據(jù)庫,確定每一個字段的作用,和表之間的關(guān)系。然后設(shè)計后臺界面,從添加數(shù)據(jù)開始做起,因為添加是否成功可以直接到數(shù)據(jù)庫里面驗證,做好了添加再做顯示的頁面,最后才是兩者的結(jié)合。一般來說后臺就包括添加刪除修改和顯示,后臺沒有問題了,前臺也沒有什么大問題。前臺還需要注意安全性和容錯還有就是輸出格式。
學(xué)會用PHP上傳文件和發(fā)郵件
上傳文件表單必須加上 enctype="multipart/form-data"
和 input type="file" name="file"
下面看一下代碼:
$f=$HTTP_POST_FILES['file'];
$dest_dir='uploads';//設(shè)定上傳目錄
$dest=$dest_dir.'/'.date("ymd")."_".$f['name'];//我這里設(shè)置文件名為日期加上文件名避免重復(fù)
$r=move_uploaded_file($f['tmp_name'],$dest);
chmod($dest, 0755);//設(shè)定上傳的文件的屬性
上傳的文件名為date("ymd")."_".$f['name'] ,可以在以后插入到數(shù)據(jù)庫的時候用到,PHP實際上是把你上傳的文件從臨時目錄移動到指定目錄。move_uploaded_file($f['tmp_name'],$dest);這是關(guān)鍵
至于發(fā)郵件就更加簡單,可以使用mail()函數(shù)
mail("收件人地址","主題","正文","From:發(fā)件人\r\nReply-to:發(fā)件人的地址");
不過mail()需要服務(wù)器的支持,在WINDOWS下還需要配置SMTP服務(wù)器,一般來說外面的LINUX空間都行。
好像上傳文件和發(fā)郵件比ASP簡單很多,只要調(diào)用函數(shù)就可以了。ASP還需要用到服務(wù)器的不同組件比如FSO、JMAIL什么的。
;
電騾上的資源:
課程介紹:
1. 從觀念的引述、程序代碼解析到范例的延伸應(yīng)用,給您最完整的學(xué)習(xí)流程。
2. 實務(wù)網(wǎng)站范例,所有技術(shù)整合運用,實作技巧一覽無遺。
3.在PHP的程序設(shè)計中,以高階的程序設(shè)計,配上靈活的圖解,增加您程序設(shè)計的功力,也能夠了解其演算的過程。
4.MySQL數(shù)據(jù)庫設(shè)計方面,使用數(shù)據(jù)庫的正規(guī)化的方法解決了數(shù)據(jù)表的分割,來建立關(guān)系型數(shù)據(jù)庫,使您有系統(tǒng)的處理現(xiàn)實生活的程序設(shè)計。
5. 深入對象導(dǎo)向程序設(shè)計,全新視界與技巧,網(wǎng)頁開發(fā)更得心應(yīng)手。
6.課程中提供范例教您設(shè)計實用的PHPMySQL數(shù)據(jù)庫,包含加入會員與密碼驗證、聊天室、留言版、討論區(qū)…等。
7.本課程提供一個網(wǎng)上購物系統(tǒng)實例,根據(jù)本實例讓你更多的了解PHPMYSQL在商業(yè)網(wǎng)站設(shè)計中所提供的強大功能,以及如何才能設(shè)計出此類站點。
8.在實戰(zhàn)方面,演示了目前功能最強大的ORACLE 9i for linux最新版9.2.0.4在Linux下的安裝及PHP與Oracle數(shù)據(jù)庫之間的連接。
9.在熱點研究篇里面,列舉了目前最熱門的PHP技術(shù),讓你在學(xué)習(xí)的同時掌握到目前最新的PHP技術(shù)。
老師介紹:
徐文龍 -- 系統(tǒng)架構(gòu)師/系統(tǒng)分析師/高級培訓(xùn)講師,擁有多年軟件及數(shù)據(jù)庫開發(fā)經(jīng)驗,擅長面向?qū)ο蟮脑O(shè)計和分析、數(shù)據(jù)庫建模以及軟件開發(fā)方法,精通.NET、J2EE、C++、PHP、Oracle/SQL SERVER/Informix/DB2 數(shù)據(jù)庫等,對各主流數(shù)據(jù)庫擁有強大的設(shè)計與實現(xiàn)能力,對性能調(diào)優(yōu)有深入的體會和經(jīng)驗,對OOA、OOD、設(shè)計模式、UML有深入的理解。已經(jīng)獲得 OCP,SCJP,MCDBA,MCSE,MCP,TLCE等證書,主講ORACLE9i、SQL Server、 J2EE、.NET、Linux、DB2, 成功授課案例有深圳市國稅局、深圳市福田公路局、香港國興集團、深圳市郵政局、中國農(nóng)行深圳分行、深圳市地稅局、招商銀行、平安保險、廣東核電技術(shù)中心、蛇口ST碼頭等等。
課程安排 :
I 理論篇
第一章 了解PHP(起源,特性,與ASP/ASP.NET和JAVA比較,PHP環(huán)境部署,IDE)
第二章 PHP語法結(jié)構(gòu)
第三章 PHP函數(shù)庫
第四章 了解MySQL
第五章 MySQL語言結(jié)構(gòu)
第六章 MySQL數(shù)據(jù)類型
第七章 MySQL函數(shù)
第八章 MySQL數(shù)據(jù)操縱語言DML
第九章 MySQL數(shù)據(jù)定義語言DDL
第十章 MySQL用戶實用命令
第十一章 MySQL 事務(wù)與鎖定
第十二章 MySQL 全文檢索
第十三章 MySQL 查詢緩存
第十四章 MySQL數(shù)據(jù)庫管理
SQL Server 2000 Job實現(xiàn)、警報實現(xiàn)、真實應(yīng)用最佳實踐。
II 實戰(zhàn)篇 ―― 小試牛刀
第十五章 計數(shù)器
第十六章 以PHP實現(xiàn)文件上載
第十七章 時鐘
第十八章 日歷
第十九章 地址簿
第二十章 圖像處理
第二十一章 表單處理
第二十二章 發(fā)郵件
第二十三章 數(shù)據(jù)庫操作
第十章:SQL Server 2000的復(fù)制體系
第二十四章 Oracle數(shù)據(jù)庫連接
III實戰(zhàn)篇 ―― 高級應(yīng)用
第二十五章 留言本
第二十六章 留言本(Oracle)
第二十七章 在線投票系統(tǒng)
第二十八章 論壇
第二十九章 聊天室
第三十章 網(wǎng)上購物系統(tǒng)
第三十一章 新聞系統(tǒng)