mysqlcapi简单连接池_MySQL
bitsCN.com
连接池为了解决频繁的创建、销毁所带来的系统开销。
简而言之,就是 自己先创建一定量的连接,然后在需要的时候取出一条连接使用。
当然如果你只有一个线程连接数据库,而且不是实时返回结果,那么你完全不必用连接池。
想一下网络大型游戏服务器,你就明白为什么需要连接池了。
自己敲代码写了一个简单的类,实现连接池,虽然没有mysql++那么强大,但是还是自己有收获。
Csqlpool.h 头文件实现如下:
#pragma once#include <WinSock2.h>#include <mysql.h>#include <list>#pragma comment( lib , "libmysql.lib" )using namespace std;class Csqlpool{public: ~Csqlpool(void); static Csqlpool *GetSqlPool(); bool IniSqlPool( const char *host , const char *name , const char *pwd , unsigned int port , unsigned int conMax ); //初始化连接池 bool SelectDB( MYSQL *sql, const char *DB); //选择数据库 MYSQL *GetConnect(); // 获取连接 void RelConnect(MYSQL *sql) ; // 释放连接 MYSQL_RES* GetQuery( MYSQL *sql , const char *query); //mysql操作 增删查改 void RelQuery(MYSQL_RES *res); //释放MYSQL_RES资源 bool Query(MYSQL *sql , const char *query); //增、删、改操作protected: Csqlpool(void);private: list<MYSQL *> m_sql_free; //空闲连接 static Csqlpool *pSqlPool; CRITICAL_SECTION m_session; //获取空闲线程};
Csqlpool.cpp 实现如下:
#include "StdAfx.h"#include "Csqlpool.h"Csqlpool *Csqlpool::pSqlPool = NULL;Csqlpool::Csqlpool(void){ InitializeCriticalSection( &m_session );}Csqlpool::~Csqlpool(void){ while ( m_sql_free.size() ) { mysql_close( m_sql_free.front() ); m_sql_free.pop_front(); } DeleteCriticalSection(&m_session);}Csqlpool* Csqlpool::GetSqlPool(){ if ( pSqlPool == NULL ) { return new Csqlpool; } return pSqlPool;}bool Csqlpool::IniSqlPool( const char *host ,const char *name , const char *pwd , unsigned int port , unsigned int conMax ) //初始化连接池{ int nsum = 0 ; for (unsigned int i = 0 ; i < conMax ;++i ) { MYSQL *pmysql; pmysql = mysql_init( (MYSQL*)NULL ); if ( pmysql != NULL ) { if ( mysql_real_connect( pmysql , host , name , pwd , NULL , 3306 , NULL , 0 ) ) { m_sql_free.push_back(pmysql); } else { if ( nsum++ == 100 ) { return false; } continue; } } continue; } return true;}bool Csqlpool::SelectDB( MYSQL *sql, const char *DB) //选择数据库{ if(mysql_select_db(sql , DB)) { return false; } return true;}MYSQL* Csqlpool::GetConnect() // 获取连接{ if ( m_sql_free.size() ) { EnterCriticalSection(&m_session); MYSQL *mysql = m_sql_free.front(); m_sql_free.pop_front(); LeaveCriticalSection(&m_session); return mysql; } else return NULL;}void Csqlpool::RelConnect(MYSQL *sql) // 释放连接{ EnterCriticalSection(&m_session); m_sql_free.push_back(sql); LeaveCriticalSection(&m_session);}MYSQL_RES* Csqlpool::GetQuery( MYSQL *sql , const char *query) //查询操作{ if ( mysql_query( sql , query ) == 0 ) { return mysql_store_result( sql ); } else return NULL;}void Csqlpool::RelQuery(MYSQL_RES *res) //mysql_res release{ mysql_free_result(res);}bool Csqlpool::Query(MYSQL *sql , const char *query) //增、删、改操作{ if ( mysql_query( sql , query ) ) { return false; } return true;}
testsqlpool.cpp 测试文件实现如下:
// testsqlpool.cpp : 定义控制台应用程序的入口点。//#include "stdafx.h"#include "Csqlpool.h"#include <iostream>using namespace std;Csqlpool *psql = Csqlpool::GetSqlPool();DWORD WINAPI ThreadProc( LPVOID lpParameter);int _tmain(int argc, _TCHAR* argv[]){ if(!psql->IniSqlPool("127.0.0.1" , "root" ,"123",3306,10)) { cout<<"连接错误"<<endl; } HANDLE phan[2] ; DWORD threadid[2]; int n1 = 0, n2 = 100;; phan[0] = CreateThread( NULL , 0 , ThreadProc , &n1 , 0 , &threadid[0] ); phan[1] = CreateThread( NULL , 0 , ThreadProc , &n2 , 0 , &threadid[1] ); WaitForMultipleObjects( 2 , phan , true , INFINITE ); CloseHandle(phan[0]); CloseHandle(phan[1]); return 0;}DWORD WINAPI ThreadProc( LPVOID lpParameter){ int index = *(int *)lpParameter ; int i = 1; MYSQL *sql = psql->GetConnect(); string stemp = "insert into actor( actor_id , first_name , last_name,last_update )values(/""; string strsql; char str[10]; if ( psql->SelectDB(sql , "sakila") ) { while ( i != 100 ) { sprintf( str , "%d" , i+index ); strsql = stemp ; strsql += str; strsql += "/",/"0/",/"0/",/"0/")"; if(!sql) return 0; if(!psql->Query( sql ,strsql.c_str() )) { cout<<"add false"<<endl; } ++i; } psql->RelConnect(sql); } return 0;}

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Bagaimana untuk membaca beberapa rekod pertama dalam pangkalan data menggunakan PHP? Apabila membangunkan aplikasi web, kita selalunya perlu membaca data daripada pangkalan data dan memaparkannya kepada pengguna. Kadangkala, kita hanya perlu memaparkan beberapa rekod pertama dalam pangkalan data, bukan keseluruhan kandungan. Artikel ini akan mengajar anda cara menggunakan PHP untuk membaca beberapa rekod pertama dalam pangkalan data dan memberikan contoh kod khusus. Mula-mula, anggap bahawa anda telah menyambung ke pangkalan data dan memilih jadual yang anda mahu kendalikan. Berikut ialah contoh sambungan pangkalan data yang mudah:

