首页 | 互联网 | IT动态 | Cisco | Windows | Linux | Java | .Net | Oracle | 华为 | 存储世界 | 服务器 | 网络设备 | IDC | 安全 | 求职招聘
IT培训 | 数字网校 | 技术专题 | 电子书下载 | 教学视频 | 网页设计 | 平面设计 | 解决方案 | 直播室 | 虚拟考场 | 搜索 | 博客 | 沙龙 | 论坛
中国IT实验室Linux频道
中国IT教育
 
首页 资讯动态 认证考试 新手入门 核心技术 高级技术 J2EE J2ME Java&XML 开源技术 其他技术 RSS订阅 论坛 专题
您现在的位置: 中国IT实验室 >> Java >> 开源技术 >> Spring >> 文章正文

Spring数据源的灵活配置巧应用

文章来源51cto博客 作者熔岩 更新时间2008-5-8 保存本文保存本文 推荐给好友推荐给好友 收藏本页收藏本页

    三、写获取数据库工具类

   package com.lavasoft.dbtest;

    import org.apache.commons.logging.Log;
    import org.apache.commons.logging.LogFactory;

    import javax.sql.DataSource;
    import java.sql.Connection;
    import java.sql.SQLException;
    import java.sql.CallableStatement;

    /**
    * Created by IntelliJ IDEA.
    * File: DBUtil.java
    * User: leizhimin
    * Date: 2008-2-21 14:26:30
    * 数据库工具
    */
    public final class DBUtil {
        private static final Log log = LogFactory.getLog(DBUtil.class);

        /**
         * 获取系统的数据源
         *
         * @return DataSource
         */
        public static DataSource getDataSource() {
            DataSource dataSource = null;
            try {
                dataSource = (DataSource) ContextHelper.getContext().getBean("rptds");
            } catch (Exception e) {
                log.error("获取数据源出错,请检查Spring数据源配置!");
            }
            return dataSource;
        }

        /**
         * 获取数据库连接
         *
         * @return Connection
         */
        public static Connection makeConnection() {
            Connection conn = null;
            try {
                conn = getDataSource().getConnection();
            } catch (SQLException e) {
                log.error("通过数据源获取数据库连接发生异常!");
                e.printStackTrace();
            }
            return conn;
        }

        /**
         * 执行没有参数的SQL过程
         *
         * @param procedureName 存储过程名字
         * @return boolean      返回存储过程执行的结果,true表示执行成功,false表示执行失败.
         */
        public static boolean executeBSDProcedure(String procedureName) {
            boolean flag = false;
            String sqlStr = "{call " + procedureName + "()}";
            CallableStatement cs;
            Connection conn = makeConnection();
            try {
                cs = (CallableStatement) conn.prepareStatement(sqlStr);
                cs.executeUpdate(sqlStr);
                flag = true;
            } catch (SQLException e) {
                log.error("调用存储过程" + sqlStr + "失败!");
                e.printStackTrace();
            }
            return flag;
        }
    }

上一页  [1] [2] [3] 下一页  

【责编:Ken】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·关于Java框架技术专题
 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题
 ·展现C#世界 C#程序设计专题
 ·Java入门 Tomcat的配置技巧精华专题
 ·Oracle RMAN物理备份技术详解
 今日更新
 社区讨论
 博客论点
 频道精选
 Java 频道导航