> 백엔드 개발 > PHP 튜토리얼 > sql 当查询不到记录时返回的是什么

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

WBOY
풀어 주다: 2016-06-06 20:10:59
원래의
1163명이 탐색했습니다.

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

<code>//考虑用户名不存在的情况,提示
$isset_sql="select username from user where username='$username'";

$is_exist=mysql_query($isset_sql); 
if(!$is_exist){
    echo "<script>alert('当前用户不存在,请您检查或选择注册!');window.location.href='article.login.php'</script>";
    exit();
    
}
</code>
로그인 후 복사
로그인 후 복사
<code>$query = "select password from user where username='$username'";
..............</code>
로그인 후 복사
로그인 후 복사

回复内容:

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

<code>//考虑用户名不存在的情况,提示
$isset_sql="select username from user where username='$username'";

$is_exist=mysql_query($isset_sql); 
if(!$is_exist){
    echo "<script>alert('当前用户不存在,请您检查或选择注册!');window.location.href='article.login.php'</script>";
    exit();
    
}
</code>
로그인 후 복사
로그인 후 복사
<code>$query = "select password from user where username='$username'";
..............</code>
로그인 후 복사
로그인 후 복사

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

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

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

<code class="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 ? '已注册' : '未注册';
</code>
로그인 후 복사
관련 라벨:
php
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