php - sql 当查询不到记录时返回的是什么
天蓬老师
天蓬老师 2017-04-10 17:21:54
[PHP讨论组]

我有一个登陆界面,我想用户输入用户名时,若不存在,则提示注册,但显然我可能不太清楚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'";
..............
天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复(1)
迷茫

首先,不要再用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 ? '已注册' : '未注册';
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号