dongshicuo4844 2014-04-14 22:08
浏览 30
已采纳

PHP函数检索mysql表列不起作用

I have this PHP function that I want to use to retrieve a column, "username", from a table called "members". I have used the below function before, and had no problems. But now when I try to use it on a different project it won't work.

Here is the "functions.php" page code:

<?php
include 'connection.php';
function getusername(){
        $query = "SELECT `username` FROM `members` WHERE `ID`=`".$_SESSION['user_id']."`";

        if($result = mysqli_query($con, $query)){
            while($row = mysqli_fetch_assoc($result)){
                return $row['username'];
            }
        }
        mysqli_free_result($result);
}
?>

On my login.php page I have a session variable that stores the user ID from the table in "$_SESSION['user_id']". I have echoed out the user ID so I know that the user ID is set.

On the page that I want the username echoed to, I have this snippet of code:

<?php echo getusername();?>

I also have the functions.php page "included" on the page where I want the username echoed to.

  • 写回答

1条回答 默认 最新

  • dqch34769 2014-04-14 22:20
    关注

    Your $con isn't set inside your function, so mysqli won't work. Additionally you're using backticks around the value you're searching for $_SESSION['user_id'] backticks are for column names, you should use ' around values.

    try it like this:

    <?php
    include 'connection.php';
    function getusername($con){
       $query = "SELECT `username` FROM `members` WHERE `ID`='".$_SESSION['user_id']."'";
       if($result = mysqli_query($con, $query)){
           $row = mysqli_fetch_assoc($result);
           mysqli_free_result($result);
           return $row['username'];
       }
    }
    ?>
    

    Then call it passing $con to the function:

     $username=getusername($con);
    

    On a side note your mysqli_free_result doesn't work if there are results as the return will stop the function. I updated the function a bit for it to work as you expect.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)