> 백엔드 개발 > PHP 튜토리얼 > Thinkphp 数据库表名区分大小写问题

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

WBOY
풀어 주다: 2016-06-20 12:38:21
원래의
2157명이 탐색했습니다.

这是我控制器的代码

<?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),

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


回复讨论(解决方案)

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

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

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

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

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