簡體   English   中英

如何從表格中獲取基於月份和年份的記錄?

[英]How can I get records based on month and year from table?

我們可以在 where 子句中僅使用日期的月份和年份部分來過濾日期字段嗎?

    SELECT `outlet`.`outlet`,cities.`city`,teritory.`teritory`,region.`region`,`countries`.`country` FROM `audit`
    JOIN `user` ON `user`.`id`=`audit`.`auditor_id`
    JOIN `user_outlet` ON `user_outlet`.id=`audit`.`outlet_id`
    JOIN `outlet` ON `outlet`.id=`user_outlet`.`outlet_id`
    JOIN `cities` ON `cities`.`id`=`outlet`.`city_id`
    JOIN `teritory_city` ON `teritory_city`.`city_id`=`cities`.id
    JOIN `teritory` ON `teritory_city`.`teritory_id`=`teritory`.`id`
    JOIN `region` ON `region`.`id`=`teritory`.`region_id`
    JOIN `org_country` ON `org_country`.`id`=`region`.`org_country_id`
    JOIN `countries` ON `countries`.`id`=`org_country`.`country_id`
    WHERE `audit`.`created_date`=?

以上是我嘗試過的查詢,我必須傳遞年和月參數而不是傳遞日期。 在 UI 中,年份和月份是我提供給用戶的唯一過濾器,用於獲取特定月份和年份中的相應數據。

使用year()month()函數,如下所示-

SELECT `outlet`.`outlet`,cities.`city`,teritory.`teritory`,region.`region`,`countries`.`country` FROM `audit`
JOIN `user` ON `user`.`id`=`audit`.`auditor_id`
JOIN `user_outlet` ON `user_outlet`.id=`audit`.`outlet_id`
JOIN `outlet` ON `outlet`.id=`user_outlet`.`outlet_id`
JOIN `cities` ON `cities`.`id`=`outlet`.`city_id`
JOIN `teritory_city` ON `teritory_city`.`city_id`=`cities`.id
JOIN `teritory` ON `teritory_city`.`teritory_id`=`teritory`.`id`
JOIN `region` ON `region`.`id`=`teritory`.`region_id`
JOIN `org_country` ON `org_country`.`id`=`region`.`org_country_id`
JOIN `countries` ON `countries`.`id`=`org_country`.`country_id`
WHERE year(`audit`.`created_date`)=yearparam and month(`audit`.`created_date`)=monthparam

盡量避免在WHERE子句中的列上使用函數。 這可以防止優化器選擇最佳優化計划。

我會建議:

where audit.created_date >= date(concat_ws('-', @yearparam, @monthparam, 1) and
      audit.created_date < date(concat_ws('-', @yearparam, @monthparam, 1) + interval 1 month

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM