PHP页面传值的问题 我需要在一个列表页中 选中若干条数据然后提交。提交后,需要把选中的数据插入到另外一张表中现在我的做法是把选中数据的ID传过来,再到数据库中查询,并插入新表。感觉很繁琐,我想把这些数据放在一个二维数组当中来传递。这个功能能不能实现?望大虾解答啊 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 额 不好意思 不好意思第一个列表页 从一张info表里读数据字段 :info_id,title,content,description,create_time第二张表 commends字段 : commend_id,info_id,title,content,description,create_time. 写了下。你试试看,能不能用://列表页。每行后面加个checkbook。$result=mysql_query("select * from info");echo '<form action="" method="post">';echo '<table>';while($info=mysql_fetch_assoc($result)){ echo '<tr>'; foreach($info as $v){ echo '<td>{$v}</td>'; } echo '<td><input type="checkbox" name="info_id[]" value="'.$info[info_id].'" /><td>'; echo '</tr>';} echo '<tr><td colspan="6"><input type="submit" value="提交"></td></tr>';echo '</table>';echo '</form>';处理页面:$uid_str=implode(',',$_PSOT['info_id']);$r=mysql_query("select * from info where id in {$uid_str}");while($row=mysql_fetch_assoc($r)){ mysql_query("insert into commends(commend_id,info_id,title,content,description,create_time) values('','{$row[info_id]}','{$row[title]}','{$row[content]}','{$row[description]}','{$row[create_time]}')");}echo '提交成功!'; 晕,后面一段没加进去://列表页。每行后面加个checkbook。$result=mysql_query("select * from info");echo '<form action="" method="post">';echo '<table>';while($info=mysql_fetch_assoc($result)){ echo '<tr>'; foreach($info as $v){ echo '<td>{$v}</td>'; } echo '<td><input type="checkbox" name="info_id[]" value="'.$info[info_id].'" /><td>'; echo '</tr>';} echo '<tr><td colspan="6"><input type="submit" value="提交"></td></tr>';echo '</table>';echo '</form>';处理页面:$uid_str=implode(',',$_PSOT['info_id']);$r=mysql_query("select * from info where id in {$uid_str}");while($row=mysql_fetch_assoc($r)){ mysql_query("insert into commends(commend_id,info_id,title,content,description,create_time) values('','{$row[info_id]}','{$row[title]}','{$row[content]}','{$row[description]}','{$row[create_time]}')");}echo '提交成功!'; 看你需不需要加密无需加密那么就直接用 cookie需要加密那么就用session 不知道select into 可以不,你可以试一试 将数组序列化即可serialize(PHP 4, PHP 5)serialize — 产生一个可存储的值的表示 描述string serialize ( mixed $value )serialize() 返回字符串,此字符串包含了表示 value 的字节流,可以存储于任何地方。 这有利于存储或传递 PHP 的值,同时不丢失其类型和结构。 想要将已序列化的字符串变回 PHP 的值,可使用 unserialize()。serialize() 可处理除了 resource 之外的任何类型。甚至可以 serialize() 那些包含了指向其自身引用的数组。你正 serialize() 的数组/对象中的引用也将被存储。 当序列化对象时,PHP 将试图在序列动作之前调用该对象的成员函数 __sleep()。这样就允许对象在被序列化之前做任何清除操作。类似的,当使用 unserialize() 恢复对象时, 将调用 __wakeup() 成员函数。 Note: 在 PHP 3 中,对象属性将被序列化,但是方法则会丢失。PHP 4 打破了此限制,可以同时存储属性和方法。请参见类与对象中的序列化对象部分获取更多信息。 Example #1 serialize() 示例<?php// $session_data 是包含了当前用户 session 信息的多维数组。// 我们使用 serialize() 在请求结束之前将其存储到数据库中。$conn = odbc_connect ("webdb", "php", "chicken");$stmt = odbc_prepare ($conn, "UPDATE sessions SET data = ? WHERE id = ?");$sqldata = array (serialize($session_data), $PHP_AUTH_USER);if (!odbc_execute ($stmt, &$sqldata)) { $stmt = odbc_prepare($conn, "INSERT INTO sessions (id, data) VALUES(?, ?)"); if (!odbc_execute($stmt, &$sqldata)) { /* 出错 */ }}?> ================================================================================unserialize(PHP 4, PHP 5)unserialize — 从已存储的表示中创建 PHP 的值 描述mixed unserialize ( string $str [, string $callback ] )unserialize() 对单一的已序列化的变量进行操作,将其转换回 PHP 的值。返回的是转换之后的值,可为 integer、float、string、array 或 object。如果传递的字符串不可解序列化,则返回 FALSE。 Note: unserialize_callback_func 指令如果在解序列化的时候需要实例化一个未定义类,则可以设置回调函数以供调用(以免得到的是不完整的 object “__PHP_Incomplete_Class”)。可通过 php.ini、ini_set() 或 .htaccess 定义‘unserialize_callback_func’。每次实例化一个未定义类时它都会被调用。若要禁止这个特性,只需置空此设定。还需要注意的是 unserialize_callback_func 指令是从 PHP 4.2.0 开始提供使用的。 Note: callback 参数是在 PHP 4.2.0 中添加的 若被解序列化的变量是一个对象,在成功地重新构造对象之后,PHP 会自动地试图去调用 __wakeup() 成员函数(如果存在的话)。 Example #1 unserialize_callback_func 示例<?php$serialized_object='O:1:"a":1:{s:5:"value";s:3:"100";}';// unserialize_callback_func 从 PHP 4.2.0 起可用ini_set('unserialize_callback_func','mycallback'); // 设置您的回调函数function mycallback($classname) { // 只需包含含有类定义的文件 // $classname 指出需要的是哪一个类}?> Note: 在 PHP 3 中,解序列化一个对象时是不保存方法的。而 PHP 4 打破了这个限制,同时保存了属性和方法。请参见类与对象中的序列化对象部分获取更多信息。 Example #2 unserialize() 示例<?php// 这里,我们使用 unserialize() 装载来自数据库的 $session_data 数组中的会话数据。// 此例是描述 serialize() 的那个例子的补充。$conn = odbc_connect ("webdb", "php", "chicken");$stmt = odbc_prepare ($conn, "SELECT data FROM sessions WHERE id = ?");$sqldata = array ($PHP_AUTH_USER);if (!odbc_execute ($stmt, &$sqldata) || !odbc_fetch_into ($stmt, &$tmp)) { // 如果执行出错或返回错误,则初始化为空数组 $session_data = array();} else { // 现在我们需要的是 $tmp[0] 中已序列化的数据。 $session_data = unserialize ($tmp[0]); if (!is_array ($session_data)) { // 出错,初始化为空数组 $session_data = array(); }}?> 简单的PHP伪缓存并定时抓取某页面内容 安装php5.3之后发现php文件夹下没有php5apache2.dll,于是安装php5.2,发现也没有 php新手,问个Wamp如何指定数据库 php+mysql一对多的多表联合查询及显示问题 如何保留表单中的value值 高分请教一个关于PHP与MYSQL结合下拉列表的问题 哪位兄弟有php写的在线购物源码 有没有又便宜又好的php空间介绍? 上传权限不够! 我用php作了一个网上商店…… PHP判断关键词个数的问题,PHP盲请教高手! 大家好 哪位大哥能简单明了 或者 比喻的手法,给我讲讲TCP和UDP
字段 : commend_id,info_id,title,content,description,create_time.
$result=mysql_query("select * from info");
echo '<form action="" method="post">';
echo '<table>';
while($info=mysql_fetch_assoc($result)){
echo '<tr>';
foreach($info as $v){
echo '<td>{$v}</td>';
}
echo '<td><input type="checkbox" name="info_id[]" value="'.$info[info_id].'" /><td>';
echo '</tr>';
}
echo '<tr><td colspan="6"><input type="submit" value="提交"></td></tr>';
echo '</table>';
echo '</form>';
处理页面:
$uid_str=implode(',',$_PSOT['info_id']);
$r=mysql_query("select * from info where id in {$uid_str}");
while($row=mysql_fetch_assoc($r)){
mysql_query("insert into commends(commend_id,info_id,title,content,description,create_time) values('','{$row[info_id]}','{$row[title]}','{$row[content]}','{$row[description]}','{$row[create_time]}')");
}
echo '提交成功!';
//列表页。每行后面加个checkbook。
$result=mysql_query("select * from info");
echo '<form action="" method="post">';
echo '<table>';
while($info=mysql_fetch_assoc($result)){
echo '<tr>';
foreach($info as $v){
echo '<td>{$v}</td>';
}
echo '<td><input type="checkbox" name="info_id[]" value="'.$info[info_id].'" /><td>';
echo '</tr>';
}
echo '<tr><td colspan="6"><input type="submit" value="提交"></td></tr>';
echo '</table>';
echo '</form>';处理页面:
$uid_str=implode(',',$_PSOT['info_id']);
$r=mysql_query("select * from info where id in {$uid_str}");
while($row=mysql_fetch_assoc($r)){
mysql_query("insert into commends(commend_id,info_id,title,content,description,create_time) values('','{$row[info_id]}','{$row[title]}','{$row[content]}','{$row[description]}','{$row[create_time]}')");
}
echo '提交成功!';
serialize
(PHP 4, PHP 5)serialize — 产生一个可存储的值的表示 描述
string serialize ( mixed $value )
serialize() 返回字符串,此字符串包含了表示 value 的字节流,可以存储于任何地方。 这有利于存储或传递 PHP 的值,同时不丢失其类型和结构。 想要将已序列化的字符串变回 PHP 的值,可使用 unserialize()。serialize() 可处理除了 resource 之外的任何类型。甚至可以 serialize() 那些包含了指向其自身引用的数组。你正 serialize() 的数组/对象中的引用也将被存储。 当序列化对象时,PHP 将试图在序列动作之前调用该对象的成员函数 __sleep()。这样就允许对象在被序列化之前做任何清除操作。类似的,当使用 unserialize() 恢复对象时, 将调用 __wakeup() 成员函数。 Note: 在 PHP 3 中,对象属性将被序列化,但是方法则会丢失。PHP 4 打破了此限制,可以同时存储属性和方法。请参见类与对象中的序列化对象部分获取更多信息。 Example #1 serialize() 示例<?php
// $session_data 是包含了当前用户 session 信息的多维数组。
// 我们使用 serialize() 在请求结束之前将其存储到数据库中。$conn = odbc_connect ("webdb", "php", "chicken");
$stmt = odbc_prepare ($conn,
"UPDATE sessions SET data = ? WHERE id = ?");
$sqldata = array (serialize($session_data), $PHP_AUTH_USER);
if (!odbc_execute ($stmt, &$sqldata)) {
$stmt = odbc_prepare($conn,
"INSERT INTO sessions (id, data) VALUES(?, ?)");
if (!odbc_execute($stmt, &$sqldata)) {
/* 出错 */
}
}
?> ================================================================================unserialize
(PHP 4, PHP 5)unserialize — 从已存储的表示中创建 PHP 的值 描述
mixed unserialize ( string $str [, string $callback ] )
unserialize() 对单一的已序列化的变量进行操作,将其转换回 PHP 的值。返回的是转换之后的值,可为 integer、float、string、array 或 object。如果传递的字符串不可解序列化,则返回 FALSE。 Note: unserialize_callback_func 指令
如果在解序列化的时候需要实例化一个未定义类,则可以设置回调函数以供调用(以免得到的是不完整的 object “__PHP_Incomplete_Class”)。可通过 php.ini、ini_set() 或 .htaccess 定义‘unserialize_callback_func’。每次实例化一个未定义类时它都会被调用。若要禁止这个特性,只需置空此设定。还需要注意的是 unserialize_callback_func 指令是从 PHP 4.2.0 开始提供使用的。
Note: callback 参数是在 PHP 4.2.0 中添加的
若被解序列化的变量是一个对象,在成功地重新构造对象之后,PHP 会自动地试图去调用 __wakeup() 成员函数(如果存在的话)。 Example #1 unserialize_callback_func 示例<?php
$serialized_object='O:1:"a":1:{s:5:"value";s:3:"100";}';// unserialize_callback_func 从 PHP 4.2.0 起可用
ini_set('unserialize_callback_func','mycallback'); // 设置您的回调函数function mycallback($classname) {
// 只需包含含有类定义的文件
// $classname 指出需要的是哪一个类
}
?> Note: 在 PHP 3 中,解序列化一个对象时是不保存方法的。而 PHP 4 打破了这个限制,同时保存了属性和方法。请参见类与对象中的序列化对象部分获取更多信息。 Example #2 unserialize() 示例<?php
// 这里,我们使用 unserialize() 装载来自数据库的 $session_data 数组中的会话数据。
// 此例是描述 serialize() 的那个例子的补充。$conn = odbc_connect ("webdb", "php", "chicken");
$stmt = odbc_prepare ($conn, "SELECT data FROM sessions WHERE id = ?");
$sqldata = array ($PHP_AUTH_USER);
if (!odbc_execute ($stmt, &$sqldata) || !odbc_fetch_into ($stmt, &$tmp)) {
// 如果执行出错或返回错误,则初始化为空数组
$session_data = array();
} else {
// 现在我们需要的是 $tmp[0] 中已序列化的数据。
$session_data = unserialize ($tmp[0]);
if (!is_array ($session_data)) {
// 出错,初始化为空数组
$session_data = array();
}
}
?>