首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在innerJoin()中使用TableSort

在innerJoin()中使用TableSort
EN

Drupal用户
提问于 2019-03-29 13:36:43
回答 1查看 38关注 0票数 0

在示例模块中,我看到了一个带有一个表的tableSort的简单示例。在网上搜索时,我找到一个帖子,他们声称Drupal 7允许创建一个db_select()对象,然后用一个join()扩展它,然后是最终的->extend('TableSort');

https://www.drupal.org/forum/support/module-development-and-code-questions/2011-12-15/dbtng-tablesort-with-joins-any

我需要做一个innerJoin(),它似乎是SelectQuery类的一个方法,而不一定是Tablesort类的一个方法。这就是为什么我看到的关于扩展器的文档说,在实例化TableSort对象时调用db_select至关重要。因此,我的尝试:

代码语言:javascript
复制
$get_all_members = db_select('users', 'u')->innerJoin('members', 'm', 'u.uid = m.uid')->extend('TableSort');

调用string上的成员函数extend()

是回应。是否有一种方法可以像扩展程序所做的那样将db_query转换为TableSort对象?

或者,我可以找到一种方法将这两个表中的字段组合起来传递给TableSort对象吗?

EN

回答 1

Drupal用户

回答已采纳

发布于 2019-03-29 16:47:54

您引用的线程中的问题被解决了。并非所有用于select类的方法都返回新的查询对象。特别是,innerJoin()返回一个别名字符串,而不是查询对象。

分配查询对象,以便在调用的方法之外引用它:

代码语言:javascript
复制
$query = db_select('users', 'u')->extend('TableSort')
$query->innerJoin('members', 'm', 'u.uid = m.uid');
//@TODO: add ->fields() ->execute() etc...
票数 1
EN
页面原文内容由Drupal提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://drupal.stackexchange.com/questions/278435

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档