doupo2157 2014-01-11 23:43
浏览 37
已采纳

使用MySQLi和PHP将行分配给变量

I'm just starting to dab into MySQLi after using MySQL for a while. I found this little code snippet on a tutorial, and just had a question about it (since Google won't return any results for me on this...).

<?php 

$link = mysqli_connect("127.0.0.1", "user", "password", "world"); 

if (!$link)
{
    $error = mysqli_connect_error();
    $errno = mysqli_connect_errno();
    print "$errno: $error
";
    exit();
}

$query = "SELECT Name, Population, Continent FROM Country WHERE Continent=? ORDER BY Name LIMIT 1";

$stmt = mysqli_stmt_init($link);
if(!mysqli_stmt_prepare($stmt, $query))
{
    print "Failed to prepare statement
";
}
else
{
    mysqli_stmt_bind_param($stmt, "s", $continent);

    $continent_array = array('Europe','Africa','Asia','North America');

    foreach($continent_array as $continent)
    {
        mysqli_stmt_execute($stmt);
        $result = mysqli_stmt_get_result($stmt);
        while ($row = mysqli_fetch_array($result, MYSQLI_NUM))
        {
            foreach ($row as $r)
            {
                print "$r ";
            }
            print "
";
        }
    }
}
mysqli_stmt_close($stmt);
mysqli_close($link);
?>

Courtesy of http://www.php.net/manual/en/mysqli-stmt.get-result.php

If I'm understanding this correctly then $r will now do an array of all of the results found in all of the rows called. How can I assign a variable to each row? Can I still do something similar like I did in MySQL?

$username = $row['username'];

Or is there something completely different now?

  • 写回答

2条回答 默认 最新

  • donglu9825 2014-01-11 23:57
    关注

    for example; we have Name, Population, Continent columns that we are selecting.

    Name | Population | Continent
    X    |  1         |  A
    Y    |  2         |  B
    Z    |  3         |  C
    

    and these are the rows returned as result of this query..

    in first iteration, you will get $row like this

    array("Name"=> "X", "Population"=>"1", "Continent"=>"A");
    

    and in second iteration, you will get $row like this

    array("Name"=> "Y", "Population"=>"2", "Continent"=>"B");
    

    and so on. so, you can use it as you mentioned(like $row["Name"])

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能
  • ¥15 Source insight编写代码后使用CCS5.2版本import之后,代码跳到注释行里面
  • ¥50 NT4.0系统 STOP:0X0000007B
  • ¥15 想问一下stata17中这段代码哪里有问题呀
  • ¥15 flink cdc无法实时同步mysql数据
  • ¥100 有人会搭建GPT-J-6B框架吗?有偿
  • ¥15 求差集那个函数有问题,有无佬可以解决