zoukankan      html  css  js  c++  java
  • 《理财市场情绪监测系统》代码实现【3】之情感极值表入库

    /**
      * Created by lkl on 2017/6/27.
      */
    import java.sql.{DriverManager, ResultSet}
    import org.apache.spark.SparkContext
    import org.apache.spark.SparkConf
    import java.math.BigDecimal
    object layer {
      def main(args: Array[String]) {
        val conf = new SparkConf().setMaster("local").setAppName("test")
        val sc = new SparkContext(conf)
        val sqlContext = new org.apache.spark.sql.SQLContext(sc)
        val role = "jdbc:mysql://192.168.0.37:3306/emotional?user=root&password=123456&useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadOnly=false"
    
    //    val log = sc.textFile("hdfs://192.168.0.211:9000/user/hadoop/emotion/汉语情感词极值表.txt")
    //        val g = log.map(line => (line.split(" ").head, line.split(" ").last.trim))
    //        import sqlContext.implicits._
    //        val df = g.toDF("words", "value").registerTempTable("layer")
    //        val value = sqlContext.sql("select words,value from layer")
    //        val pp=value.map(p => {
    //          val words= p.getString(0)
    //          val value = p.getString(1)
    //          (words,value)
    //        })
    //
    //        pp.foreach(p => {
    //            val v0 = p._1
    //            val v1 = p._2.toFloat
    //          insert(v0, v1)
    //
    //        })
    
        val logCsenticNet = sc.textFile("hdfs://192.168.0.211:9000/user/hadoop/emotion/editCsenticNet.txt")
        val gCsenticNet = logCsenticNet.map(line => (line.split(",")(0), line.split(",")(1), line.split(",")(2), line.split(",")(3), line.split(",")(4)))
        import sqlContext.implicits._
        val dfCsenticNet = gCsenticNet.toDF("words", "attitude", "expression", "extreme", "VALUE").registerTempTable("CsenticNetlayer2")
        val valueCsenticNet = sqlContext.sql("select words,attitude,expression,extreme,VALUE from CsenticNetlayer2")
        val ppCsenticNet = valueCsenticNet.map(p => {
          val v0 = p.getString(0)
          val v1 = p.getString(1)
          val v2 = p.getString(2)
          val v3 = p.getString(3)
          val v4 = p.getString(4)
          (v0, v1, v2, v3, v4)
        })
    
        ppCsenticNet.foreach(p => {
          val v0 = p._1
          val v1 = p._2
          val v2 = p._3
          val v3 = p._4
          val v4 = p._5
          insert2(v0, v1, v2, v3, v4)
        })
    
    
    
        def insert(value0: String, value1: Float): Unit = {
    
          println(value0, value1)
          val rl = "jdbc:mysql://192.168.0.37:3306/emotional?user=root&password=123456&useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadOnly=false"
    
          classOf[com.mysql.jdbc.Driver]
          val conn = DriverManager.getConnection(rl)
          val statement = conn.createStatement(ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_UPDATABLE)
          try {
            val prep = conn.prepareStatement("INSERT INTO layer(words,VALUE) VALUES (?,?) ")
            prep.setString(1, value0)
            prep.setFloat(2, value1)
    
            prep.executeUpdate
          } catch {
            case e: Exception => e.printStackTrace
          }
          finally {
           // conn.close
          }
        }
    
        def insert2(value0: String, value1: String, value2: String, value3: String, value4: String): Unit = {
          val rl = "jdbc:mysql://192.168.0.37:3306/emotional?user=root&password=123456&useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadOnly=false"
    
          classOf[com.mysql.jdbc.Driver]
          val conn = DriverManager.getConnection(rl)
          val statement = conn.createStatement(ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_UPDATABLE)
          // CREATE TABLE words2(innersessionId VARCHAR(100),words VARCHAR(100), VARCHAR(100),posit VARCHAR(100),va VARCHAR(100))
          try {
            val prep = conn.prepareStatement("INSERT INTO CsenticNetlayer2(words,attitude,expression,extreme,VALUE) VALUES (?,?,?,?,?) ")
            prep.setString(1, value0)
            prep.setString(2, value1)
            prep.setString(3, value2)
            prep.setString(4, value3)
            prep.setString(5, value4)
            prep.executeUpdate
          } catch {
            case e: Exception => e.printStackTrace
          }
          finally {
           // conn.close
          }
        }
      }}
  • 相关阅读:
    java中map接口hashMap以及Enty之间的用法和关系
    Collection集合总结,List和set集合的用法,HashSet和LinkedHashSetde用法
    微信小程序开发攻略
    Java闰年的计算,Calendar的用法
    Java计算计算活了多少天
    Java用代码演示String类中的以下方法的用法
    Java判断一个字符串中有多少大写字母、小写字母和数字
    Java将一个字符串的首位改为大写后边改为小写的实现,String
    Java 获取一个字符串中,另一个字符串出现的次数
    linux下重命名文件或文件夹(linux)
  • 原文地址:https://www.cnblogs.com/canyangfeixue/p/7193001.html
Copyright © 2011-2022 走看看