PHP中使用extract函數(shù)
php中的extract函數(shù)
extract函數(shù)用來將一個(gè)數(shù)字分解成多個(gè)變量直接使用,下面是W3C的解釋:PHP extract() 函數(shù)從數(shù)組中把變量導(dǎo)入到當(dāng)前的符號(hào)表中。對(duì)于數(shù)組中的每個(gè)元素,鍵名用于變量名,鍵值用于變量值。第二個(gè)參數(shù) type 用于指定當(dāng)某個(gè)變量已經(jīng)存在,而數(shù)組中又有同名元素時(shí),extract() 函數(shù)如何對(duì)待這樣的沖突。本函數(shù)返回成功設(shè)置的變量數(shù)目。
下面表格是參數(shù)說明:
語法
extract(array,extract_rules,prefix)
| 參數(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ù)庫中取得一行數(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方式是不是比較的簡單直接呢??
到此這篇關(guān)于PHP中使用extract函數(shù)的文章就介紹到這了,更多相關(guān)PHP extract函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Yii數(shù)據(jù)模型中rules類驗(yàn)證器用法分析
這篇文章主要介紹了Yii數(shù)據(jù)模型中rules類驗(yàn)證器用法,結(jié)合實(shí)例形式分析了rules類驗(yàn)證器的簡單使用方法,代碼注釋中包含了相關(guān)方法的使用說明,需要的朋友可以參考下2016-07-07
thinkphp在php7環(huán)境下提示Cannot use ‘String’ as class name as it is
這篇文章主要介紹了thinkphp在php7環(huán)境下提示Cannot use ‘String’ as class name as it is reserved的解決方法,涉及thinkPHP針對(duì)php7關(guān)鍵字判定的相關(guān)底層代碼修改技巧,需要的朋友可以參考下2016-09-09
在PHP中靈活使用foreach+list處理多維數(shù)組的方法
這篇文章主要介紹了在PHP中靈活使用foreach+list處理多維數(shù)組的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
Centos6.5和Centos7 php環(huán)境搭建方法
這篇文章主要介紹了Centos6.5和Centos7 php環(huán)境搭建方法的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-05-05
Thinkphp5.0 框架的請(qǐng)求方式與響應(yīng)方式分析
這篇文章主要介紹了Thinkphp5.0 框架的請(qǐng)求方式與響應(yīng)方式,結(jié)合實(shí)例形式分析了thinkPHP5常見的請(qǐng)求方式與響應(yīng)方式實(shí)現(xiàn)技巧與操作注意事項(xiàng),需要的朋友可以參考下2019-10-10