Dalam program Java, menyambung ke pangkalan data adalah operasi yang sangat biasa. Walaupun perpustakaan dan alatan kelas siap sedia boleh digunakan untuk menyambung ke pangkalan data, pelbagai situasi tidak normal mungkin masih berlaku semasa pembangunan program, antaranya SQLException adalah salah satu daripadanya. SQLException ialah kelas pengecualian yang disediakan oleh Java Ia menerangkan ralat yang berlaku semasa mengakses pangkalan data, seperti ralat pernyataan pertanyaan, ketiadaan jadual, pemutusan sambungan, dll. Untuk pengaturcara Java, terutamanya yang menggunakan JDBC (Java Data

Bahasa Go menyambung ke pangkalan data dengan mengimport pemacu pangkalan data, mewujudkan sambungan pangkalan data, melaksanakan penyata SQL, menggunakan penyata yang disediakan dan pemprosesan transaksi. Pengenalan terperinci: 1. Import pemacu pangkalan data dan gunakan pakej github.com/go-sql-driver/mysql untuk menyambung ke pangkalan data MySQL 2. Wujudkan sambungan pangkalan data dan sediakan maklumat sambungan pangkalan data, termasuk alamat pangkalan data, pengguna; nama, kata laluan, dll. Wujudkan sambungan pangkalan data dan seterusnya melalui fungsi sql.Open.

Menggunakan bahasa Go untuk menyambung ke pangkalan data: Meningkatkan prestasi dan kecekapan aplikasi Apabila aplikasi berkembang dan bilangan pengguna meningkat, penyimpanan dan pemprosesan data menjadi semakin penting. Untuk meningkatkan prestasi dan kecekapan aplikasi, penyambungan dan pengendalian pangkalan data dengan betul adalah bahagian yang penting. Sebagai bahasa pembangunan yang pantas, boleh dipercayai dan sangat sesuai, bahasa Go berpotensi untuk memberikan prestasi yang cekap semasa memproses pangkalan data. Artikel ini akan memperkenalkan cara menggunakan bahasa Go untuk menyambung ke pangkalan data dan memberikan beberapa contoh kod. Pasang pemacu pangkalan data menggunakan bahasa Go

Langkah dan teknik untuk melaksanakan inventori produk dalam PHP Dalam industri e-dagang, pengurusan inventori produk adalah tugas yang sangat penting. Pengiraan inventori yang tepat pada masanya dan tepat boleh mengelakkan kelewatan jualan, aduan pelanggan dan masalah lain yang disebabkan oleh kesilapan inventori. Artikel ini akan memperkenalkan langkah dan teknik tentang cara menggunakan PHP untuk melaksanakan pengiraan inventori produk dan memberikan contoh kod. Langkah 1: Buat pangkalan data Pertama, kita perlu mencipta pangkalan data untuk menyimpan maklumat produk. Buat pangkalan data bernama "inventori" dan kemudian buat pangkalan data bernama "prod

Belajar bahasa Go: pengetahuan asas menyambung ke pangkalan data, contoh kod khusus diperlukan bahasa Go ialah bahasa pengaturcaraan sumber terbuka. Cirinya yang mudah dan cekap menjadikannya disukai dan digunakan oleh semakin ramai pembangun. Semasa proses pembangunan, selalunya perlu untuk mewujudkan sambungan dengan pangkalan data untuk melaksanakan operasi seperti membaca, menulis, mengemas kini dan memadam data. Oleh itu, mempelajari cara menyambung ke pangkalan data dalam bahasa Go adalah kemahiran yang sangat penting. Pemacu pangkalan data Dalam bahasa Go, pemacu pangkalan data diperlukan untuk menyambung ke pangkalan data. Pada masa ini, pemacu pangkalan data utama bahasa Go ialah:

Memasang dan mengkonfigurasi PHP pada sistem Ubuntu untuk menyambung ke pangkalan data MSSQL adalah tugas biasa, terutamanya apabila membangunkan aplikasi web. Dalam artikel ini, kami akan memperkenalkan cara memasang PHP, sambungan MSSQL dan mengkonfigurasi sambungan pangkalan data pada sistem Ubuntu, sambil memberikan contoh kod khusus. Langkah 1: Pasang sambungan PHP dan MSSQL Pasang PHP Mula-mula, anda perlu memastikan bahawa PHP dipasang pada sistem Ubuntu anda. PHP boleh dipasang dengan arahan berikut: sudoaptu

Tajuk: Apakah fungsi penting pakej Jar MySQL? MySQL ialah sistem pengurusan pangkalan data hubungan popular yang digunakan oleh banyak pembangun Java semasa membangunkan aplikasi. Untuk berinteraksi dengan pangkalan data MySQL dalam projek Java, pakej Jar pemacu Java rasmi yang disediakan oleh MySQL biasanya digunakan. Pakej Jar MySQL mempunyai banyak fungsi penting Artikel ini akan memperkenalkan beberapa daripadanya dan memberikan contoh kod khusus. 1. Sambung ke MyS
