1.

 using System;
using System.Collections;
using MySql.Data.MySqlClient; namespace Helper
{
/// <summary>
/// MySQL连接池
/// </summary>
public static class MySQLConnPool
{
//private static string connStr = "server=localhost;User ID=root;Password=qwer1234;database=test;";//连接字符串
private static ArrayList poolLs = new ArrayList();//连接池
private static int max = ;//连接池最大数量 /// <summary>
/// 获取连接对象
/// </summary>
/// <param name="connStr">数据库连接字符串</param>
/// <returns></returns>
public static MySqlConnection GetConn(string connStr)
{
lock (poolLs)
{
MySqlConnection retConn = null;//超出线程池大小限制时返回null
if (poolLs.Count > )
{
retConn = (MySqlConnection)poolLs[];//获取池中第一个
poolLs.RemoveAt();//从池中移除
}
else
{
retConn = new MySqlConnection(connStr);//连接池中没有连接,创建一个
retConn.Open();
}
return retConn;
}
} /// <summary>
/// 关闭连接或添加到连接池
/// </summary>
/// <param name="conn"></param>
public static void Close(MySqlConnection conn)
{
lock (poolLs)
{
if (poolLs.Count < max)//连接池只保留最大数量的连接
{
poolLs.Add(conn);//连接池数量小于限制,将连接添加到连接池
}
else
{
conn.Close();//线程池超出数量限制,关闭连接
}
}
}
}
}

连接池代码

2.

 using System;
using System.Web.Mvc;
using System.Data;
using MySql.Data.MySqlClient;
using Helper; namespace MVC4.Controllers
{
public class testController : Controller
{
private static string connStr = "server=localhost;User ID=root;Password=12345678;database=test;";
public ActionResult Index()
{
MySqlConnection conn = MySQLConnPool.GetConn(connStr);
MySqlCommand cmd = new MySqlCommand("Select * from us_BaseInfo", conn);
MySqlDataReader dr = cmd.ExecuteReader();
if (dr.Read())
{
}
dr.Close();//关闭MySqlDataReader
MySQLConnPool.Close(conn);
return View();
}
}
}

连接池使用

MySQL连接池的更多相关文章

  1. 解决Mysql连接池被关闭 ,hibernate尝试连接不能连接的问题。 (默认mysql连接池可以访问的时间为8小时,如果超过8小时没有连接,mysql会自动关闭连接池。系统发布第二天访问链接关闭问题。

    解决Mysql连接池被关闭  ,hibernate尝试连接不能连接的问题. (默认MySQL连接池可以访问的时间为8小时,如果超过8小时没有连接,mysql会自动关闭连接池. 所以系统发布第二天访问会 ...

  2. Java Mysql连接池配置和案例分析--超时异常和处理

    前言: 最近在开发服务的时候, 发现服务只要一段时间不用, 下次首次访问总是失败. 该问题影响虽不大, 但终究影响用户体验. 观察日志后发现, mysql连接因长时间空闲而被关闭, 使用时没有死链检测 ...

  3. tomcat中使用mysql连接池的配置

    1.下载相应的jar包,添加到工程中 需要下载的包主要有commons-pool2-2.2 commons-dbcp2-2.0.1-src commons-dbcp2-2.0.1  commons-c ...

  4. mysql连接池的使用工具类代码示例

    mysql连接池代码工具示例(scala): import java.sql.{Connection,PreparedStatement,ResultSet} import org.apache.co ...

  5. 用swoole简单实现MySQL连接池

    MySQL连接池 在传统的网站开发中,比如LNMP模式,由Nginx的master进程接收请求然后分给多个worker进程,每个worker进程再链接php-fpm的master进程,php-fpm再 ...

  6. 实现一个协程版mysql连接池

    实现一个协程版的mysql连接池,该连接池支持自动创建最小连接数,自动检测mysql健康:基于swoole的chanel. 最近事情忙,心态也有点不积极.技术倒是没有落下,只是越来越不想写博客了.想到 ...

  7. mysql连接池模块

    如果不想程序在查询数据时卡死或等待过长时间,一般不推荐在node中开启一个连接后全部查询都用这个链接并且不关闭.因为node里面的mysql不像php里的那样会在完成查询后断开,只要不主动断开,连接一 ...

  8. python中实现mysql连接池

    python中实现mysql连接池 import pymysql from DBUtils.PooledDB import PooledDB MYSQL_HOST = 'localhost' USER ...

  9. workerman如何写mysql连接池

    首先要了解为什么用连接池,连接池能为你解决什么问题 连接池主要的作用1.减少与数据服务器建立TCP连接三次握手及连接关闭四次挥手的开销,从而降低客户端和mysql服务端的负载,缩短请求响应时间2.减少 ...

随机推荐

  1. 【131202】SQL

    SELECT TOP 2 * FROM Persons SELECT *FROM PersonsWHERE ROWNUM <= 5   SELECT * FROM Persons WHERE C ...

  2. AngularJS讲义-控制器

    在Angular中,控制器(Controller)就是基于JavaScript的构造方法,主要用来构造模型并建立模型和视图之间的数据绑定.控制器里面定义了应用程序的逻辑和行为. 通过ng-contro ...

  3. struct和typedef struct

    转自:http://www.cnblogs.com/qyaizs/articles/2039101.html struct和typedef struct 分三块来讲述: 1 首先://注意在C和C++ ...

  4. World of Warcraft

    一大堆快捷键 鼠标中键:致盲 上滚:闪避 下滚:疾跑 通用:~伺机待发 Q加速 E斗篷 R徽章 T消失 alt+Q脚踢,alt+W毒刃 alt+E亡灵意志 alt+D烟幕弹 alt+F死亡标记 Z天降 ...

  5. bat学习

    http://www.cnblogs.com/gaohongchen01/p/4042047.html http://www.cnblogs.com/amylis_chen/p/3585339.htm ...

  6. 在网页中显示html代码

    string str = "<div>aaa</div>"; this.Literal1.Text = string.Format("<pr ...

  7. 处理滚动条置底的JS代码

    function scrollTopToBottom(){ var seffheight =$(".consultingRecords_view").height(); $(&qu ...

  8. C#的Enum——枚举

    枚举 枚举类型声明为一组相关的符号常数定义了一个类型名称.枚举用于“多项选择”场合,就是程序运行时从编译时已经设定的固定数目的“选择”中做出决定. 枚举类型(也称为枚举)为定义一组可以赋给变量的命名整 ...

  9. matlab坐标外围背景变白色

    set(gcf,'Color',[1,1,1]) 默认图片是这样的: 出图之前使用命令,外围变白后效果如下:

  10. 对于for的一些认识

    /*▲            ▲▲            ▲▲▲            ▲▲▲▲            ▲▲▲▲▲            ▲▲▲▲▲▲*/例:如图用for嵌套打印一个三 ...