MySQL 临时表在我们需要保存一些临时数据时是非常有用的。临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。 临时表在MySQL 3.23版本中添加,如果你的MySQL版本低于 3.23版本就无法使用MySQL的临时表。不过现在一般很少有再使用这么低版本的MySQL数据库服务了。 MySQL临时表只在当前连接可见,如果你使用PHP脚本来创建MySQL临时表,那没当PHP脚本执行完成后,该临时表也会自动销毁。 如果你使用了其他MySQL客户端程序连接MySQL数据库服务器来创建临时表,那么只有在关闭客户端程序时才会销毁临时表,当然你也可以手动销毁。…
April 29, 2015
PHP: extract 将数组array的key变为变量 ( extract函数的定义和用法 )
将键值 “Cat”、”Dog” 和 “Horse” 赋值给变量 $a、$b 和 $c:
<?php $a = "Original"; $my_array = array("a" => "Cat","b" => "Dog", "c" => "Horse"); extract($my_array); echo "\$a = $a; \$b = $b; \$c = $c"; ?>
定义和用法
extract() 函数从数组中将变量导入到当前的符号表。
该函数使用数组键名作为变量名,使用数组键值作为变量值。针对数组中的每个元素,将在当前符号表中创建对应的一个变量。
第二个参数 type 用于指定当某个变量已经存在,而数组中又有同名元素时,extract() 函数如何对待这样的冲突。
该函数返回成功导入到符号表中的变量数目。
语法
extract(array,extract_rules,prefix)
参数 | 描述 |
---|---|
array | 必需。规定要使用的数组。 |
extract_rules | 可选。extract() 函数将检查每个键名是否为合法的变量名,同时也检查和符号表中已存在的变量名是否冲突。对不合法和冲突的键名的处理将根据此参数决定。
可能的值:
|
prefix | 可选。请注意 prefix 仅在 extract_type 的值是 EXTR_PREFIX_SAME,EXTR_PREFIX_ALL,EXTR_PREFIX_INVALID 或 EXTR_PREFIX_IF_EXISTS 时需要。如果附加了前缀后的结果不是合法的变量名,将不会导入到符号表中。
前缀和数组键名之间会自动加上一个下划线。 |
技术细节
返回值: | 返回成功导入到符号表中的变量数目。 |
PHP 版本: | 4+ |
更新日志: | extract_rules 的值 EXTR_REFS 是在 PHP 4.3 中新增的。
extract_rules 的值 EXTR_IF_EXISTS 和 EXTR_PREFIX_IF_EXISTS 是在 PHP 4.2 中新增的。 自 PHP 4.0.5 起,该函数返回成功导入到符号表中的变量数目。 extract_rules 的值 EXTR_PREFIX_INVALID 是在 PHP 4.0.5 中新增的。 自 PHP 4.0.5 起,extract_rules 的值 EXTR_PREFIX_ALL 也包含数字变量。 |
实例:
<?php $a = "Original"; $my_array = array("a" => "Cat", "b" => "Dog", "c" => "Horse"); extract($my_array, EXTR_PREFIX_SAME, "dup"); echo "\$a = $a; \$b = $b; \$c = $c; \$dup_a = $dup_a"; // 结果为: $a = Original; $b = Dog; $c = Horse; $dup_a = Cat ?>
<?php extract($_POST); //相当于$username = $_POST['username']; //$password = $_POST['password']; ?>
转自: http://www.w3school.com.cn/php/func_array_extract.asp
很实用的一个例子: extract array into global variables
function foo() { $vars = array('aa' => 11, 'bb' => 22); $GLOBALS += $vars; } foo(); echo $aa;
function extract_array($array=false) { //if($array AND is_array($array)) extract($array); //else { extract($_POST); extract($_GET); } if($array AND is_array($array)) $GLOBALS += $array; else{ $GLOBALS += $_POST; $GLOBALS += $_GET; } }
更多参考:
PHP: 用readonly取代disabled来获取input值 submit a disabled input in a form could not get value
PHP: 关键字global 和 超全局变量$GLOBALS的用法、解释、区别
本文: PHP: extract 将数组array的key变为变量 ( extract函数的定义和用法 )