-
-
Save Strae/47f955a1ff27080eef6cdeb0f2cc38c0 to your computer and use it in GitHub Desktop.
Drupal Commerce - Top selling Products
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/** | |
* Get a list of the top selling products on a Drupal Commerce site | |
* If you have different product types - add them to the in list. | |
* Based on https://drupal.org/node/1292104#comment-6866420 by tmsimont https://drupal.org/user/566678 | |
*/ | |
SELECT node.title AS product_title, node.nid AS product_nid, COUNT(cp.title) AS order_count | |
FROM commerce_order | |
LEFT JOIN field_data_commerce_line_items as fdcli ON commerce_order.order_id = fdcli.entity_id AND (fdcli.entity_type = 'commerce_order' AND fdcli.deleted = '0') | |
INNER JOIN commerce_line_item as cli ON fdcli.commerce_line_items_line_item_id = cli.line_item_id | |
LEFT JOIN field_data_commerce_product as fdcp ON cli.line_item_id = fdcp.entity_id AND (fdcp.entity_type = 'commerce_line_item' AND fdcp.deleted = '0') | |
INNER JOIN commerce_product as cp ON fdcp.commerce_product_product_id = cp.product_id | |
LEFT JOIN field_data_field_product as fdfp ON cp.product_id = fdfp.field_product_product_id AND fdfp.deleted = '0' | |
LEFT JOIN node as node ON fdfp.entity_id = node.nid | |
WHERE (( (cli.type IN ('product')) AND (cp.type IN ('product', 's1_product', 's2_product', 's3_product')) )) | |
GROUP BY product_title, product_nid | |
ORDER BY order_count DESC |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
/** | |
* Exported view to show best selling products from a Drupal Commerce site | |
* taken from https://drupal.org/node/1292104#comment-6866420 credit to tmsimont - https://drupal.org/user/566678 | |
* | |
**/ | |
$view = new view; | |
$view->name = 'bestsellers'; | |
$view->description = ''; | |
$view->tag = 'default'; | |
$view->base_table = 'commerce_order'; | |
$view->human_name = 'Bestsellers'; | |
$view->core = 7; | |
$view->api_version = '3.0'; | |
$view->disabled = FALSE; /* Edit this to true to make a default view disabled initially */ | |
/* Display: Master */ | |
$handler = $view->new_display('default', 'Master', 'default'); | |
$handler->display->display_options['group_by'] = TRUE; | |
$handler->display->display_options['access']['type'] = 'none'; | |
$handler->display->display_options['cache']['type'] = 'none'; | |
$handler->display->display_options['query']['type'] = 'views_query'; | |
$handler->display->display_options['query']['options']['query_comment'] = FALSE; | |
$handler->display->display_options['exposed_form']['type'] = 'basic'; | |
$handler->display->display_options['pager']['type'] = 'none'; | |
$handler->display->display_options['pager']['options']['offset'] = '0'; | |
$handler->display->display_options['style_plugin'] = 'default'; | |
$handler->display->display_options['row_plugin'] = 'fields'; | |
/* Relationship: Commerce Order: Referenced line item */ | |
$handler->display->display_options['relationships']['commerce_line_items_line_item_id']['id'] = 'commerce_line_items_line_item_id'; | |
$handler->display->display_options['relationships']['commerce_line_items_line_item_id']['table'] = 'field_data_commerce_line_items'; | |
$handler->display->display_options['relationships']['commerce_line_items_line_item_id']['field'] = 'commerce_line_items_line_item_id'; | |
$handler->display->display_options['relationships']['commerce_line_items_line_item_id']['required'] = 1; | |
/* Relationship: Commerce Line item: Referenced product */ | |
$handler->display->display_options['relationships']['commerce_product_product_id']['id'] = 'commerce_product_product_id'; | |
$handler->display->display_options['relationships']['commerce_product_product_id']['table'] = 'field_data_commerce_product'; | |
$handler->display->display_options['relationships']['commerce_product_product_id']['field'] = 'commerce_product_product_id'; | |
$handler->display->display_options['relationships']['commerce_product_product_id']['relationship'] = 'commerce_line_items_line_item_id'; | |
$handler->display->display_options['relationships']['commerce_product_product_id']['required'] = 1; | |
/* Relationship: Commerce Product: Node referencing products from field_product */ | |
$handler->display->display_options['relationships']['field_product']['id'] = 'field_product'; | |
$handler->display->display_options['relationships']['field_product']['table'] = 'commerce_product'; | |
$handler->display->display_options['relationships']['field_product']['field'] = 'field_product'; | |
$handler->display->display_options['relationships']['field_product']['relationship'] = 'commerce_product_product_id'; | |
$handler->display->display_options['relationships']['field_product']['label'] = 'Node'; | |
$handler->display->display_options['relationships']['field_product']['required'] = 0; | |
/* Field: Content: Title */ | |
$handler->display->display_options['fields']['title_1']['id'] = 'title_1'; | |
$handler->display->display_options['fields']['title_1']['table'] = 'node'; | |
$handler->display->display_options['fields']['title_1']['field'] = 'title'; | |
$handler->display->display_options['fields']['title_1']['relationship'] = 'field_product'; | |
$handler->display->display_options['fields']['title_1']['label'] = ''; | |
$handler->display->display_options['fields']['title_1']['alter']['alter_text'] = 0; | |
$handler->display->display_options['fields']['title_1']['alter']['make_link'] = 0; | |
$handler->display->display_options['fields']['title_1']['alter']['absolute'] = 0; | |
$handler->display->display_options['fields']['title_1']['alter']['external'] = 0; | |
$handler->display->display_options['fields']['title_1']['alter']['replace_spaces'] = 0; | |
$handler->display->display_options['fields']['title_1']['alter']['trim_whitespace'] = 0; | |
$handler->display->display_options['fields']['title_1']['alter']['nl2br'] = 0; | |
$handler->display->display_options['fields']['title_1']['alter']['word_boundary'] = 1; | |
$handler->display->display_options['fields']['title_1']['alter']['ellipsis'] = 1; | |
$handler->display->display_options['fields']['title_1']['alter']['more_link'] = 0; | |
$handler->display->display_options['fields']['title_1']['alter']['strip_tags'] = 0; | |
$handler->display->display_options['fields']['title_1']['alter']['trim'] = 0; | |
$handler->display->display_options['fields']['title_1']['alter']['html'] = 0; | |
$handler->display->display_options['fields']['title_1']['element_label_colon'] = FALSE; | |
$handler->display->display_options['fields']['title_1']['element_default_classes'] = 1; | |
$handler->display->display_options['fields']['title_1']['hide_empty'] = 0; | |
$handler->display->display_options['fields']['title_1']['empty_zero'] = 0; | |
$handler->display->display_options['fields']['title_1']['hide_alter_empty'] = 1; | |
$handler->display->display_options['fields']['title_1']['link_to_node'] = 0; | |
/* Field: Content: Link */ | |
$handler->display->display_options['fields']['view_node']['id'] = 'view_node'; | |
$handler->display->display_options['fields']['view_node']['table'] = 'views_entity_node'; | |
$handler->display->display_options['fields']['view_node']['field'] = 'view_node'; | |
$handler->display->display_options['fields']['view_node']['relationship'] = 'field_product'; | |
$handler->display->display_options['fields']['view_node']['label'] = ''; | |
$handler->display->display_options['fields']['view_node']['alter']['alter_text'] = 0; | |
$handler->display->display_options['fields']['view_node']['alter']['make_link'] = 0; | |
$handler->display->display_options['fields']['view_node']['alter']['absolute'] = 0; | |
$handler->display->display_options['fields']['view_node']['alter']['replace_spaces'] = 0; | |
$handler->display->display_options['fields']['view_node']['alter']['trim_whitespace'] = 0; | |
$handler->display->display_options['fields']['view_node']['alter']['nl2br'] = 0; | |
$handler->display->display_options['fields']['view_node']['alter']['word_boundary'] = 1; | |
$handler->display->display_options['fields']['view_node']['alter']['ellipsis'] = 1; | |
$handler->display->display_options['fields']['view_node']['alter']['more_link'] = 0; | |
$handler->display->display_options['fields']['view_node']['alter']['strip_tags'] = 0; | |
$handler->display->display_options['fields']['view_node']['alter']['trim'] = 0; | |
$handler->display->display_options['fields']['view_node']['alter']['html'] = 0; | |
$handler->display->display_options['fields']['view_node']['element_label_colon'] = FALSE; | |
$handler->display->display_options['fields']['view_node']['element_default_classes'] = 1; | |
$handler->display->display_options['fields']['view_node']['hide_empty'] = 0; | |
$handler->display->display_options['fields']['view_node']['empty_zero'] = 0; | |
$handler->display->display_options['fields']['view_node']['hide_alter_empty'] = 1; | |
$handler->display->display_options['fields']['view_node']['text'] = 'view details'; | |
/* Sort criterion: COUNT(Commerce Product: Title) */ | |
$handler->display->display_options['sorts']['title']['id'] = 'title'; | |
$handler->display->display_options['sorts']['title']['table'] = 'commerce_product'; | |
$handler->display->display_options['sorts']['title']['field'] = 'title'; | |
$handler->display->display_options['sorts']['title']['relationship'] = 'commerce_product_product_id'; | |
$handler->display->display_options['sorts']['title']['group_type'] = 'count'; | |
$handler->display->display_options['sorts']['title']['order'] = 'DESC'; | |
/* Filter criterion: Commerce Line Item: Type */ | |
$handler->display->display_options['filters']['type']['id'] = 'type'; | |
$handler->display->display_options['filters']['type']['table'] = 'commerce_line_item'; | |
$handler->display->display_options['filters']['type']['field'] = 'type'; | |
$handler->display->display_options['filters']['type']['relationship'] = 'commerce_line_items_line_item_id'; | |
$handler->display->display_options['filters']['type']['value'] = array( | |
'product' => 'product', | |
); | |
/* Filter criterion: Commerce Product: Type */ | |
$handler->display->display_options['filters']['type_1']['id'] = 'type_1'; | |
$handler->display->display_options['filters']['type_1']['table'] = 'commerce_product'; | |
$handler->display->display_options['filters']['type_1']['field'] = 'type'; | |
$handler->display->display_options['filters']['type_1']['relationship'] = 'commerce_product_product_id'; | |
$handler->display->display_options['filters']['type_1']['value'] = array( | |
'product' => 'product', | |
); | |
?> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment