duandan4680 2017-01-23 09:22
浏览 48
已采纳

在php函数中使用变量返回值

I have a function that is supposed to give me a staff members name from his ID number so my php is like this

$staffId = $_GET['staff_id'];
$staff = staff_load($staffId);

and my function is like this

function staff_load()
{
$dbh = dbh_get(); //connects to database

$sql = 'select user_name from user_staff where user_id = ?';
$stmt = $dbh->prepare($sql);
$stmt->execute();
$staff = $stmt->fetch();

dbh_free($dbh); //disconnects from database
return $staff;
}

But when I try and use the $staff variable, it shows nothing. I can't work out what I'm doing wrong. I've tried a bunch of variants and gotten nowhere except frustrated.

<td>Book for ' . $staff . '</td>
  • 写回答

2条回答 默认 最新

  • doudi4621 2017-01-23 09:29
    关注

    First, you forgot to include the parameter in your function definition:

    function staff_load($id) {
    

    Then you need to bind the parameter of the prepared statement.

    $sql = 'select user_name from user_staff where user_id = $1';
    $stmt = $dbh->prepare($sql);
    $stmt->execute(array($id));
    

    Next, fetch() returns an array, you need to extract the user_name element from the array:

    $row = $stmt->fetch();
    if ($row) {
        $staff = $row['user_name'];
    } else {
        $staff = false;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥100 求数学坐标画圆以及直线的算法
  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决