• 技术文章 >后端开发 >php教程

    sql 当查询不到记录时返回的是什么

    2016-06-06 20:10:59原创282
    我有一个登陆界面,我想用户输入用户名时,若不存在,则提示注册,但显然我可能不太清楚sql语句,所以一直有问题,调试时即使输入了数据库中不存在的用户名,也不会提示,望解答
    if (!empty($_POST['login'])) {

    //考虑用户名不存在的情况,提示
    $isset_sql="select username from user where username='$username'";
    
    $is_exist=mysql_query($isset_sql); 
    if(!$is_exist){
        echo "";
        exit();
        
    }
    
    $query = "select password from user where username='$username'";
    ..............

    回复内容:

    我有一个登陆界面,我想用户输入用户名时,若不存在,则提示注册,但显然我可能不太清楚sql语句,所以一直有问题,调试时即使输入了数据库中不存在的用户名,也不会提示,望解答
    if (!empty($_POST['login'])) {

    //考虑用户名不存在的情况,提示
    $isset_sql="select username from user where username='$username'";
    
    $is_exist=mysql_query($isset_sql); 
    if(!$is_exist){
        echo "";
        exit();
        
    }
    
    $query = "select password from user where username='$username'";
    ..............

    首先,不要再用mysql_*一系列的连接方式了。请改成PDO或者MySQLi

    然后你的问题答案:mysql_query只是发送查询请求到数据库,你还需要执行mysql_fetch_assoc来获取数据库的回应。

    Warning: mysql_* 已经被PHP正式移除。

    // 连接数据库部分
    $db = new PDO('mysql:host=localhost;dbname=数据库名称','用户名','密码');
    $db->exec('set names utf8');
    
    // 使用预处理解决SQL注入漏洞的问题
    $stmt = $db->prepare('select username from user where username = :username');
    // 绑定参数
    $stmt->bind(':username',$username,PDO::PARAM_STR);
    // 执行查询
    $stmt->execute();
    // 获取数据
    $user = $stmt->fetchColumn();
    echo $user ? '已注册' : '未注册';
    
    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:php
    上一篇:请大神分开解释一下SQL语句 下一篇:laravel 连接数据库超时
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• php在apache中的3种工作模式解决思路• sql+mysql 随机数据读取-进阶有关问题• PHP session 丢失 有关问题 • input button 一个很严重的有关问题• php大文件上传如何实现的
    1/1

    PHP中文网