<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
本文主要介紹了java操作gaussDB資料庫的實現範例,分享給大家,具體如下:
package com.shiwusuo.ReadHdfsToClickHouse.gauss import java.sql.{Connection, DriverManager} import java.util.Properties import org.apache.spark.sql.DataFrame import scala.collection.mutable.ArrayBuffer; object GaussDBUtils { val urls = application.gaussURL //資料庫URL val username = application.gaussName //使用者名稱 val password = application.gaussPass //密碼 val database = application.gaussDatabase val gaussCreateDatabase = application.gaussCreateDatabase //val driver = "org.postgresql.Driver" val driver = application.driver var conn: Connection = null; def getConnection(): Connection = { try { Class.forName(driver) conn = DriverManager.getConnection(urls, username, password) conn } catch { case e: Throwable => e.printStackTrace() println("連線gaussDB失敗===請檢查原因") conn } } //建立表 def createGaussTable(sql: String): Unit = { try { val connection = getConnection() val statement = connection.createStatement() statement.executeUpdate(sql) statement.close() } catch { case e: Exception => e.printStackTrace() } } //判斷是否存在該表 def tableExists(database: String, tablName: String): Boolean = { val connection = getConnection() val set = connection.getMetaData.getTables(null, database, tablName, null) if (set.next()) { return true } else { println("gaussDB中" + tablName + "不存在") return false } } //建立資料庫 def createDatabase(): Unit = { val connection = getConnection() val statement = connection.createStatement() statement.executeUpdate(gaussCreateDatabase) statement.close() } //查詢 、執行sql語句 def ReadFromGaussDB(sql: String): Unit = { try { val connection = getConnection() val statement = connection.createStatement() val set = statement.executeQuery(sql) while (set.next()) { val str = set.getString(2) println(str) } }catch { case e: Exception => e.printStackTrace() } } //獲取gaussDB中所有表名 def getTablesByGaussDB(db: String) :ArrayBuffer[String]={ val tablesList = new ArrayBuffer[String]() val connection = getConnection() val set = connection.getMetaData.getTables(null,db,null,null) while (set.next()) { val str: String = set.getString("TABLE_NAME") tablesList += str // println(str) } tablesList } //根據resourceId刪除gaussDB資料 def deleteDataByResourceId(sql:String): Unit ={ val connection = getConnection() val statement = connection.createStatement() statement.executeUpdate(sql) } //插入gaussDB庫中 def insertgaussDBTable(table: String, df: DataFrame): Unit = { val connectionProperties = new Properties() connectionProperties.setProperty("user", username) connectionProperties.setProperty("password", password) println("+++++++開始寫入GaussDB++++++" + table + "共有" + df.count()) df.write.mode("append").option("batchsize", "50000").option("isolationLevel", "NONE"). option("numPartitions", "1").jdbc(urls, table, connectionProperties) println("=================GaussDB完成寫入========" + table + "====================") } def main(args: Array[String]): Unit = { //val bool = tableExists("gaussdb","test_01087") //println(bool) //val a = "CREATE TABLE gaussdb.CDPCPn (n code bigint NULL,n ident bigint NULL,n len bigint NULL,n lineNum1 bigint NULL,n lineNum2 bigint NULL,n lineNum3 bigint NULL,n lineNum4 bigint NULL,n lineName varchar(10000000) NULL,n begTime bigint NULL,n endTime bigint NULL,n comDur bigint NULL,n meanID varchar(10000000) NULL,n siteID varchar(10000000) NULL,n unitID varchar(10000000) NULL,n taskID varchar(10000000) NULL,n guid bigint NULL,n storTime bigint NULL,n mdSecDeg varchar(10000000) NULL,n fileSecDeg varchar(10000000) NULL,n secDegPro varchar(10000000) NULL,n ipVer bigint NULL,n srcAddr varchar(10000000) NULL,n dstAddr varchar(10000000) NULL,n srcPort bigint NULL,n dstPort bigint NULL,n protNum bigint NULL,n srcAddrV6 varchar(10000000) NULL,n dstAddrV6 varchar(10000000) NULL,n srcLoc varchar(10000000) NULL,n dstLoc varchar(10000000) NULL,n srcISP varchar(10000000) NULL,n dstISP varchar(10000000) NULL,n srcAS varchar(10000000) NULL,n dstAS varchar(10000000) NULL,n protInfo varchar(10000000) NULL,n linkInfo varchar(10000000) NULL,n protType varchar(10000000) NULL,n protName varchar(10000000) NULL,n mulRouFlag bigint NULL,n intFlag bigint NULL,n strDirec bigint NULL,n pktNum bigint NULL,n payLen bigint NULL,n hashId bigint NULL,n sessionID varchar(10000000) NULL,n resourceId varchar(10000000) NULLn )" //createGaussTable(a) //createtable // ReadFromGaussDB("select * from test_0110.user") //val strings = getTablesByGaussDB("test_0301") //strings.foreach(println) //DELETE FROM test_0110.AOE WHERE resourceId = 518824231216091205 val b ="DELETE FROM test_0110."ANS" WHERE "resourceId" = '518824231216091205'" println(b) deleteDataByResourceId(b) } }
到此這篇關於java操作gaussDB資料庫的實現範例的文章就介紹到這了,更多相關java操作gaussDB內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45