/**
* Created by wu-yj on 2016/5/6.
*/ import java.sql.{Connection, DriverManager, PreparedStatement} import org.apache.spark.{SparkConf, SparkContext}
import java.sql.{Connection, DriverManager} import org.apache.spark.{SparkConf, SparkContext}
import org.apache.spark.sql.hive.HiveContext import java.util.Date
import java.text.SimpleDateFormat class zhengxin_dis{ } object zhengxin_dis {
def main(args: Array[String]) {
//链接Mysql
val driver = "com.mysql.jdbc.Driver"
val url = "jdbc:mysql://10.1.2.190:8066/mq_sale_disc"
val username = "kr.user"
val password = "user@85263382"
var connectionMqcrm: Connection = null
Class.forName(driver)
connectionMqcrm = DriverManager.getConnection(url, username, password)
val statement = connectionMqcrm.createStatement() //链接Hive
val sparkconf = new SparkConf().setMaster("spark://10.1.2.70:7077").setAppName("local")
val sc = new SparkContext(sparkconf)
val sqlContext = new org.apache.spark.sql.hive.HiveContext(sc) //定义城市级别
val oneline: List[String] = List("北京", "上海 ", "广州 ", "深圳 ")
val twoline: List[String] = List("杭州", "宁波 ", "西安 ", "温州 ", "佛山 ", "东莞 ", "成都 ", "武汉 ", "哈尔滨 ", "青岛 ", "大连 ", "厦门 ",
"沈阳 ", "长春 ", "长沙 ", "福州 ", "郑州 ", "石家庄 ", "苏州 ", "南京 ", "济南 ", "重庆 ", "无锡 ",
"烟台 ", "太原 ", "合肥 ", "南昌 ", "南宁 ", "昆明 ", "淄博 ", "唐山 ")
val threeline: List[String] = List("绍兴", "台州 ", "嘉兴 ", "榆林 ", "义乌 ", "金华 ", "中山 ", "惠州 ", "茂名 ", "江门 ", "湛江 ", "宝鸡 ", "珠海 ")
val fourline: List[String] = List("咸阳", "肇庆 ", "汕头 ", "揭阳 ", "延安 ", "渭南 ", "清远 ", "衢州 ", "韶关 ", "丽水 ", "阳江 ") val rdd1 = sqlContext.sql("use moreqinrdb")
val namelist = sqlContext.sql("select company_name from company_business_info")
val namelistt=namelist.take(5)
//计算征信得分过程
for (coname <- namelistt) {
//法定代表人
var score = 0
val sqllegal = sqlContext.sql("select legal_representative from company_business_info where company_name = \'" + coname + "\'")
if (sqllegal.count() > 0) {
val legal = sqllegal.take(1)(0).toString().replace("[", "").replace("]", "")
if (legal != "" && (legal != "null" || legal != "None"))
score += 100
else
score += 90
} else
score += 90
//公司类型
val sqlcompanytype = sqlContext.sql("select company_type from company_business_info where company_name = \'" + coname + "\'")
if (sqlcompanytype.count() > 0) {
val companytype = sqlcompanytype.take(1)(0).toString().replace("[", "").replace("]", "")
if (companytype.contains("无限责任"))
score += 100
else if (companytype.contains("有限股份") || companytype.contains("无限股份") || companytype.contains("股份两合"))
score += 90
else if (companytype.contains("两合公司"))
score += 80
else if (companytype.contains("股份有限"))
score += 60
else if (companytype.contains("个体"))
score += 20
else if (companytype.contains("有限责任"))
score += 40
else
score += 0
} else
score += 0
//经营状态
val sqlmanagementform = sqlContext.sql("select operation_status from company_business_info where company_name = \'" + coname + "\'")
sqlmanagementform.show()
if (sqlmanagementform.count() > 0) {
val managementform = sqlmanagementform.take(1)(0).toString().replace("[", "").replace("]", "")
if (managementform == "开业")
score += 80
else if (managementform == "存续")
score += 100
else if (managementform == "迁出")
score += 50
else if (managementform == "吊销")
score += 0
else if (managementform == "迁入" || managementform == "待迁入")
score += 60
else if (managementform == "歇业")
score += 30
else
score += 0
} else
score += 0
//成立时间
val sqlfoundtime = sqlContext.sql("select build_date from company_business_info where company_name = \'" + coname + "\'")
if (sqlfoundtime.count() > 0) {
val foundtime = sqlfoundtime.take(1)(0).toString().replace("[", "").replace("]", "")
if (foundtime.length > 1 && foundtime != "null" && foundtime != "None" && foundtime != "") {
if (foundtime != "None" || foundtime != "null" || foundtime != "") {
val time = System.currentTimeMillis()
var dateFormat: SimpleDateFormat = new SimpleDateFormat("yyyy-MM-dd")
var now: Date = new Date(time)
val currentTime = dateFormat.format(now)
val daydiff = dateFormat.parse(currentTime).getTime - dateFormat.parse(foundtime).getTime
val dayinter = daydiff / (1000 * 3600 * 24)
var timeyear = dayinter / 365
if (timeyear > 30)
score += 100
if (timeyear >= 10 && timeyear <= 30)
score += 90
if (timeyear >= 5 && timeyear < 10)
score += 80
if (timeyear >= 3 && timeyear < 5)
score += 60
if (timeyear > 1 && timeyear < 3)
score += 30
if (timeyear < 1 && timeyear >= 0)
score += 0
} else
score += 0
} else
score += 0
} else
score += 0
//注册资本
val sqlcapital = sqlContext.sql("select registered_capital from company_business_info where company_name = \'" + coname + "\'")
if (sqlcapital.count() > 0) {
val capital = sqlcapital.take(1)(0).toString().replace("[", "").replace("]", "")
if (capital.length > 0) {
if (capital.contains("人民币")) {
val zibencl = capital.subSequence(0, capital.indexOf("万"))
if (zibencl.toString().contains(",")) {
val ziben = zibencl.toString().replace(",", "").toInt
if (ziben >= 10000)
score += 100
else if (ziben >= 5000 && ziben < 10000)
score += 90
else if (ziben >= 3000 && ziben < 5000)
score += 80
else if (ziben >= 1000 && ziben < 3000)
score += 70
else if (ziben >= 500 && ziben < 1000)
score += 50
else if (ziben >= 100 && ziben < 500)
score += 30
else if (ziben < 100)
score += 0
} else {
val ziben = zibencl.toString().toFloat
if (ziben >= 500 && ziben < 1000)
score += 50
else if (ziben >= 100 && ziben < 500)
score += 30
else if (ziben < 100)
score += 0
}
} else if (capital.contains("美元")) {
val zibencl = capital.subSequence(0, capital.indexOf("万"))
if (zibencl.toString().contains(",")) {
val ziben = zibencl.toString().toFloat * 6.8
if (ziben >= 10000)
score += 100
else if (ziben >= 5000 && ziben < 10000)
score += 90
else if (ziben >= 3000 && ziben < 5000)
score += 80
else if (ziben >= 1000 && ziben < 3000)
score += 70
else if (ziben >= 500 && ziben < 1000)
score += 50
else if (ziben >= 100 && ziben < 500)
score += 30
else if (ziben < 100)
score += 0
} else {
val ziben = zibencl.toString().toFloat * 6.8
if (ziben >= 5000 && ziben < 10000)
score += 90
else if (ziben >= 3000 && ziben < 5000)
score += 80
else if (ziben >= 1000 && ziben < 3000)
score += 70
else if (ziben >= 500 && ziben < 1000)
score += 50
else if (ziben >= 100 && ziben < 500)
score += 30
else if (ziben < 100)
score += 0
}
} else {
score += 0
}
} else {
score += 0
}
} else
score += 0
//登记机关
val sqlregister = sqlContext.sql("select registration_authority from company_business_info where company_name = \'" + coname + "\'")
if (sqlregister.count() > 0) {
val register = sqlregister.take(1)(0).toString().replace("[", "").replace("]", "")
if (register.length > 1) {
if (register.contains("县"))
score += 20
else if (register.contains("市") == true && register.contains("区") == true && register.contains("省") == true) {
val subS = register.subSequence(register.indexOf("省") + 1, register.indexOf("市") + 1)
if (oneline.contains(subS))
score += 100
else if (twoline.contains(subS))
score += 80
else if (threeline.contains(subS))
score += 60
else if (fourline.contains(subS))
score += 40
else if (oneline.contains(subS) == false && twoline.contains(subS) == false && threeline.contains(subS) == false && fourline.contains(subS) == false)
score += 20
} else if (register.contains("市") == true && register.contains("省") == true && register.contains("区") == false) {
val subS = register.subSequence(register.indexOf("省") + 1, register.indexOf("市") + 1)
if (oneline.contains(subS))
score += 100
else if (twoline.contains(subS))
score += 80
else if (threeline.contains(subS))
score += 60
else if (fourline.contains(subS))
score += 40
else if (oneline.contains(subS) == false && twoline.contains(subS) == false && threeline.contains(subS) == false && fourline.contains(subS) == false)
score += 20
} else if (register.contains("市") == true && register.contains("区") == true && register.contains("省") == false) {
val subS = register.subSequence(0, register.indexOf("市") + 1)
if (oneline.contains(subS))
score += 100
else if (twoline.contains(subS))
score += 80
else if (threeline.contains(subS))
score += 60
else if (fourline.contains(subS))
score += 40
else if (oneline.contains(subS) == false && twoline.contains(subS) == false && threeline.contains(subS) == false && fourline.contains(subS) == false)
score += 20
} else if (register.contains("市") == true && register.contains("区") == false && register.contains("省") == false) {
val subS = register.subSequence(0, register.indexOf("市") + 1)
if (oneline.contains(subS))
score += 100
else if (twoline.contains(subS))
score += 80
else if (threeline.contains(subS))
score += 60
else if (fourline.contains(subS))
score += 40
else if (oneline.contains(subS) == false && twoline.contains(subS) == false && threeline.contains(subS) == false && fourline.contains(subS) == false)
score += 20
} else if (register.contains("市") == false && register.contains("区") == true && register.contains("省") == false) {
score == 20
} else
score += 0
} else
score += 0
} else
score += 0
//股东信息
val sqlshareholder = sqlContext.sql("select stock_holder_type from stock_holder_info where company_name = \'" + coname + "\'")
if (sqlshareholder.count() > 0) {
val shareholder = sqlshareholder.take(1)(0).toString().replace("[", "").replace("]", "")
if (shareholder.contains("法人"))
score += 100
else if (shareholder.contains("自然人"))
score += 50
else
score += 0
} else
score += 0
//主要人员
val sqlkeymember = sqlContext.sql("select manager_occupation from managers_info where company_name = \'" + coname + "\'")
if (sqlkeymember.count() > 0) {
val keymember = sqlkeymember.take(1)(0).toString().replace("[", "").replace("]", "")
if (keymember.contains("监事"))
score += 100
else
score += 50
} else
score += 0
//法院判决
val sqlcourtdecision = sqlContext.sql("select judge_role from judicial_decision where company_name = \'" + coname + "\'")
if (sqlcourtdecision.count() > 0) {
val courtdecision = sqlcourtdecision.take(1)(0).toString().replace("[", "").replace("]", "")
var countdc = 0
if (courtdecision.contains("被告")) {
countdc += 1
}
score -= countdc * 10
} else
score += 0
//被执行人信息
val sqlexecuteinfo = sqlContext.sql("select filing_time from judicial_decision_execution where company_name =\'" + coname + "\'")
if (sqlexecuteinfo.count() > 0) {
val executeinfo = sqlexecuteinfo.take(1)(0).toString().replace("[", "").replace("]", "")
val countexin = executeinfo.length
var num = 0
for (re <- executeinfo) {
if (re.toString() == "" || re.toString() == "None")
num += 1
}
score -= (countexin - num) * 10
} else
score += 0
//失信人信息
val sqllosefaith = sqlContext.sql("select *from dishonest_info where company_name =\'" + coname + "\'")
if (sqllosefaith.count() > 0) {
val losefaith = sqllosefaith.take(1)(0).toString().replace("[", "").replace("]", "")
val countlose = losefaith.length
if (countlose > 0)
score += -100
else
score += 0
} else
score += 0
//经营异常
val sqlrununusual = sqlContext.sql("select inclusion_date from company_exception_info where company_name =\'" + coname + "\'")
if (sqlrununusual.count() > 0) {
val rununusual = sqlrununusual.take(1)(0).toString().replace("[", "").replace("]", "")
val countrun = rununusual.length
score += -10 * countrun
} else
score += 0
//对外投资
val sqlinvestment = sqlContext.sql("select investment_company_name from investment_company_info where parent_company_name =\'" + coname + "\'")
if (sqlinvestment.count() > 0) {
val investment = sqlinvestment.take(1)(0).toString().replace("[", "").replace("]", "")
val countment = investment.length
score += 5 * countment
} else
score += 0
//企业基本年报
val sqlreport = sqlContext.sql("select *from company_basic_info where company_name =\'" + coname + "\'")
if (sqlreport.count() > 0) {
val report = sqlreport.take(1)(0).toString().replace("[", "").replace("]", "")
val countreport = report.length
if (countreport > 0)
score += 50
else
score += 0
} else
score += 0
if (score < 0)
score = 0
else {
score = score
}
//生成ID
var count = 0
val sqlname = "insert into tmp_enterprise( ENTERPRISE_NAME ) values (\'" + coname + "\') "
val sqlcount = "select count(*) from tmp_enterprise where ENTERPRISE_NAME =\'" + coname + "\' "
var ecusqlcount = statement.executeQuery(sqlcount)
while (ecusqlcount.next()){
count = ecusqlcount.getInt(1)
}
if (count >0) {
val ecusqlname = statement.executeUpdate(sqlname)
}
//插入征信分数
var countnum =0
var companyID = 0
val sqlID = "select ENTERPRISE_ID from tmp_enterprise where ENTERPRISE_NAME= \'" + coname +"\' "
val ecusqlID = statement.executeQuery(sqlID)
while (ecusqlID.next()){
companyID = ecusqlID.getInt("ENTERPRISE_ID")
}
val timenew = System.currentTimeMillis()
var dateFormat: SimpleDateFormat = new SimpleDateFormat("yyyy-MM-dd")
var nowtime: Date = new Date(timenew)
val currentTimenew = dateFormat.format(nowtime)
val sqlscore = "insert into tm_enterprise_credit(CREATE_TIME ,UPDATE_TIME , ENTERPRISE_ID, CREDIT_SCORE ) values( \'" + currentTimenew + "\' , \'" + currentTimenew + "\',\'" + companyID + "\',\'" + score + "\')"
val sqlcountN = "select count(*) from tm_enterprise_credit where ENTERPRISE_ID = \'" + companyID + "\'"
val ecusqlcountN = statement.executeQuery(sqlcountN)
while (ecusqlcountN.next()){
countnum = ecusqlcountN.getInt(1)
}
if (countnum > 0 ) {
val sqlnew = "update tm_enterprise_credit set CREDIT_SCORE= \'" + score + " \' , UPDATE_TIME= \'" + currentTimenew + "\'" + "where ENTERPRISE_ID= \'" + companyID + "\'"
val ecusqlnew = statement.executeUpdate(sqlnew)
} else {
val ecusqlscore = statement.executeUpdate(sqlscore)
}
}
}
}

company_credit的更多相关文章

随机推荐

  1. HFSS中查看增益

    第一步:设置查看增益条件  radiation 中设置 第二步设置扫描方式   下面的save fields 一定要勾选 第三步:扫描完成就可以查看了  results 中 查看   其中   phi ...

  2. mysql distinct()用法

    在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所 ...

  3. Windows下配置node和npm

    Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境.Node.js 使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又高效. Node.js 的使用包管理器 ...

  4. 2016(5)系统设计,web应用

    试题五(共25分) 阅读以下关于Web应用的叙述,在答题纸上回答问题1至问题3. 某软件企业拟开发一套基于Web的云平台配置管理与监控系统,该系统按租户视图.系统管理视图以及业务视图划分为多个相应的W ...

  5. oracle 表空间,用户的创建及授权,表空间基本操作

    参考地址:https://www.cnblogs.com/zhaideyou/articles/5845271.html Oracle安装完后,其中有一个缺省的数据库,除了这个缺省的数据库外,我们还可 ...

  6. ADB——模拟手机按键输入

    基本命令 adb 模拟按键输入的命令主要通过 input 进行 Usage: input [<source>] <command> [<arg>...] The s ...

  7. mybatis 分页插件

    博客地址http://www.jianshu.com/nb/5226994 引言 对于使用Mybatis时,最头痛的就是写分页,需要先写一个查询count的select语句,然后再写一个真正分页查询的 ...

  8. LeetCode 15 输入无序、有重复,输出排重版 3-Sum

    V1 粗暴的遍历,时间复杂度O(N³) func threeSumClosest(nums []int, target int) int { min := 0 result := 0 for i := ...

  9. Java集合框架面试题目

    1.为什么Map接口不继承Collection 接口? Set是无序集合,并且不允许重复的元素 List是有序的集合,并且允许重复的元素 而Map是键值对 它被视为是键的set和值的set的组合 Ma ...

  10. List、Set、Map集合

    1 List接口 我们掌握了Collection接口的使用后,再来看看Collection接口中的子类,他们都具备那些特性呢? 接下来,我们一起学习Collection中的常用几个子类(List集合. ...