#include "StdAfx.h"
#include "ConnPool.h"
#include <algorithm>
#define MIN_COUNT 10
#define MAX_COUNT 100
HANDLE hMutex;
ConnPool::ConnPool(void)
{
this->Init();
}
ConnPool::~ConnPool(void)
{
}
ConnPool* ConnPool::cpInst = NULL;
ConnPool* ConnPool::GetInstance()
{
if(NULL==cpInst)
{
cpInst = new ConnPool();
}
else
{
return cpInst;
}
}
void ConnPool::Init()
{
CoInitialize(NULL);
for(int i=0;i<MIN_COUNT;i++)
{
ConnObj *co = new ConnObj;
co->OpenConn();
if(NULL!=co)
{
//lock
WaitForSingleObject(hMutex,INFINITE);
poolList.push_back(co);
ReleaseMutex(hMutex);
}
}
}
ConnObj* ConnPool::Increase()
{
int size = poolList.size();
if(size<MAX_COUNT)
{
ConnObj *co = new ConnObj;
co->OpenConn();
if(NULL!=co)
{
//lock
WaitForSingleObject(hMutex,INFINITE);
poolList.push_back(co);
ReleaseMutex(hMutex);
return co;
}
else
{
return NULL;
}
}
else
{
return NULL;
}
}
ConnObj* ConnPool::GetConn()
{
bool bSuc;
for(list<ConnObj*>::iterator it = this->poolList.begin();it!=this->poolList.end();it++)
{
if(!(*it)->isUsed)
{
WaitForSingleObject(hMutex,INFINITE);
(*it)->isUsed = true;
(*it)->usedCount = (*it)->usedCount + 1;
ReleaseMutex(hMutex);
bSuc = true;
return (*it);
break;
}
}
//全满
if(!bSuc)
{
return Increase();
}
}
void ConnPool::DropConn(ConnObj* co)
{
co->isUsed = false;
co->usedCount = co->usedCount - 1;
}
#pragma once
#include <stdio.h>
#include <string>
#include <list>
#include <iostream>
#import "c:\Program Files\Common Files\System\ADO\msado15.dll" no_namespace rename("EOF", "adoEOF")
#include "ConnObj.h"
using namespace std;
class ConnPool
{
private:
static ConnPool* cpInst;
public:
list<ConnObj*> poolList;
public:
static ConnPool* GetInstance();
void Init();
ConnObj* Increase();
ConnObj* GetConn();
void DropConn(ConnObj* co);
public:
ConnPool(void);
~ConnPool(void);
};
#include "StdAfx.h"
#include "ConnObj.h"
ConnObj::ConnObj(void)
{
isUsed = false;
isTrans = false;
usedCount = 0;
}
ConnObj::~ConnObj(void)
{
}
void ConnObj::OpenConn()
{
_bstr_t strConnect= "Provider=SQLOLEDB;Server=localhost;Database=bty_db_main;uid=sa; pwd=123";
conn.CreateInstance("ADODB.Connection");
conn->Open(strConnect,"","",adModeUnknown);
}
void ConnObj::CloseConn()
{
conn->Close();
conn = NULL;
}
#pragma once
#include <stdio.h>
#include <string>
#include <list>
#include <iostream>
#import "c:\Program Files\Common Files\System\ADO\msado15.dll" no_namespace rename("EOF", "adoEOF")
using namespace std;
class ConnObj
{
public:
_ConnectionPtr conn;
bool isUsed;
bool isTrans;
int usedCount;
public:
void OpenConn();
void CloseConn();
public:
ConnObj(void);
~ConnObj(void);
};
// sqt.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <stdio.h>
#include <string>
#include <iostream>
#include "ConnPool.h"
#import "c:\Program Files\Common Files\System\ADO\msado15.dll" no_namespace rename("EOF", "adoEOF")
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
_bstr_t strConnect= "Provider=SQLOLEDB;Server=localhost;Database=bty_db_main;uid=sa; pwd=123";
/*CoInitialize(NULL);
_ConnectionPtr m_pConnection("ADODB.Connection");
m_pConnection.CreateInstance("ADODB.Connection");
m_pConnection->Open(strConnect,"","",adModeUnknown);
if(m_pConnection==NULL)
printf("conn error");
printf("conn ok\n");
_ConnectionPtr m_pConnection2("ADODB.Connection");
m_pConnection2.CreateInstance("ADODB.Connection");
m_pConnection2->Open(strConnect,"","",adModeUnknown);*/
ConnObj *co = ConnPool::GetInstance()->GetConn();
_ConnectionPtr m_pConnection = co->conn;
_RecordsetPtr m_pRecordset("ADODB.Recordset");
_bstr_t bstrSQL("select * from bty_product");
if(FAILED(m_pRecordset->Open(bstrSQL,strConnect,adOpenStatic,adLockOptimistic,adCmdText)))
{
printf("Open table failed!");
m_pRecordset.Release();
}
while(!m_pRecordset->GetadoEOF())
{
_variant_t varName;
varName = m_pRecordset->GetCollect("prod_name");
string strName =(char *)_bstr_t(varName);
//printf("%s\n",strName);
cout<<strName<<endl;
m_pRecordset->MoveNext();
}
m_pRecordset->Close();
m_pRecordset->Release();
while(1)
{
}
//getchar();
return 0;
}
分享到:
相关推荐
利用java编写的数据库连接池程序,希望对象要了解数据库连接池的人有所帮助。
12 Buffer Pool这个内存数据结构到底长个什么样子.pdf
NULL 博文链接:https://wujay.iteye.com/blog/1988628
sql连接池需要的commons-dbcp-1.2.1.jar,commons-pool-1.3.jar,msbase.jar,mssqlserver.jar,msutil.jar,五个jar文件
共享池(shared buffer pool) 第一次解析SQL之后, ORACLE将SQL语句存放在共享池中. ORACLE只对简单的表提供高速缓冲(cache buffering)这个功能并不适用于多表连接查询. 在数据高速缓冲区中存放着Oracle系统最近...
DB2/SQL命令大全 连接数据库: connect to [数据库名] user [操作用户名] using [密码] 创建缓冲池(8K): create bufferpool ibmdefault8k IMMEDIATE SIZE 5000 PAGESIZE 8 K ; 创建缓冲池(16K)(OA_...
Represented by Memory: Pool Paged Bytes and Memory:Pool Paged Resident Bytes. Typically between 10-30MB + size of Registry. For more information regarding “limits,” see also… Inside Windows 2000...
玛丽亚·普尔(MariaPool) 这对于my_pool_sql来说很困难,它扩展了功能并提供了维护。 该池模块基于mysql-simple-pool的池代码: : 但使用Mariasql节点模块以获得更好的性能实例化连接池连接池必须实例化。 您可以...
按 SQL 查找支持任意查询发送到sql store Pool = sumo_backend_mysql : get_pool ( sumo_mysql_backend ),Sql = " select * from people where name in ( \" Jim \" , \" Bob \" ) " ,sumo_sql_extra : find_by_sql ...
<property name="hibernate.proxool.pool_alias">dbpool</property> <property name="hibernate.proxool.xml"> ProxoolConf.xml </property> <property name="connection.provider_class"> org.hibernate....
一、解析 1、语法检查 sql语句解析的时候,先执行语法检查。看语句是否符合规范。 2、语义检查 这个阶段,数据库会去判断SQL语句...那是sql_id v$sql.sql_id.(sql语句shared pool check当匹配到了相
SQL Server 2014中另一个非常好的功能是,可以将SSD虚拟成内存的一部分,来供SQL Server数据页缓冲区使用。通过使用SSD来扩展Buffer-Pool,可以使得大量随机的IOPS由SSD来承载,从而大量减少对于数据页的随机IOPS...
41 在Buffer Pool执行完增删改之后,写入日志文件的redo log长什么样.pdf
这块位于系统全局区域SGA(system global area)的共享池(shared buffer pool)中的内存可以被所有的数据库用户共享. 因此,当你执行一个SQL语句(有时被称为一个游标)时,如果它 和之前的执行过的语句完全相同, ORACLE...
pqxx_pool 该项目在borisovs( )... 然后从提供的文件(pool.sql)中执行SQL语句,以将必要的表插入该数据库,如下所示 psql -U postgres demo < pool.sql 然后通过以下方式编译,链接并制作可执行文件 make 它
14 当我们更新Buffer Pool中的数据时,flush链表有什么用.pdf
这块位于系统全局区域SGA(system global area)的共享池(shared buffer pool)中的内存可以被所有的数据库用户共享. 因此,当你执行一个SQL语句(有时被称为一个游标)时,如果它 和之前的执行过的语句完全相同, ORACLE就...
21 生产经验:如何通过多个Buffer Pool来优化数据库的并发性能.pdf
[Asp.net+SQL]仿阿里巴巴B2B电子商务系统_hyb2b 1.把"Web"文件夹内的文件拷贝到某个文件夹 2.在IIS中新建站点,指向该文件夹,如果新建虚拟路径,会导致一些图片的不正常显示. 3."Database"文件夹内有数据库文件hyb2...