package utils;

import java.io.IOException;
import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Types;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Properties; import org.apache.tomcat.jdbc.pool.DataSource;
import org.apache.tomcat.jdbc.pool.PoolProperties; /**
* edit by lxj 2016-10-19
* 采用tomcat7的最新数据库连接池技术进行处理参考以下网址
* https://tomcat.apache.org/tomcat-7.0-doc/jdbc-pool.html#Introduction
* 需要引入tomcat-juli.jar和tomcat-jdbc.jar两个包
* @author Administrator
*
*/
public class MySqlHelper {
private static DataSource datasource;
public MySqlHelper()
{
if(datasource==null)
{
Properties pro=new Properties();
try {
pro.load(this.getClass().getResourceAsStream("/dbinfo.properties"));
} catch (IOException e) {
e.printStackTrace();
}
String jdbcDriver=pro.getProperty("driver");
String dbUrl=pro.getProperty("url");
String dbUsername=pro.getProperty("userName");
String dbPassword=pro.getProperty("password");
PoolProperties p = new PoolProperties();
p.setUrl(dbUrl);
p.setDriverClassName(jdbcDriver);
p.setUsername(dbUsername);
p.setPassword(dbPassword);
p.setJmxEnabled(true);
p.setTestWhileIdle(false);
p.setTestOnBorrow(true);
p.setValidationQuery("SELECT 1");
p.setTestOnReturn(false);
p.setValidationInterval(30000);
p.setTimeBetweenEvictionRunsMillis(30000);
p.setMaxActive(100);
p.setInitialSize(3);
p.setMaxWait(10000);
p.setRemoveAbandonedTimeout(60);
p.setMinEvictableIdleTimeMillis(30000);
p.setMinIdle(10);
p.setLogAbandoned(true);
p.setRemoveAbandoned(true);
p.setJdbcInterceptors(
"org.apache.tomcat.jdbc.pool.interceptor.ConnectionState;"+
"org.apache.tomcat.jdbc.pool.interceptor.StatementFinalizer");
datasource = new DataSource();
datasource.setPoolProperties(p);
}
}
/**
* 查询
* @param sql
* @param lo
* @return
*/
public List<Map<String, Object>> search(String sql, Object[] lo) {
List<Map<String, Object>> lm = new ArrayList<Map<String, Object>>();
Connection con = null;
PreparedStatement ps =null;
ResultSet rs=null;
try {
con = datasource.getConnection();
ps = con.prepareStatement(sql);
if (lo != null) {
for (int i = 1; i <= lo.length; i++) {
ps.setObject(i, lo[i - 1]);
}
}
rs = ps.executeQuery();
ResultSetMetaData rm = rs.getMetaData();
int cont = rm.getColumnCount();
while (rs.next()) {
Map<String, Object> mp = new HashMap<String, Object>();
for (int c = 1; c <= cont; c++) {
Object o = rs.getObject(c);
mp.put(rm.getColumnName(c), o == null ? "" : o);
}
lm.add(mp);
}
} catch (SQLException e) {
e.printStackTrace();
}
finally {
if (rs!=null) try {rs.close();}catch (Exception ex) {}
if (ps!=null) try {ps.close();}catch (Exception ex) {}
if (con!=null) try {con.close();}catch (Exception ex) {}
}
return lm;
} /**
* 保存和修改和删除
* @param sql
* @param lo
* @return
*/
public int saveorupdate(String sql, Object[] lo) {
int p = 0;
Connection con = null;
PreparedStatement ps =null;
try {
con = datasource.getConnection();
ps = con.prepareStatement(sql);
if (lo != null) {
for (int i = 1; i <= lo.length; i++) {
ps.setObject(i, lo[i - 1]);
}
}
p = ps.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}
finally {
if (ps!=null) try {ps.close();}catch (Exception ex) {}
if (con!=null) try {con.close();}catch (Exception ex) {}
}
return p;
} /**
* 获取分页数据
* @param sqlmodel 查询模型
* @return
*/
public static List<Map<String, Object>> GetPageList(Model.Sql_PageList sqlmodel) {
List<Map<String, Object>> lm = new ArrayList<Map<String, Object>>();
Connection con = null;
ResultSet rs = null;
CallableStatement Callstmt=null;
try {
con = datasource.getConnection();
Callstmt = con.prepareCall("{call PageList(?,?,?,?,?,?,?,?)}");
Callstmt.setString("_fields", sqlmodel.getStrFieldShow());
Callstmt.setString("_tables", sqlmodel.getStrTableName());
Callstmt.setString("_where", sqlmodel.getStrWhere());
Callstmt.setString("_orderby", sqlmodel.getStrFieldOrder());
Callstmt.setInt("_pageindex", sqlmodel.getPageCurrent());
Callstmt.setInt("_pagesize", sqlmodel.getPageSize());
Callstmt.registerOutParameter("_totalcount",java.sql.Types.INTEGER);
Callstmt.registerOutParameter("_pagecount",java.sql.Types.INTEGER);
Callstmt.executeQuery();
rs = Callstmt.executeQuery();
int totalcount = Callstmt.getInt("_totalcount");
int pagecount = Callstmt.getInt("_pagecount"); sqlmodel.setInfoCount(totalcount);
sqlmodel.setPageCount(pagecount);
ResultSetMetaData rm = rs.getMetaData();
int cont = rm.getColumnCount();
while (rs.next()) {
Map<String, Object> mp = new HashMap<String, Object>();
for (int c = 1; c <= cont; c++) {
Object o = rs.getObject(c);
mp.put(rm.getColumnName(c), o == null ? "" : o);
}
lm.add(mp);
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if (rs!=null) try {rs.close();}catch (Exception ex) {}
if (Callstmt!=null) try {Callstmt.close();}catch (Exception ex) {}
if (con!=null) try {con.close();}catch (Exception ex) {}
}
return lm;
}
}

MySqlHelper的更多相关文章

