select();会报错,错误信息提示中的sql语句中包括了配置文件中的表前缀,可是在用..."/> select();会报错,错误信息提示中的sql语句中包括了配置文件中的表前缀,可是在用...">
首页 > 后端开发 > php教程 > thinkphp中的table方法怎样使用?

thinkphp中的table方法怎样使用?

WBOY
发布: 2016-09-26 08:40:13
原创
1371 人浏览过

网上搜到基本和文档里写的一样:
http://document.thinkphp.cn/m...

<code>例如:
$Model->table('think_user')->where('status>1')->select();
也可以在table方法中指定数据库,例如:
$Model->table('db_name.think_user')->where('status>1')->select();
复制代码
table方法指定的数据表需要完整的表名,但可以采用下面的方式简化数据表前缀的传入,例如:
$Model->table('__USER__')->where('status>1')->select();
会自动获取当前模型对应的数据表前缀来生成 think_user 数据表名称。
</code>
登录后复制
登录后复制

但我在使用的时候,用
M()->table("tp_user)->select();
会报错,错误信息提示中的sql语句中包括了配置文件中的表前缀,可是在用table方法的时候,不是本来就需要自己加表前缀的吗?为什么在我加了前缀后,它还会去读取配置文件中的前缀?

另外,文档中写到的省略前缀的写法:M()->table("__USER__") 在实际开发中有必要这样使用吗?
这样写不是更简单吗?--> M("User")

回复内容:

网上搜到基本和文档里写的一样:
http://document.thinkphp.cn/m...

<code>例如:
$Model->table('think_user')->where('status>1')->select();
也可以在table方法中指定数据库,例如:
$Model->table('db_name.think_user')->where('status>1')->select();
复制代码
table方法指定的数据表需要完整的表名,但可以采用下面的方式简化数据表前缀的传入,例如:
$Model->table('__USER__')->where('status>1')->select();
会自动获取当前模型对应的数据表前缀来生成 think_user 数据表名称。
</code>
登录后复制
登录后复制

但我在使用的时候,用
M()->table("tp_user)->select();
会报错,错误信息提示中的sql语句中包括了配置文件中的表前缀,可是在用table方法的时候,不是本来就需要自己加表前缀的吗?为什么在我加了前缀后,它还会去读取配置文件中的前缀?

另外,文档中写到的省略前缀的写法:M()->table("__USER__") 在实际开发中有必要这样使用吗?
这样写不是更简单吗?--> M("User")

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板