thinkphp中的table方法怎样使用?
阿神
阿神 2017-04-11 10:34:23
[PHP讨论组]

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

例如:
$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 数据表名称。

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

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

阿神
阿神

闭关修行中......

全部回复(5)
黄舟

我在写子查询的时候比较喜欢用
$subQuery = $model->field('id,name')->table('tablename')->group('field')->where($where)->order('status')->buildSql();
// 利用子查询进行查询
$model->table($subQuery.' a')->where()->order()->select()

其他时候我就喜欢用M('tablename')->select()
还有多表查询的时候,M('user')这种方式实现不了,table就可以
$Model->field('user.name,role.title')
->table('think_user user,think_role role')
->limit(10)->select();

PHP中文网

写sql语句时候用,比如

      $ob=M('表名');
object $ob->table(表名);
object $ob->field("字段列表");
object $ob->where("条件") 指定条件
object $ob->group('字段') 分组
object $ob->having('条件') 筛选
object $ob->limit("开始位置,长度") limit 子句
object $ob->order('字段 asc|desc') 排序
object $ob->join("表名2 as t2 on t1.字段=t2.字段") 连接查询
object $ob->alias('别名') 为表1指定别名
array $ob->find()  查询一条
array $ob->select() 获取多条
高洛峰

这个有没有必要我觉得应该像你上面说的 table可以指定数据库啊 你M能指定数据库吗 这个要根据不同的业务情况 感觉没必要去纠结 有些东西是根据不同的业务情况而定的吧 我也没用过这个方法 只是猜想 不对的话望不要介意

PHP中文网

看一下源码就明白了,Model.class.php中table方法会自动补上前缀;M方法也是要先实例化Model,两种写法区别不大,看习惯吧。

大家讲道理

假如表名为 think_user 那么就可以用 __USER__,thinkphp框架会自动获取完整表名。
这样写用于联合查询的时候,举个栗子:

M()->table('__User__ as User, __ARTICLE__ as Article')->where('User.id = Article.uid')->select();
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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