欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySql如何按照日期進(jìn)行分組統(tǒng)計(jì)

 更新時(shí)間:2023年09月28日 10:07:12   作者:zhao_854093140  
這篇文章主要介紹了MySql如何按照日期進(jìn)行分組統(tǒng)計(jì)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

最近接到一個(gè)需求,就是按照日期進(jìn)行統(tǒng)計(jì)數(shù)量,數(shù)據(jù)庫(kù)表里有id(編號(hào)),date(日期),phone(手機(jī)號(hào))

數(shù)據(jù)庫(kù)

CREATE TABLE `tb_count`  (
  `id` int(20) NOT NULL AUTO_INCREMENT COMMENT '編號(hào)',
  `tiems` datetime(0) NOT NULL COMMENT '日期',
  `number` varchar(11) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '手機(jī)號(hào)',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 18 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

我的sql是這樣的

這一條sql是查詢所有的,可以按照這個(gè)方法進(jìn)行分頁(yè)查詢,查詢所有

SELECT COUNT(*) AS counts,DATE_FORMAT(tiems,"%Y年%m月%d日") AS dates FROM tb_count  GROUP BY DATE_FORMAT (tiems,"%Y年%m月%d日")
-- DATE_FORMAT();按照格式對(duì)某個(gè)日期操作,
-- tb_count 表名
-- period 日期
-- 整段代碼的意思是:從tb_count表中 查詢?nèi)掌冢╬eriod )(將日期按照"%Y年%m月"格式)并作為dates,統(tǒng)計(jì)數(shù)量(count(*)),按照日期分組 GROUP BY DATE_FORMAT(period ,"%Y年%m月")

如果是進(jìn)行分頁(yè)查詢 我是做了一個(gè)封裝,將count(數(shù)量)和period(時(shí)間)做了一個(gè)封裝,做了一個(gè)實(shí)體類,技術(shù)有限,只能想到封裝為一個(gè)對(duì)象

封裝對(duì)象

@ApiModel(description = "Statis",value = "Statis")
public class Statis implements Serializable {
    //數(shù)量
    @ApiModelProperty(value = "",required = false)
    private int counts;
    //時(shí)間
    @ApiModelProperty(value = "",required = false)
    private String dates;
    public int getCounts() {
        return counts;
    }
    public void setCounts(int counts) {
        this.counts = counts;
    }
    public String getDates() {
        return dates;
    }
    public void setDates(String dates) {
        this.dates = dates;
    }
}

Service層

  /**
     * 分頁(yè)查詢
     * @param page 當(dāng)前頁(yè)
     * @param size 每頁(yè)顯示的條數(shù)
     * @return
     */
    Result findPage(int page,int size);

ServiceImpl Service層實(shí)現(xiàn)類

我這邊用分頁(yè)插件是PageInfo,需要傳入一個(gè)page和size

  /**
     * 分頁(yè)查詢
     * @param page 當(dāng)前頁(yè)
     * @param size 每頁(yè)顯示的條數(shù)
     * @return
     */
    @Override
    public Result findPage(int page, int size) {
        try {
            //分頁(yè)查詢
            PageHelper.startPage(page, size);
            //查詢所有
            List<Statis> statisList = countsMapper.findAll();
            PageInfo<Statis> pageInfo = new PageInfo<Statis>(statisList);
            return new Result(true,StatusCode.OK,"分頁(yè)查詢成功",pageInfo);
        }catch (Exception e){
            e.printStackTrace();
            return  new Result(false,StatusCode.ERROR,"分頁(yè)查詢失敗");
        }
    }

Controller層

    /**
     * 分頁(yè)查詢
     * @param page 當(dāng)前頁(yè)
     * @param size 每頁(yè)顯示的條數(shù)
     * @return
     * @throws Exception
     */
    @GetMapping("/search/{page}/{size}")
    @ApiImplicitParams({
            @ApiImplicitParam(paramType = "path", name = "page", value = "當(dāng)前頁(yè)", required = true, dataType = "Integer"),
            @ApiImplicitParam(paramType = "path", name = "size", value = "每頁(yè)顯示條數(shù)", required = true, dataType = "Integer")
    })
    @ApiOperation(value = "日期分頁(yè)查詢",notes = "日期分頁(yè)方法詳情",tags = {"MemberController"})
    public Result findPage(@PathVariable int page,@PathVariable int size) throws Exception {
      return   countsService.findPage(page, size);
    }

