控制器中用到$m = D('Home/Carts');
但是数据库中没有carts这个表,提问错误
1146:Table 'sxtcs_tp.zht_carts' doesn't exist [ SQL语句 ] : SHOW COLUMNS FROM `zht_carts`
thinkphp d 方法没有对应的表怎么办?
Thinkphp中D方法必须要有对应数据库吗?
方法一:
模型对对应的数据表 默认是跟模型名同名的数据表
Login模型默认对应Login表,
如果不想这样对应,可以用
protected $tableName='products';
指定数据表名
方法二:
设置虚拟模型https://www.kancloud.cn/manual/thinkphp/1779
虚拟模型是指虽然是模型类,但并不会真正的操作数据库的模型。有些时候,我们建立模型类但又不需要进行数据库操作,仅仅是借助模型类来封装一些业务逻辑,那么可以借助虚拟模型来完成。虚拟模型不会自动连接数据库,因此也不会自动检测数据表和字段信息
namespace Home\Model;
Class UserModel extends \Think\Model {
Protected $autoCheckFields = false;
}
看别人的代码,版本是thinkphp3.2.2,没用上述2个方法,也不报错。我的版本是thinkphp3.2.3,不知道是不是跟版本有关