參數(shù) | 描述 |
---|---|
array | 必需。規(guī)定要使用的輸入。 |
extract_rules |
可選。extract() 函數(shù)將檢查每個(gè)鍵名是否為合法的變量名,同時(shí)也檢查和符號(hào)表中的變量名是否沖突。 對(duì)非法、數(shù)字和沖突的鍵名的處理將根據(jù)此參數(shù)決定。可以是以下值之一: 可能的值:
|
prefix |
可選。請(qǐng)注意 prefix 僅在 extract_type 的值是 EXTR_PREFIX_SAME,EXTR_PREFIX_ALL,EXTR_PREFIX_INVALID 或 EXTR_PREFIX_IF_EXISTS 時(shí)需要。如果附加了前綴后的結(jié)果不是合法的變量名,將不會(huì)導(dǎo)入到符號(hào)表中。 前綴和數(shù)組鍵名之間會(huì)自動(dòng)加上一個(gè)下劃線。 |
這個(gè)在從數(shù)據(jù)庫中取得一行數(shù)據(jù)的時(shí)候很好用,我們來看下面的例子
?php $db = mysql_connect('localhost','root','Ctrip07185419') or die('can not connect to mysql'); mysql_select_db('moviesite',$db) or die(mysql_error($db)); mysql_query('set names gbk',$db); if(isset($_GET['action']) $_GET['action'] == 'edit') { $query = 'SELECT movie_name,movie_type,movie_year,movie_leadactor,movie_director FROM movie WHERE movie_id='.$_GET['id']; //echo $query; $result = mysql_query($query , $db) or die(mysql_error($db)); extract(mysql_fetch_assoc($result)); } else { $movie_name=''; $movie_type=0; $movie_year=date('Y'); $movie_leadactor=0; $movie_director=0; } ?> html> head> title>?php echo ucfirst($_GET['action']);?> Movie/title> style type="text/css">/style> /head> body> form action="commit.php?action=?php echo $_GET['action'];?>type=movie" method="post"> table> tr> td>Movie Name/td> td>input type="text" name="movie_name" value="?php echo $movie_name;?>"/>/td> /tr> tr> td>Movie Type/td> td>select name="movie_type" id=""> ?php $query = 'select movietype_id,movietype_label from movietype order by movietype_label'; $result = mysql_query($query , $db) or die(mysql_error($db)); while($row = mysql_fetch_assoc($result)) { if($row['movietype_id'] == $movie_type) { echo 'option value="'.$row["movietype_id"].'" selected="selected">'.$row["movietype_label"].'/option>'; } else { echo 'option value="'.$row["movietype_id"].'">'.$row["movietype_label"].'/option>'; } } ?> /select>/td> /tr> tr> td>Movie Year/td> td>select name="movie_year" id=""> ?php for($yr = date('Y');$yr>1970;$yr--) { if($yr == $movie_year) { echo 'option value="'.$yr.'" selected="selected">'.$yr.'/option>'; } else { echo 'option value="'.$yr.'">'.$yr.'/option>'; } } ?> /select>/td> /tr> tr> td>Lead actor/td> td>select name="movie_leadactor" id=""> ?php $query = 'select people_id,people_fullname from people where people_isactor = 1 order by people_fullname'; $result = mysql_query($query,$db) or die(mysql_error($db)); while($row = mysql_fetch_assoc($result)) { if($row["people_id"] == $movie_leadactor) { echo 'option value="'.$row["people_id"].'" selected="selected">'.$row["people_fullname"].'/option>'; } else { echo 'option value="'.$row["people_id"].'">'.$row["people_fullname"].'/option>'; } } ?> /select>/td> /tr> tr> td>Director/td> td>select name="movie_director" id=""> ?php $query = 'select * from people where people_isdirector=1 order by people_fullname'; $result = mysql_query($query , $db) or die(mysql_error($db)); while($row = mysql_fetch_assoc($result)) { if($row['people_id'] == $movie_director) { echo 'option value="'.$row['people_id'].'" selected="selected">'.$row["people_fullname"].'/option>'; } else { echo 'option value="'.$row['people_id'].'">'.$row["people_fullname"].'/option>'; } } ?> /select>/td> /tr> tr> td colspan="2" style="text-align:center"> ?php if('edit' == $_GET['action']) { echo 'input type="hidden" value="'.$_GET["id"].'" name="movie_id"/>'; } ?> input type="submit" name="submit" value="?php echo ucfirst($_GET['action']);?>"/> /td> /tr> /table> /form> /body> /html>
注意標(biāo)紅的語句,在使用extract之后可以直接使用變量,并且變量的名字是字段名字,變量的值是字段的值,這個(gè)有點(diǎn)類似于ado.net中從DataReader或DataSet中取得數(shù)據(jù)的方法Movie.Name = DataSet.Table[o].Row[i]["Name "].ToString() Movie.Name=reader["Name "].ToString();
相比較之下php中的這個(gè)extract方式是不是比較的簡(jiǎn)單直接呢??
到此這篇關(guān)于PHP中使用extract函數(shù)的文章就介紹到這了,更多相關(guān)PHP extract函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
標(biāo)簽:七臺(tái)河 怒江 洛陽 酒泉 赤峰 金華 白城 溫州
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP中使用extract函數(shù)》,本文關(guān)鍵詞 PHP,中,使用,extract,函數(shù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。