hive udf获取当前月最后一天

本文介绍了一个Hive自定义函数(UDF)的实现,用于从输入日期中计算并返回所在月份的最后一天。该函数首先解析输入的日期字符串,然后使用Java的Calendar类来设置日期到当月的最后一天,并最终格式化输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.hive.udf;
 
 
import org.apache.hadoop.hive.ql.exec.UDF;
 
import java.net.URLDecoder;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
/*
 * 
 * 
 */
public class LastDay extends UDF {  
      
      public LastDay() {  
      }  
      
      public String evaluate(String thisdate) {  
            SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); 
            if (thisdate.length()==8)
                format = new SimpleDateFormat("yyyyMMdd");
              //获取当前月第一天:
            Calendar c = Calendar.getInstance();    
            Date   thisb=null;
            try {
                  thisb=format.parse(thisdate);
                
                } catch (ParseException e) {
                 e.printStackTrace();
                }
            c.setTime(thisb);
            c.add(Calendar.MONTH, 0);
     //       c.set(Calendar.DAY_OF_MONTH,1);//设置为1号,当前日期既为本月第一天 
      //      String first = format.format(c.getTime());
      //      System.out.println("===============first:"+first);
            
            //获取当前月最后一天
         //   Calendar ca = Calendar.getInstance();    
            c.set(Calendar.DAY_OF_MONTH, c.getActualMaximum(Calendar.DAY_OF_MONTH));  
            String last = format.format(c.getTime());
            return last;
      }  
     }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值