目录
PHP pdo ,为什么不抛出异常?
pdo
php
如下代码:
<code>/** * 写入数据 * * @param string $table * @param array $data * @return int */ public function insert($table ,$data){ try { $sql = "INSERT INTO ".$this->table($table); $columns = $values = ''; foreach( $data as $k=>$v ) { $columns .= "`$k`,"; $values .= ":$k,"; } $columns = rtrim($columns,','); $values = rtrim($values,','); $sql = $sql . " ($columns) VALUES ($values)"; $this->_init($sql ,$data); unset($sql ,$columns ,$values); return $this->insertId(); }catch( \PDOException $e ) { $this->halt($e->getMessage() ,$this->getSql()); return false; } }</code>
登录后复制
登录后复制
会生成如下SQL,
<code>INSERT INTO `dba_tables` (`pid`,`sellerId`,`cardNum`,`processUnit`,`proDate`,`dateOfPro`,`shipDate`,`clinicName`,`doctor`,`created`,`doctorEmail`,`doctorMobile`,`treatTime`,`treatDesc`,`patient`,`patientEmail`,`remark`) VALUES (3,0,'2DFBD1-9E27-CFFD-6846-459CA9E9','第二车间',1460476800,1459008000,1463068800,'某医院','某医生',1460507802,'d@a.com','13333333333','','牙','某某某','c@a.com','asfasdf')</code>
登录后复制
登录后复制
用PHP执行上面的语句,不出现在错误也不抛出异常。
已经开启了pdo的抛出异常模式
<code> $this->_pdo->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);</code>
登录后复制
登录后复制
但是用phpmyadmin执行会出现如下错误
回复内容:
如下代码:
<code>/** * 写入数据 * * @param string $table * @param array $data * @return int */ public function insert($table ,$data){ try { $sql = "INSERT INTO ".$this->table($table); $columns = $values = ''; foreach( $data as $k=>$v ) { $columns .= "`$k`,"; $values .= ":$k,"; } $columns = rtrim($columns,','); $values = rtrim($values,','); $sql = $sql . " ($columns) VALUES ($values)"; $this->_init($sql ,$data); unset($sql ,$columns ,$values); return $this->insertId(); }catch( \PDOException $e ) { $this->halt($e->getMessage() ,$this->getSql()); return false; } }</code>
登录后复制
登录后复制
会生成如下SQL,
<code>INSERT INTO `dba_tables` (`pid`,`sellerId`,`cardNum`,`processUnit`,`proDate`,`dateOfPro`,`shipDate`,`clinicName`,`doctor`,`created`,`doctorEmail`,`doctorMobile`,`treatTime`,`treatDesc`,`patient`,`patientEmail`,`remark`) VALUES (3,0,'2DFBD1-9E27-CFFD-6846-459CA9E9','第二车间',1460476800,1459008000,1463068800,'某医院','某医生',1460507802,'d@a.com','13333333333','','牙','某某某','c@a.com','asfasdf')</code>
登录后复制
登录后复制
用PHP执行上面的语句,不出现在错误也不抛出异常。
已经开启了pdo的抛出异常模式
<code> $this->_pdo->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);</code>
登录后复制
登录后复制
但是用phpmyadmin执行会出现如下错误
回答已删除,见谅
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
刺客信条阴影:贝壳谜语解决方案
1 周前
By DDD
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
在哪里可以找到原子中的起重机控制钥匙卡
1 周前
By DDD

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

PHP 8.4 带来了多项新功能、安全性改进和性能改进,同时弃用和删除了大量功能。 本指南介绍了如何在 Ubuntu、Debian 或其衍生版本上安装 PHP 8.4 或升级到 PHP 8.4

CakePHP 是 PHP 的开源框架。它的目的是使应用程序的开发、部署和维护变得更加容易。 CakePHP 基于类似 MVC 的架构,功能强大且易于掌握。模型、视图和控制器 gu
