| 參數(shù) | 描述 |
|---|---|
| array | 必需。規(guī)定要使用的輸入。 |
| extract_rules |
可選。extract() 函數(shù)將檢查每個(gè)鍵名是否為合法的變量名,同時(shí)也檢查和符號(hào)表中的變量名是否沖突。 對(duì)非法、數(shù)字和沖突的鍵名的處理將根據(jù)此參數(shù)決定??梢允且韵轮抵唬?/p> 可能的值:
|
| 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ù)庫(kù)中取得一行數(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)紅的語(yǔ)句,在使用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)河 怒江 洛陽(yáng) 酒泉 赤峰 金華 白城 溫州
巨人網(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)。