最后就是測(cè)試了

這個(gè)需求不是很難,就是一個(gè)簡(jiǎn)單的分頁(yè)查詢而已,難點(diǎn)在于這個(gè)sql。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 關(guān)于Mysql提高SQL性能的技巧(必看)

    關(guān)于Mysql提高SQL性能的技巧(必看)

    這篇文章主要介紹了關(guān)于Mysql提高SQL性能的技巧(必看),SQL查詢的性能直接影響系統(tǒng)的響應(yīng)時(shí)間,優(yōu)化SQL可以減少查詢的執(zhí)行時(shí)間,提高系統(tǒng)的響應(yīng)速度,提升用戶體驗(yàn),本文就來(lái)詳細(xì)講解一下如何優(yōu)化SQL性能
    2023-07-07
  • 在centOS 7安裝mysql 5.7的詳細(xì)教程

    在centOS 7安裝mysql 5.7的詳細(xì)教程

    這篇文章主要介紹了在centOS 7安裝mysql 5.7的詳細(xì)教程,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2016-12-12
  • 微信昵稱帶符號(hào)導(dǎo)致插入MySQL數(shù)據(jù)庫(kù)時(shí)出錯(cuò)的解決方案

    微信昵稱帶符號(hào)導(dǎo)致插入MySQL數(shù)據(jù)庫(kù)時(shí)出錯(cuò)的解決方案

    Mysql的utf8編碼最多3個(gè)字節(jié),而Emoji表情或者某些特殊字符是4個(gè)字節(jié),所以會(huì)導(dǎo)致帶有表情的昵稱插入數(shù)據(jù)庫(kù)時(shí)出錯(cuò),下面給大家分享下解決方案,需要的朋友參考下吧
    2016-12-12
  • 查看當(dāng)前mysql使用頻繁的sql語(yǔ)句(詳解)

    查看當(dāng)前mysql使用頻繁的sql語(yǔ)句(詳解)

    下面小編就為大家?guī)?lái)一篇查看當(dāng)前mysql使用頻繁的sql語(yǔ)句(詳解)。小編覺的挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-03-03
  • MySQL存儲(chǔ)引擎總結(jié)

    MySQL存儲(chǔ)引擎總結(jié)

    這篇文章主要介紹了MySQL存儲(chǔ)引擎總結(jié),本文講解了什么是存儲(chǔ)引擎、MyISAM、InnoDB、MEMORY、MERGE等內(nèi)容,需要的朋友可以參考下
    2014-09-09
  • mysql增加新用戶無(wú)法登陸解決方法

    mysql增加新用戶無(wú)法登陸解決方法

    在使用mysql增加新用戶之后,發(fā)現(xiàn)新增的用戶無(wú)法登陸,一時(shí)束手無(wú)策,網(wǎng)上搜集整理了一下,曬出來(lái)和大家分享一下,希望可以幫助你們
    2012-11-11
  • Mysql中的事務(wù)是什么如何使用

    Mysql中的事務(wù)是什么如何使用

    事務(wù)是邏輯上的一組操作,組成這組操作的各個(gè)單元,要不全都成功要不全都失敗,這個(gè)特性就是事務(wù),下面為大家介紹下Mysql中的事務(wù)的具體使用
    2013-12-12
  • mysql回表查詢是什么,回表查詢的使用

    mysql回表查詢是什么,回表查詢的使用

    這篇文章主要介紹了mysql回表查詢是什么,回表查詢的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。
    2022-11-11
  • centos7通過yum安裝mysql的方法

    centos7通過yum安裝mysql的方法

    這篇文章主要介紹了centos7通過yum安裝mysql的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-11-11
  • MySQL thread_stack連接線程的優(yōu)化

    MySQL thread_stack連接線程的優(yōu)化

    當(dāng)有新的連接請(qǐng)求時(shí),MySQL首先會(huì)檢查Thread Cache中是否存在空閑連接線程,如果存在則取出來(lái)直接使用,如果沒有空閑連接線程,才創(chuàng)建新的連接線程
    2017-04-04

最新評(píng)論