Aay*_*ush 7 php mysql arrays session
//从问题表中返回10个问题
$result = mysqli_query($con,"SELECT question FROM questions ORDER BY rand() LIMIT 10' ");
while($row = mysqli_fetch_row($result))
{
$que[]=$row[0];
}
Run Code Online (Sandbox Code Playgroud)
现在我需要将这整套存储$que[]在一个会话变量中.(即10个问题)
像这样的东西
$_SESSION['question'] = $que[];
$my_array[] = $_SESSION['question'];
Run Code Online (Sandbox Code Playgroud)
所以$my_array[0]返回第一个问题,$my_array[1]返回第二个问题,并像那样.
(Thanx提前帮助)
Pra*_*dra 10
分配
$_SESSION['question'] = $que;
Run Code Online (Sandbox Code Playgroud)
print_r($_SESSION['question'][0]); 会给你第一个问题.
你几乎是正确的,你只需要[]添加到数组时.
$_SESSION['question'] = $que;
Run Code Online (Sandbox Code Playgroud)
确保首先进行会话,将其置于脚本顶部将启动会话(如果尚不存在):
if( !isset( $_SESSION ) ) {
session_start();
}
Run Code Online (Sandbox Code Playgroud)
把它拉回来:
$array = $_SESSION['question']; //Assigns session var to $array
print_r($array); //Prints array - Cannot use echo with arrays
Run Code Online (Sandbox Code Playgroud)
最后的补充
要迭代数组,通常可以使用for或foreach.对于语句,只有当数组键是增量(0,1,2,3等)而没有任何间隙时才能正常工作.
for( $x = 0, $max = count($array); $x < $max; ++$x ) {
echo $array[$x];
}
foreach( $array as &$value ) {
echo $value;
}
Run Code Online (Sandbox Code Playgroud)
两者都是为了表现而写的.非常重要的是要知道在使用引用时(&$value注意&)如果编辑引用,原始值会发生变化.如果不通过引用使用,它将创建值的副本.例如:
//Sample Array
$array = array( '0' => 5, '1' => 10 );
//By Reference
foreach( $array as &$value ) {
$value += 2; //Add 2 to each value
echo $value; //Echos 7 and 12, respectively
}
print_r( $array ); //Now equals array( '0' => 7, '1' => 12 )
//Normal Method
foreach( $array as $value ) {
$value += 2; //Add 2 to each value
echo $value; //Echos 7 and 12, respectively
}
print_r( $array ); //Still equals array( '0' => 5, '1' => 10 )
Run Code Online (Sandbox Code Playgroud)
引用速度更快,但如果您在保持原始数组完整的同时修改值,则不会更快.