在示例模块中,我看到了一个带有一个表的tableSort的简单示例。在网上搜索时,我找到一个帖子,他们声称Drupal 7允许创建一个db_select()对象,然后用一个join()扩展它,然后是最终的->extend('TableSort');
我需要做一个innerJoin(),它似乎是SelectQuery类的一个方法,而不一定是Tablesort类的一个方法。这就是为什么我看到的关于扩展器的文档说,在实例化TableSort对象时调用db_select至关重要。因此,我的尝试:
$get_all_members = db_select('users', 'u')->innerJoin('members', 'm', 'u.uid = m.uid')->extend('TableSort');调用string上的成员函数extend()
是回应。是否有一种方法可以像扩展程序所做的那样将db_query转换为TableSort对象?
或者,我可以找到一种方法将这两个表中的字段组合起来传递给TableSort对象吗?
发布于 2019-03-29 16:47:54
您引用的线程中的问题被解决了。并非所有用于select类的方法都返回新的查询对象。特别是,innerJoin()返回一个别名字符串,而不是查询对象。
分配查询对象,以便在调用的方法之外引用它:
$query = db_select('users', 'u')->extend('TableSort')
$query->innerJoin('members', 'm', 'u.uid = m.uid');
//@TODO: add ->fields() ->execute() etc...https://drupal.stackexchange.com/questions/278435
复制相似问题