| 参数 | 描述 |
|---|---|
| array | 必需。规定要使用的输入。 |
| extract_rules |
可选。extract() 函数将检查每个键名是否为合法的变量名,同时也检查和符号表中的变量名是否冲突。 对非法、数字和冲突的键名的处理将根据此参数决定。可以是以下值之一: 可能的值:
|
| prefix |
可选。请注意 prefix 仅在 extract_type 的值是 EXTR_PREFIX_SAME,EXTR_PREFIX_ALL,EXTR_PREFIX_INVALID 或 EXTR_PREFIX_IF_EXISTS 时需要。如果附加了前缀后的结果不是合法的变量名,将不会导入到符号表中。 前缀和数组键名之间会自动加上一个下划线。 |
这个在从数据库中取得一行数据的时候很好用,我们来看下面的例子
?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>
注意标红的语句,在使用extract之后可以直接使用变量,并且变量的名字是字段名字,变量的值是字段的值,这个有点类似于ado.net中从DataReader或DataSet中取得数据的方法Movie.Name = DataSet.Table[o].Row[i]["Name "].ToString() Movie.Name=reader["Name "].ToString();
相比较之下php中的这个extract方式是不是比较的简单直接呢??
到此这篇关于PHP中使用extract函数的文章就介绍到这了,更多相关PHP extract函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
上一篇:PHP实现自动加载机制
下一篇:PHP中token的生成案例