package spark import java.text.SimpleDateFormat import java.util.{Calendar, Date} import org.apache.spark.SparkConf import org.apache.spark.sql._ object Execute { def main(args: Array[String]): Unit = { val sparkConf = new SparkConf().setAppName("Execute") val session = SparkSession.builder().config(sparkConf).enableHiveSupport().getOrCreate() val time = args(0) //傳入參數 2019052212 val dateFormatTime = new SimpleDateFormat("yyyyMMddHH") val dateFormatDay = new SimpleDateFormat("yyyyMMdd") val dateFormatHour = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss") val cal = Calendar.getInstance() cal.setTime(dateFormatTime.parse(time)) val partitionDate = dateFormatDay.format(cal.getTime) val partitionHour = cal.get(Calendar.HOUR_OF_DAY).toString.length() match { case 1 => "0" + cal.get(Calendar.HOUR_OF_DAY).toString case _ => cal.get(Calendar.HOUR_OF_DAY).toString } val statisDatePre = dateFormatHour.format(dateFormatTime.parse(time)) cal.setTime(new Date(dateFormatTime.parse(time).getTime + 3600000)) val statisDateNow = dateFormatHour.format(cal.getTime) val handle: Array[Row] = session.sql("select handle_condition FROM sospdm.mysql_to_hive_m_guest_screen_info WHERE create_time >= '" + statisDatePre + "' and create_time <= '" + statisDateNow + "' and source = 'SH_10001'").rdd.collect() for (row <- handle) { val ex_sql = row.getString(0) val idCust = session.sql(ex_sql) idCust.registerTempTable("tmp_m_guest_screen_info") //結果數據插入結果表 session.sql("insert overwrite table sospdm.tdm_wit_customer_group_detail partition (statis_date= " + partitionDate + " ,statis_hour= " + partitionHour + " ) select cust_group_cd as cid,cust_num from tmp_m_guest_screen_info") session.sql("insert overwrite table sospdm.tdm_wit_customer_group_code partition (statis_date= " + partitionDate + " ,statis_hour= " + partitionHour + " ) select cust_group_cd as cid from tmp_m_guest_screen_info group by cust_group_cd") } } }