前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >thinkphp框架解决数据库字段大小问题

thinkphp框架解决数据库字段大小问题

作者头像
Mandy的名字被占用了
发布2020-05-19 16:25:26
1.1K0
发布2020-05-19 16:25:26
举报
文章被收录于专栏:菜鸟成长学习笔记

在使用thinkphp的时候,我遇到过数据库字段名大小写的问题,使用M()方法的时候,thinkphp默认会寻找小写的数据库字段,通过以下方法解决了:

就是修改thinkphp的源码中的Library/Db/Driver.class.php文件,把

PDO::ATTR_CASE => PDO::CASE_LOWER 改为 PDO::ATTR_CASE => PDO::CASE_NATURAL,

或者在配置文件里面增加

DB_PARAMS’ => array(\PDO::ATTR_CASE => \PDO::CASE_NATURAL) 这一句。

第一次使用的时候这种解决方法果然可以,但是做另外一个项目的时候却始终不生效,无奈,百度了半天,找到一个方法,因为thinkphp执行的时候默认会把大写转换成小写,所以我们找到它的源码不让它转换就行。

修改Common/functions.php里面的parse_name函数源码为:

function parse_name(name, type=0) { /* if (type) { return ucfirst(preg_replace_callback('/_([a-zA-Z])/', function(match){return strtoupper(match[1]);}, name)); } else { //这里会将数据库表名里的大写转换为 _小写,修改成不转换 return strtolower(trim(preg_replace("/[A-Z]/", "_\\0", name), "_")); }*/ return

其中注释掉的是原来的,未注释是新增的。

修改Library/Think/Model.class.php里面的getTableName函数:

//this->trueTableName = strtolower(this->trueTableName =

修改其中一句,这样就可以解决数据库字段名大写的问题。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2017-01-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 卡二条的技术圈 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档