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 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路
  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应