php 字段名不存在,thinkphp3.2 model名称不存在对应的数据表可以吗?

控制器中用到$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,不知道是不是跟版本有关

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值