diff --git a/profiles/wcm_base/CHANGELOG.txt b/profiles/wcm_base/CHANGELOG.txt index f6f76c2a81eb2ba035ec04c2658a536206252cad..5526a177773c24cd22ac3f9a9621a11250fe43ac 100644 --- a/profiles/wcm_base/CHANGELOG.txt +++ b/profiles/wcm_base/CHANGELOG.txt @@ -1,3 +1,7 @@ +WCM Base 7.x-1.8-rc3, 2018-07-24 +-------------------------------- +- WCM Base: Added patch to fix duplicate results bug introduced in Views 3.20. + WCM Base 7.x-1.8-rc2, 2018-07-23 -------------------------------- - WCM Base: diff --git a/profiles/wcm_base/modules/contrib/views/PATCHES.txt b/profiles/wcm_base/modules/contrib/views/PATCHES.txt index c09d8e8ae7403da4839c8f2720044f8b993a5034..1d3ca2ccdfd961c1eb05feb18fcd30059835db73 100644 --- a/profiles/wcm_base/modules/contrib/views/PATCHES.txt +++ b/profiles/wcm_base/modules/contrib/views/PATCHES.txt @@ -1,4 +1,5 @@ The following patches have been applied to this project: +- http://drupal.org/files/issues/2018-07-15/mysql-group-by-duplication-workaround-2985178-7.patch - http://drupal.org/files/issues/views-exposed-sorts-2037469-26.patch This file was automatically generated by Drush Make (http://drupal.org/project/drush). diff --git a/profiles/wcm_base/modules/contrib/views/plugins/views_plugin_query_default.inc b/profiles/wcm_base/modules/contrib/views/plugins/views_plugin_query_default.inc index 2911a56033947fcfc217c13b1ea76377bccffb7b..92eb19261eb5ac505da1acd1c831db1c2b888896 100644 --- a/profiles/wcm_base/modules/contrib/views/plugins/views_plugin_query_default.inc +++ b/profiles/wcm_base/modules/contrib/views/plugins/views_plugin_query_default.inc @@ -1214,7 +1214,10 @@ class views_plugin_query_default extends views_plugin_query { } // This is a formula, using no tables. elseif (empty($field['table'])) { - if (!in_array($fieldname, $non_aggregates)) { + if (Database::getConnection()->databaseType() != 'pgsql') { + $non_aggregates[] = $fieldname; + } + elseif (!in_array($fieldname, $non_aggregates)) { $non_aggregates[] = $fieldname; } $placeholders = !empty($field['placeholders']) ? $field['placeholders'] : array(); @@ -1224,13 +1227,16 @@ class views_plugin_query_default extends views_plugin_query { elseif ($this->distinct && !in_array($fieldname, $this->groupby)) { // d7cx: This code was there, apparently needed for PostgreSQL // $string = db_driver() == 'pgsql' ? "FIRST($string)" : $string; - if (!in_array($string, $non_aggregates)) { + if (Database::getConnection()->databaseType() == 'pgsql' && !in_array($string, $non_aggregates)) { $non_aggregates[] = $string; } $query->addField(!empty($field['table']) ? $field['table'] : $this->base_table, $field['field'], $fieldname); } elseif (empty($field['aggregate'])) { - if (!in_array($string, $non_aggregates)) { + if (Database::getConnection()->databaseType() != 'pgsql') { + $non_aggregates[] = $fieldname; + } + elseif (!in_array($string, $non_aggregates)) { $non_aggregates[] = $string; } $query->addField(!empty($field['table']) ? $field['table'] : $this->base_table, $field['field'], $fieldname); diff --git a/profiles/wcm_base/wcm_base.make b/profiles/wcm_base/wcm_base.make index 1484d8273b2c412def46446cbbd21f0d01db7c40..fb8d4b625790aa96e2de785251df5bef7f551776 100644 --- a/profiles/wcm_base/wcm_base.make +++ b/profiles/wcm_base/wcm_base.make @@ -174,6 +174,7 @@ projects[token_filter][subdir] = contrib projects[views][version] = 3.20 projects[views][subdir] = contrib +projects[views][patch][2985178] = http://drupal.org/files/issues/2018-07-15/mysql-group-by-duplication-workaround-2985178-7.patch projects[views][patch][2037469] = http://drupal.org/files/issues/views-exposed-sorts-2037469-26.patch projects[views_accordion][version] = 1.1