⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 minervaconnectionfactory.java

📁 Sequoia ERP是一个真正的企业级开源ERP解决方案。它提供的模块包括:电子商务应用(e-commerce), POS系统(point of sales),知识管理,存货与仓库管理
💻 JAVA
字号:
/* * $Id: MinervaConnectionFactory.java 6609 2006-01-29 09:50:01Z jonesde $ * * Copyright (c) 2003 The Open For Business Project - www.ofbiz.org * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT * OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR * THE USE OR OTHER DEALINGS IN THE SOFTWARE. * */package org.ofbiz.entity.transaction;import java.sql.Connection;import java.sql.SQLException;import java.util.HashMap;import java.util.Iterator;import java.util.Map;import java.util.Set;import org.ofbiz.base.util.Debug;import org.ofbiz.entity.GenericEntityException;import org.ofbiz.minerva.pool.jdbc.xa.XAPoolDataSource;import org.ofbiz.minerva.pool.jdbc.xa.wrapper.XADataSourceImpl;import org.w3c.dom.Element;/** * MinervaConnectionFactory - Central source for Minerva JDBC Objects * * @author     <a href="mailto:jaz@ofbiz.org">Andy Zeneski</a> * @version    $Rev: 6609 $ * @since      3.0 */public class MinervaConnectionFactory {            public static final String module = MinervaConnectionFactory.class.getName();                            protected static Map dsCache = new HashMap();        public static Connection getConnection(String helperName, Element jotmJdbcElement) throws SQLException, GenericEntityException {                                       XAPoolDataSource pds = (XAPoolDataSource) dsCache.get(helperName);                if (pds != null) {                                              return TransactionFactory.getCursorConnection(helperName, pds.getConnection());        }                synchronized (MinervaConnectionFactory.class) {            pds = (XAPoolDataSource) dsCache.get(helperName);            if (pds != null) {                                           return pds.getConnection();            } else {                pds = new XAPoolDataSource();                pds.setPoolName(helperName);            }            XADataSourceImpl ds = new XADataSourceImpl();            if (ds == null)                throw new GenericEntityException("XADataSource was not created, big problem!");                        ds.setDriver(jotmJdbcElement.getAttribute("jdbc-driver"));            ds.setURL(jotmJdbcElement.getAttribute("jdbc-uri"));                        String transIso = jotmJdbcElement.getAttribute("isolation-level");            if (transIso != null && transIso.length() > 0) {                if ("Serializable".equals(transIso)) {                    pds.setTransactionIsolation(Connection.TRANSACTION_SERIALIZABLE);                } else if ("RepeatableRead".equals(transIso)) {                    pds.setTransactionIsolation(Connection.TRANSACTION_REPEATABLE_READ);                } else if ("ReadUncommitted".equals(transIso)) {                    pds.setTransactionIsolation(Connection.TRANSACTION_READ_UNCOMMITTED);                } else if ("ReadCommitted".equals(transIso)) {                    pds.setTransactionIsolation(Connection.TRANSACTION_READ_COMMITTED);                } else if ("None".equals(transIso)) {                    pds.setTransactionIsolation(Connection.TRANSACTION_NONE);                }                                                        }                        // set the datasource in the pool                        pds.setDataSource(ds);            pds.setJDBCUser(jotmJdbcElement.getAttribute("jdbc-username"));            pds.setJDBCPassword(jotmJdbcElement.getAttribute("jdbc-password"));                        // set the transaction manager in the pool            pds.setTransactionManager(TransactionFactory.getTransactionManager());                        // configure the pool settings            try {                            pds.setMaxSize(Integer.parseInt(jotmJdbcElement.getAttribute("pool-maxsize")));            } catch (NumberFormatException nfe) {                Debug.logError("Problems with pool settings [pool-maxsize=" + jotmJdbcElement.getAttribute("pool-maxsize") + "]; the values MUST be numbers, using default of 20.", module);                pds.setMaxSize(20);            } catch (Exception e) {                Debug.logError(e, "Problems with pool settings", module);                pds.setMaxSize(20);            }            try {                            pds.setMinSize(Integer.parseInt(jotmJdbcElement.getAttribute("pool-minsize")));            } catch (NumberFormatException nfe) {                Debug.logError("Problems with pool settings [pool-minsize=" + jotmJdbcElement.getAttribute("pool-minsize") + "]; the values MUST be numbers, using default of 5.", module);                pds.setMinSize(2);            } catch (Exception e) {                Debug.logError(e, "Problems with pool settings", module);                pds.setMinSize(2);            }                                              // cache the pool            dsCache.put(helperName, pds);                                                                          return TransactionFactory.getCursorConnection(helperName, pds.getConnection());        }                    }        public static void closeAll() {        Set cacheKeys = dsCache.keySet();        Iterator i = cacheKeys.iterator();        while (i.hasNext()) {            String helperName = (String) i.next();            XAPoolDataSource pds = (XAPoolDataSource) dsCache.remove(helperName);            pds.close();           }                                                                                 }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -