mysql - PHP 的 pdo 方法,怎么返回字段名?

 平凡天使007 发布于 2022-11-17 19:06
$pdo->query($SQL); 

用了之后,可以返回结果集,但是没有字段名,
当然用

$stmt->fetch( PDO::FETCH_ASSOC )

可以把数组的key当成字段名,

但是除了字段名,别的信息都没有,

请问有什么方法像

 object mysqli 的 $result->fetch_field()

一样,可以看到字段的全部信息呢?

2 个回答
  • sql= "SHOW COLUMNS FROM `your_table`"
    

    返回的结果集就是your_table 的所有字段 还有TYPE 等

    2022-11-17 19:26 回答
  • PDO是PDO, Mysqli是Mysqli,我们没办法要求PDO像Mysqli保持一样的结构和设计。
    也许你会觉得mysqli的fetch_field很方便,但是实际上这个方法的使用概率极低,因为通常会读出表的所有字段信息并缓存起来,而不是总是进行字段查询。
    表现最明显的框架如Cakephp,当你用直接编辑数据表的方法增加了一个新字段之后数据并不会被保存到这个字段中,必须先清除缓存的数据表信息才行。

    通过阅读不同的PHP框架,我们可以发现极少会有框架需要开发人员直接调用PDO或者mysqli对象去执行sql,它们往往将其通过DbAdapter之类的接口进行封装。我建议你思考这样做的好处然后优化自己的代码结构。
    你问题中的这个行为通常也不需要封装在db对象中,一般是在Table对象处理,例如

    class Table {
        protected $_tableName;
        public function __construct($tableName);
        protected function _readFieldsPrototype();
        protected function _getCachedFieldsPrototype();
        public function getFieldPrototype($filed);
    }

    仅供参考。

    2022-11-17 19:26 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有