C#是一種廣泛使用的編程語言,而MySQL是一個流行的開源關系型數據庫系統。建立C#與MySQL的連接池可以提高程序性能,減小資源消耗,下面是一個使用C#與MySQL建立連接池的例子。
using MySql.Data.MySqlClient;
using System.Data;
using System.Threading;
public class ConnectionPool
{
private static string connectionString = "server=localhost;port=3306;database=mydb;uid=root;password=123456;";
private static Semaphore semaphore;
private static Stack<MySqlConnection> pool;
static ConnectionPool()
{
int poolSize = 10;
semaphore = new Semaphore(poolSize, poolSize);
pool = new Stack<MySqlConnection>(poolSize);
for (int i = 0; i < poolSize; i++)
{
MySqlConnection connection = new MySqlConnection(connectionString);
pool.Push(connection);
}
}
public static MySqlConnection GetConnection()
{
semaphore.WaitOne();
lock (pool)
{
if (pool.Count >0)
{
return pool.Pop();
}
}
MySqlConnection connection = new MySqlConnection(connectionString);
connection.Open();
return connection;
}
public static void ReleaseConnection(MySqlConnection connection)
{
lock (pool)
{
pool.Push(connection);
}
semaphore.Release();
}
}
在這個例子中,我們使用Semaphore和Stack類來實現連接池。Semaphore控制連接池的大小,Stack類用于管理連接對象。當一個連接請求到來時,通過semaphore.WaitOne()來獲取一個連接。如果連接池中有可用的連接,從pool中取出一個連接對象使用。如果沒有可用的連接,創建一個新連接對象并返回使用,同時需要調用connection.Open()打開連接。當一個連接使用完后,通過ReleaseConnection()將它放回到連接池中。
使用C#與MySQL建立連接池可以優化程序性能與資源利用。以上是一個使用C#實現MySQL連接池的例子,可以根據實際需求進行修改。