mybatis DBmanager

12 篇文章 0 订阅
2 篇文章 0 订阅
package com.cicro.wcm.db;


import java.util.List;


import org.apache.ibatis.session.ExecutorType;
import org.apache.ibatis.session.SqlSession;
/**
 * 数据库操作基础类.
 * <p>Title: CicroDate</p>
 * <p>Description: 数据库操作</p>
 * <p>Copyright: Copyright (c) 2010</p>
 * <p>Company: Cicro</p>
 * @author zhuliang
 * * 
 */
/**
 * 数据库操作基础类.
 * <p>Title: CicroDate</p>
 * <p>Description: 数据库操作</p>
 * <p>Copyright: Copyright (c) 2010</p>
 * <p>Company: Cicro</p>
 * @author zhuliang
 * * 
 */
public class DBManager {
/**
     * 执行sql返回一个字段的值.
     * @param sqlName sql别名,对应xml配置文件中的id
     * @param Object o 字符串或对象,用于传入查询参数
     * @return 字段的值
     *
     * History 2010-04-16 zhuliang
     */
public static String getString(String sqlName,Object o)
{
SqlSession s = IbatisSessionFactory.getInstance().openSession(ExecutorType.BATCH, false);
try{
Object tempO = s.selectOne(getSqlNameByDataType(sqlName),o);
s.commit();
if(tempO == null)
return "";
else
return tempO.toString();
}finally { 
s.close(); 
}
}

/**
     * 获取单个对象值
     * @param sqlName sql别名,对应xml配置文件中的id
     * @param Object o 字符串或对象或map,用于传入查询参数
     * @return Object
     *
     * History 2010-04-16 zhuliang
     */
public static Object queryFObj(String sqlName,Object o){
SqlSession s = IbatisSessionFactory.getInstance().openSession(ExecutorType.BATCH, false);
try{
return s.selectOne(getSqlNameByDataType(sqlName),o);
}finally { 
s.commit();
s.close(); 
}
}




/*
@SuppressWarnings("unchecked")
public static void batchQuery(String sqlName,Object o,List<PurposeBean> purposes) {
SqlSession s = IbatisSessionFactory.getInstance().openSession();
try {
//queryFList("getAllPurposeList", "");
List<PurposeBean> localPurposes = s.selectList(getSqlNameByDataType(sqlName), o);
purposes.addAll(localPurposes);

}
catch(RuntimeException e) {
s.rollback();
System.out.println(e.getMessage());
System.out.println(e.getCause());
System.out.println(e.getStackTrace());
}
catch(Throwable e) {
System.out.println("Fatal errors");
System.out.println(e.getMessage());
System.out.println(e.getCause());
System.out.println(e.getStackTrace());
}
finally {
s.commit();
s.close();
}
}
*/

/**
     * 获取列表值
     * @param sqlName sql别名,对应xml配置文件中的id
     * @param Object o 字符串或对象或map,用于传入查询参数
     * @return List
     *
     * History 2010-04-16 zhuliang
     */
@SuppressWarnings("unchecked")
public static List queryFList(String sqlName,Object o){
SqlSession s = IbatisSessionFactory.getInstance().openSession(ExecutorType.BATCH, false);
//Connection c = IbatisSessionFactory.getInstance().openSession(ExecutorType.BATCH, false).getConnection();
try{
return s.selectList(getSqlNameByDataType(sqlName),o);
}finally { 
s.commit();
s.close(); 
}
}




/**
     * 添加记录方法 
     * @param sqlName sql别名,对应xml配置文件中的id
     * @param Object o 字符串或对象或map,用于传入查询参数
     * @return boolean 成功或失败
     *
     * History 2010-04-16 zhuliang
     */
public static boolean insert(String sqlName,Object o)
{
SqlSession s = IbatisSessionFactory.getInstance().openSession(ExecutorType.BATCH, false);
try{
s.insert(getSqlNameByDataType(sqlName), o);

s.commit();
}catch(Exception ex){
ex.printStackTrace();
return false;
}
finally { 
s.close(); 
}
return true;
}

/**
     * 修改记录方法 
     * @param sqlName sql别名,对应xml配置文件中的id
     * @param Object o 字符串或对象或map,用于传入查询参数
     * @return boolean 成功或失败
     *
     * History 2010-04-16 zhuliang
     */
public static boolean update(String sqlName,Object o)
{
SqlSession s = IbatisSessionFactory.getInstance().openSession(ExecutorType.BATCH, false);
try{
s.update(getSqlNameByDataType(sqlName), o);
s.commit();
}catch(Exception ex){
ex.printStackTrace();
return false;
}
finally { 
s.close(); 
}
return true;
}
/**
     * 删除记录方法 
     * @param sqlName sql别名,对应xml配置文件中的id
     * @param Object o 字符串或对象或map,用于传入查询参数
     * @return boolean 成功或失败
     *
     * History 2010-04-16 zhuliang
     */
public static boolean delete(String sqlName,Object o)
{
SqlSession s = IbatisSessionFactory.getInstance().openSession(ExecutorType.BATCH, false);
try{
s.delete(getSqlNameByDataType(sqlName), o);
s.commit();
}catch(Exception ex){
ex.printStackTrace();
return false;
}
finally { 
s.close(); 
}
return true;
}

/******************* 以下为存储过程方法 ********************************/
/**
     * 执行存储过程(带参数的)
     * @param proName 存储别名,对应xml配置文件中的id
     * @param Object o 字符串或对象或map,用于传入查询参数
     * @return 空
     *
     * History 2010-04-16 zhuliang
     */
public static boolean executeProcedure(String proName,Object o)
{
SqlSession s = IbatisSessionFactory.getInstance().openSession(ExecutorType.BATCH, false);
try{
s.selectOne(proName,o);
s.commit();
return true;
}catch(Exception ex){
ex.printStackTrace();
return false;
}     
finally {
s.close(); 
}
}
/**
     * 执行存储过程(不带参数的)
     * @param proName 存储别名,对应xml配置文件中的id
     * @param Object o 字符串或对象或map,用于传入查询参数
     * @return 空
     *
     * History 2010-04-16 zhuliang
     */
public static boolean executeProcedure(String proName)
{
SqlSession s = IbatisSessionFactory.getInstance().openSession(ExecutorType.BATCH, false);
try{
s.selectOne(proName);
s.commit();
return true;
}catch(Exception ex){
ex.printStackTrace();
return false;
}finally {
s.close(); 
}
}

/**
     * 根据数据库类型得到匹配的sql名称
     * @param String sqlName sql名称
     * @return String 返回真实的sql名称
     *
     * History 2010-04-16 zhuliang
     */
public static String getSqlNameByDataType(String sqlName)
{
String data_type_name = BoneDataSourceFactory.getDataTypeName();
//oracle为默认数据库,后面不会跟数据库别名
if(!"oracle".equals(data_type_name) && IbatisSessionFactory.getInstance().getConfiguration().hasStatement(sqlName+"_"+data_type_name))
sqlName = sqlName+"_"+data_type_name;
return sqlName;
}


/*
*  以下新增方法为处理性能问题所加 
*  add  2014-03-20
*/

// overloaded function, takes SqlSession to avoid local open-close db connections
public static Object queryFObj(SqlSession sqlSess, String sqlName, Object o){
try{
return sqlSess.selectOne(getSqlNameByDataType(sqlName), o);
}
/*
catch(RuntimeException e) {
sqlSess.rollback();
System.out.println(e.getMessage());
System.out.println(e.getCause());
System.out.println(e.getStackTrace());
return null;
}
*/
finally {}
}

@SuppressWarnings("unchecked")
public static List queryFList(SqlSession sqlSess, String sqlName, Object o){
try{
return sqlSess.selectList(getSqlNameByDataType(sqlName), o);
}
/*
catch(Throwable e) {
System.out.println(e.getMessage());
System.out.println(e.getCause());
System.out.println(e.getStackTrace());
return null;
}
*/
finally {}
}


public static void main(String[] args)
{  
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值