gpt4 book ai didi

php - 如何覆盖 drupal View 寻呼机查询?

转载 作者:可可西里 更新时间:2023-10-31 23:09:15 25 4
gpt4 key购买 nike

我正在使用 drupal 6 和 View 2 -

我已经使用此文档为我的 View 创建了一个自定义过滤器

http://www.chadcf.com/blog/creating-custom-filters-drupal-and-views .

一切似乎都很好,只有一个问题 -

我的分页不工作(没有出现在某些运营商身上)

让我简要解释一下我想要实现的目标-

在我的页面 View 中,我已经有一些带有运算符下拉列表的公开过滤器,并且我创建了一个没有运算符下拉列表的自定义公开过滤器。

我的要求是将一个现有的过滤器功能与我的自定义过滤器合并。意味着两个过滤器将协同工作以获得所需的结果。但是一个过滤器由现有字段组成,如果我从下拉列表中选择它的任何运算符,那么它的值将包含在 where 子句中,这是我不想要的。所以我使用

从 View 查询中完全删除了查询 block
hook_views_pre_execute(&$view) {
$view->build_info['query'] = preg_replace('/AND \(node_data_field_stock.field_stock_value [<<=>>=!=\\s%d|IS NULL|IS NOT NULL]*\)/','',$view->build_info['query']);
}

现在在我的站点/所有/模块/mymodule/inc/mymodule_filter.inc

function query() {
$this->query->add_where($this->options['group'], "MY_QUERY");
}

添加where子句查看查询。

使用上面的过程,我成功地扩展了默认 View 行为,也得到了想要的结果,但是对于一些运算符(operator)分页链接没有出现,即使我知道数据库中存在更多记录。

我知道为什么会这样——因为我的 View 分页脚本不知道我所做的更改。

我的问题是如何覆盖 View 寻呼机查询?

如有任何帮助,我们将不胜感激。

最佳答案

下面是我从 View 查询中删除 where 子句的操作。

hook_views_pre_execute(&$view) {
$view->build_info['query'] = preg_replace('/AND \(node_data_field_stock.field_stock_value [<<=>>=!=\\s%d|IS NULL|IS NOT NULL]*\)/','',$view->build_info['query']);
}

但是要从 View 查询中删除 where 子句的正确位置是 hook_views_query_alter()。通过使用本教程

http://www.drupaler.co.uk/blog/altering-views-query-tackling-node-type-filter-bug/451

    function hook_views_query_alter(&$view, &$query) {
if($view->name == 'view_name'){
var_dump($query->where[0]['clauses']);
foreach ($query->where[0]['clauses'] as $key=>$value) {
if(preg_match('/node_data_field_stock.field_stock_value/',$value)){
unset($query->where[0]['clauses'][$key]);
// remove the where clause by it's key
}
}

var_dump($query->where[0]['clauses']);
}
}

关于php - 如何覆盖 drupal View 寻呼机查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8383486/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com