在使用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 $name;}
其中注释掉的是原来的,未注释是新增的。修改Library/Think/Model.class.php里面的getTableName函数:
//$this->trueTableName = strtolower($tableName); //这里会将表名转换成小写,修改成不转换$this->trueTableName = $tableName;
修改其中一句,这样就可以解决数据库字段名大写的问题。
以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索数据库
, 文件
, class
, 函数
, 注释
this
数据库字段名大小写、mybatis 字段名大小写、mysql 字段名 大小写、oracle 字段名大小写、mongodb 字段名大小写,以便于您获取更多的相关知识。