  1. Net连接mysql的公共Helper类MySqlHelper.cs带MySql.Data.dll下载

    MySqlHelper.cs代码如下: using System; using System.Collections.Generic; using System.Linq; using System. ...

  2. MySqlHelper、CacheHelper

    MySqlHelper代码: using System; using System.Collections; using System.Collections.Generic; using Syste ...

  3. MysqlHelper 需要重写

    using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Text;u ...

  4. PHP简单封装MysqlHelper类

    MysqlHelper.class.php 1: <?php 2:  3: /** 4: * Mysql数据帮助类 5: */ 6: class MysqlHelper 7: { 8: func ...

  5. C# MySqlHelper

    1.MySql官方提供ADO.NET访问模式的MySql.Data.dll,下载地址:http://dev.mysql.com/downloads/connector/net/ 2.MySqlHelp ...

  6. 在.NET连接MySQL以及封装好的MySQLHelper.cs

    1.首先上MySQL网站下驱动:http://www.mysql.com/products/connector/ 2.安装下载的安装包 3.我们在Visual Studio里创建一个Web Appli ...

  7. MysqlHelper类

    连接方式:server=localhost;port=3306;userid=root;password=123456789;database=mysql;persist security info= ...

  8. 简洁的MysqlHelper

    把MySqlXXX的类更改为SqlXXX就可以成为sqlHelper. 另外C#也提供了MysqlHelper和sqlHelper,用起来也挺方便的. public class MySqlHelper ...

  9. Python学习笔记10-Python MysqlHelper ,MySql 辅助类

    自己写了一个MySql辅助类,有需要的拿走: #--encoding:utf-8-- # import MySQLdb class MySQLHelper: myVersion=0.1 def __i ...

随机推荐

  1. 使用Gson解析json

    前边的博客说过将json解析成java的方法,使用的是 这几个jar包,但是在解析时层遇到一个问题,就是在将时间字符串转换为java的Timestamp对象时会抛出异常,这个问题一直放在哪里没有去解决 ...

  2. c#判断闰年

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  3. 考查SQLite 3索引对整数排序的性能影响

    做个实验,想了解SQLite3索引对整数排序的性能影响. 用这个测试表,考查绿色那列: id name date 自增型主键 字符串型,随机生成 整数型 随机生成,范围0到54354354 1 bMz ...

  4. Jquery--JS的函数包

    Jquery-----JS的函数包,直接来调用方法. 一.基本知识 用法:把jquery-1.7.2.js直接复制到要做的网站项目中,拖拽引用和JS用法一样. 二.选择器 [1]基本: 1.取ID:v ...

  5. Python内置函数总结

    1.abs() 取绝对值 1 2 3 4 >>> a = abs(-7) >>> b= abs(7) >>>print(a,b) 7 7 2.al ...

  6. Bash Shell的操作环境

    1.路径与命令查找顺序 基本上,命令运行的顺序可以这样看: 1)以相对/绝对路径执行命令,例如“/bin/ls”或“./ls”; 2)由alias找到该命令来执行; 3)由bash内置的(builti ...

  7. PPTP-VPN第一章——部署与简单使用

    最近前游戏同事搞了台的VPS,贡献出来做VPN使用.目前流行的服务器VPN软件主要有PPTP VPN和Openvpn.Openvpn虽然功能较为强大,且安全性高,支持nat穿越等等,但服务器端和客户端 ...

  8. jquery的hide()和show()

    jquery用hide()和show()函数来控制html元素的显示和隐藏. hide()和show()都可以带参数的,hide(1000)表示隐藏所需的时间为1秒.此外还可以用slow,fast参数 ...

  9. Git项目存放位置在导入Eclipse前不能存放在Eclipse Workspace

    这篇帖子的背景: 本人想将一个git项目导入至Eclipse的Workspace中,并且该项目的所有git信息.但是,该git项目在导入之前,就已经存放在Eclipse的Workspace中.在将该g ...

  10. js对象的继承以及公有私有属性的定义和读写

    最近想写一些js工具,有些方面需要用到面向对象的方法,比如继承父类属性和方法.通过私有化隐藏某些对象的属性等,因为没有系统的学习js,所以不知道怎么做,觉得很伤脑筋. 今天受到技术群里朋友的提示,并查 ...