Thinkphp 数据库表名区分大小写问题

php中文网
发布: 2016-06-20 12:38:21
原创
2378人浏览过

这是我控制器的代码

<?phpnamespace home\controller;use think\controller;class indexcontroller extends controller {    public function index(){           $result=m('praise');        $a=$result->select();        var_dump($a);        die;        $this->display();    }}
登录后复制

这是报错:
1146:table 'movierdc.praise' doesn't exist [ sql语句 ] : show columns from `praise`
声明一下,我的表名没错,数据库中有一个全小写的表,查询正常。这个首字母大写就不行 

以下是尝试过的方法,没用
'db_params' => array(\pdo::attr_case => \pdo::case_natural),

有没有碰到类似的问题,怎么解决? 求职!

问问小宇宙
问问小宇宙

问问小宇宙是小宇宙团队出品的播客AI检索工具

问问小宇宙 77
查看详情 问问小宇宙


回复讨论(解决方案)

windows 中不会有问题
linux 中就不好说了
 

'DB_PARAMS' => array(\PDO::ATTR_CASE => \PDO::CASE_NATURAL), 

'DB_PARAMS' => array(\PDO::ATTR_CASE => \PDO::CASE_NATURAL),
这个配置是  让字段名不区分大小写。对表名无效。

我自己看了源代码,这是thinkphp默认将所有表名转换成小写,大写的在大写字母中间拆开,用_连接,并将大写字母改成小写。
我查不到关于配置表名的配置项。所以我直接从源代码入手,将转换成小写的函数去掉,拆分重组的函数也去掉。最后能用了。

那么久才上CSDN自己把帖子结了!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号