代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Scala
】
数据库连接池
作者:
泺清
/ 发布于
2015/5/12
/
1342
package org.dave.common.database import java.util.concurrent.ConcurrentHashMap import java.util.ResourceBundle import com.jolbox.bonecp.{BoneCPConfig, BoneCP} import java.sql.Connection import org.slf4j.LoggerFactory /** * 数据库连接池 * @Anthor David Day * @Date 2011-6-23 */ object DatabaseConnectionPool { private val log = LoggerFactory.getLogger(DatabaseConnectionPool.getClass) private val pools = new ConcurrentHashMap[String, BoneCP]() private val reader = ResourceBundle.getBundle("connection") /** * 启动数据库 * @param databases 数据库列表 */ def startup(datebases : Array[String]) { datebases.foreach(database => { Class.forName(reader.getString(database + ".driver")) val config = new BoneCPConfig config.setJdbcUrl(database + ".url") config.setUsername(database + ".username") config.setPassword(database + ".password") config.setMaxConnectionsPerPartition(Integer.parseInt(database + ".max_connection")) config.setMinConnectionsPerPartition(Integer.parseInt(database + ".min_connection")) config.setPartitionCount(Integer.parseInt(database + ".partition_count")) pools.put(database, new BoneCP(config)) log.info("Startup datebase: "+ database) }) } /** * 关闭有数据库 * @param databases 数据库列表 */ def shutdown(datebaseNames : Array[String]) { datebaseNames.foreach(name => { pools.get(name).shutdown log.info("Shutdown datebase: "+ name) }) } /** * 关闭所有数据库 */ def shutdownAll { val iter = pools.entrySet.iterator while (iter.hasNext) { val entry = iter.next entry.getValue.shutdown log.info("Shutdown datebase: "+ entry.getKey) } } /** * @param 数据库 * @return 数据库连接 */ def getConnection(database : String) = pools.get(database).getConnection /** * 查询数据库 * @param 数据库 * @return 数据库连接 */ def doQuery(database : String) (query : Connection => Unit) { val conn = getConnection(database) try { query(conn) } finally { conn.close } } /** * 更新数据库 * @param 数据库 * @return 数据库连接 */ def doUpdate(database : String) (execute : Connection => Unit) { val conn = getConnection(database); try { conn setAutoCommit false execute(conn) conn.commit } catch { case t : Throwable => { conn.rollback throw t } } finally { conn.close } } }
试试其它关键字
数据库连接池
同语言下
.
Scala正则判断替换
.
spark 提交
.
判断字符串是否能转换为数字
.
Scala字符串处理常用函数
.
Scala调用Java类
.
返回去掉l头两个元素的新列表
.
通过索引获取列表值
.
用“:::”叠加创建新列表
.
用字符串创建列表
.
创建空列表
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
泺清
贡献的其它代码
(
14
)
.
错误重定向和终止进程
.
数据库连接池
.
scala通用dao
.
多父类虚函数
.
压缩css
.
全组合算法
.
简单的RandomUtil
.
随机生成指定字数的简体汉字
.
SQLite保存数据 和更新显示
.
谷歌超链接
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3