首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLSTATE[HY093]错误

SQLSTATE[HY093]错误
EN

Stack Overflow用户
提问于 2016-07-22 11:22:35
回答 3查看 23关注 0票数 2

我正在尝试用PHP运行以下代码:

代码语言:javascript
复制
$stmt = $db_con->prepare("SELECT * FROM users WHERE email=:email");
$stmt->execute(array(":email"=>$user_email));
$count = $stmt->rowCount();

if($count==0){

$stmt = $db_con->prepare("INSERT INTO users(username,email,password,ip)VALUES(:uname, :email, :password, :ip)");
$stmt->bindParam(":username",$username);
$stmt->bindParam(":email",$useremail);
 $stmt->bindParam(":password",$hasheduserpassword);
$stmt->bindParam(":ip",$userip);

结果,我得到了以下错误:

代码语言:javascript
复制
SQLSTATE[HY093]: Invalid parameter number: parameter was not defined
EN

回答 3

Stack Overflow用户

发布于 2016-07-22 11:31:59

在查询中,您定义了uname,同时设置了一个名为username try的参数

代码语言:javascript
复制
$stmt = $db_con->prepare("INSERT INTO users(username,email,password,ip)VALUES(:username, :email, :password, :ip)");
票数 1
EN

Stack Overflow用户

发布于 2016-07-22 11:33:09

你的error在这里

代码语言:javascript
复制
  $stmt = $db_con->prepare("INSERT INTO users(username,email,password,ip)VALUES(:uname, :email, :password, :ip)");
 //   $stmt->bindParam(":username",$username);// this shoud be uname
 $stmt->bindParam(":uname",$username);
票数 0
EN

Stack Overflow用户

发布于 2016-07-22 12:05:54

错误在这里:

VALUES(:uname,

$stmt->bindParam(":username",$username);

MySql正在查找:username,但找不到,因为您将其命名为:uname

两者必须匹配。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38517641

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档