栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

mySQLi准备的语句无法get_result()

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

mySQLi准备的语句无法get_result()

通过一些检查,即使我的主机上安装了mysqli,显然mysqlnd驱动程序也不存在。因此,不能使用get_result()(PHP手册将get_result定义为mysqlnd依赖),取而代之的是,需要做一些额外的编码以按我希望的方式处理我的结果。

因此,我决定尝试并了解PDO的工作原理,几分钟之内,瞧!

将上面的代码替换为:

function checkUsernameEmailAvailability($username, $email) {echo 'pdo about to be created';$dsn = 'mysql:dbname='.C_base.';host='.C_HOST;$user = C_USER;$password = C_PASS;try {    $dbh = new PDO($dsn, $user, $password);} catch (PDOException $e) {    echo 'Connection failed: ' . $e->getMessage();}$params = array(':username' => $username, ':email' => $email);try{$sth = $dbh->prepare('SELECt username,email FROM tb_users WHERe username = :username OR email = :email ');} catch(PDOException $e) {    echo 'Prepare failed: ' . $e->getMessage();}try{$sth->execute($params);} catch(PDOException $e) {    echo 'Execute failed: ' . $e->getMessage();}$result = $sth->fetch(PDO::FETCH_ASSOC);print_r($result);}

我可以想到的错误检查量不多,而且一开始就完全没有问题!

最终密码

function checkUsernameEmailAvailability($username, $email) {    $dsn = 'mysql:dbname='.C_base.';host='.C_HOST;    $user = C_USER;    $password = C_PASS;    new PDO($dsn, $user, $password);    $params = array(':username' => $username, ':email' => $email);    $sth = $dbh->prepare('SELECt username,email FROM tb_users WHERe username = :username OR email = :email ');    $sth->execute($params);    $result = $sth->fetch(PDO::FETCH_ASSOC);    print_r($result);}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/376248.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号