‘壹’ 什么是数据库连接
数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。对数据库连接的管理能显着影响到整个应用程序的伸缩性和健壮性,影响到程序的性能指标。数据库连接池正是针对这个问题提出来的。数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而再不是重新建立一个;释放空闲时间超过最大空闲时间的数据库连接来避免因为没有释放数据库连接而引起的数据库连接遗漏。这项技术能明显提高对数据库操作的性能。
数据库连接池在初始化时将创建一定数量的数据库连接放到连接池中,这些数据库连接的数量是由最小数据库连接数来设定的。无论这些数据库连接是否被使用,连接池都将一直保证至少拥有这么多的连接数量。连接池的最大数据库连接数量限定了这个连接池能占有的最大连接数,当应用程序向连接池请求的连接数超过最大连接数量时,这些请求将被加入到等待队列中。数据库连接池的最小连接数和最大连接数的设置要考虑到下列几个因素:
1) 最小连接数
是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费;
2) 最大连接数
是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影响之后的数据库操作。
3) 如果最小连接数与最大连接数相差太大,
那么最先的连接请求将会获利,之后超过最小连接数量的连接请求等价于建立一个新的数据库连接。不过,这些大于最小连接数的数据库连接在使用完不会马上被释放,它将被放到连接池中等待重复使用或是空闲超时后被释放。
‘贰’ 如何连接数据库
如果您是ACCESS数据库。这是最简单的一种数据库,它通常都是随着数据库源码可以放在一起的,只需要知道FTP地址、账户与密码就可以连接。利用FTP上传工具上传即可。上传工具小编在下方资料参考处提供软件下载链接。
‘叁’ 数据库如何连接
//初始化数据库连接
::CoInitialize(NULL);
连接数据库
[cpp]viewplainprint?
BOOLCLogin::ConnectDB(void)
{
HRESULThr=NULL;
try
{
hr=m_pConnection.CreateInstance("ADODB.Connection");///创建Connection对象
if(SUCCEEDED(hr))
{
//登录数据库并连接数据库DBCourse
//这里的server不能写成127.0.0.1否则会出现未指定的错误,应该写成sqlserver登录界面的服务器名称
m_pConnection->ConnectionString="driver={SQLServer};server=LOGO-PC\LOGO;uid=DBCourse;pwd=DBCourse;";
m_pConnection->Open("","","",adConnectUnspecified);
m_pConnection->DefaultDatabase="DBCourse";
}
else
{
AfxMessageBox(TEXT("创建Connection对象失败"));///显示错误信息
returnFALSE;
}
}
catch(_com_errore)///捕捉异常
{
CStringerrormessage;
errormessage.Format(TEXT("连接数据库失败! 错误信息:%s(%ld)"),e.ErrorMessage(),e.Error());
AfxMessageBox(errormessage);///显示错误信息
returnFALSE;
}
returnTRUE;
}
操作数据库
[cpp]viewplainprint?
voidCLogin::OnBnClickedButton1()
{
if(m_user.GetWindowTextLength()<=0||m_password.GetWindowTextLength()<=0)
{
MessageBox(TEXT("请输入用户名或密码!"),TEXT("错误:用户名或密码为空"),MB_OK|MB_ICONWARNING);
return;
}
if(FALSE==this->ConnectDB())return;
TCHARszUserName[20];
TCHARszPassword[50];
TCHARszSql[MAX_PATH];
//获取用户输入的用户名和密码
m_user.GetWindowText(szUserName,20);
m_password.GetWindowText(szPassword,50);
//创建_RecordsetPtr用来执行数据库操作
_RecordsetPtrpRecordset;
pRecordset.CreateInstance("ADODB.Recordset");
_tcscpy_s(szSql,TEXT("select*fromusrwhereuname='"));
_tcscat_s(szSql,szUserName);
_tcscat_s(szSql,TEXT("'andpasswd='"));
_tcscat_s(szSql,szPassword);
_tcscat_s(szSql,TEXT("';"));
pRecordset->Open(_variant_t(szSql),_variant_t((IDispatch*)m_pConnection,true),adOpenStatic,adLockOptimistic,adCmdText);
intnResult=DLG_RESULT_OK;
if(pRecordset->RecordCount>0)
{
//MessageBox(TEXT("登录成功!"),szUserName,MB_OK|MB_ICONINFORMATION);
}
else
{
MessageBox(TEXT("用户名或密码错误!"),TEXT("登录失败!"),MB_OK|MB_ICONINFORMATION);
nResult=DLG_RESULT_ERROR;
}
pRecordset->Close();
if(DLG_RESULT_OK==nResult)Exit(DLG_RESULT_OK);
}
哦忘了一件事了,还需要在stafx.h文件中引入dll文件的,如此
[cpp]viewplainprint?
//添加dll库
#import"c:.dll"no_namespacerename("EOF","adoEOF")
//添加dll库
//添加宏定义
#defineDLG_RESULT_OK1
#defineDLG_RESULT_ERROR2
#defineDLG_RESULT_CANCEL3
//添加宏定义‘肆’ 数据库怎么连接
方法/步骤
网络搜索heidisql下载,选择绿色版下载
7
点击数据库名点击打开,点击表进入就可以查看表里的数据了
‘伍’ 常见数据库的连接方式有哪些呢
一种是以系统身份登陆,一种是以sql连接方式登录
连接方式 ado,jdbc,odbc,ole db等‘陆’ 数据库连接方式有哪些
在基于微软IIS/PWS的网络平台上,通过服务器端运行的ASP程序来访问后台数据库,是一种最常见的模式了。而对于小型的数据库应用需求,微软的Access数据库,应该是与ASP程序配套使用的首选。由于Access数据库的ODBC驱动程序支持的SQL指令全,执行效率高,所以Access后台数据库+ASP服务器端程序+客户端IE浏览器,是一个精练实用高效的组合模式。
在这种使用模式中,ASP程序无疑是最重要的,是沟通客户端和后台数据库之间的桥梁。在ASP程序中,通过VB Script,建立对Access数据库的连接,是客户能够访问后台数据库的前提。
一、建立Access数据库连接的常用方法
在ASP中建立对Access数据库连接的一般格式如下:
<%
DbPath=Server.MapPath(数据库名)
Set Conn=Server.CreatObject(“ADODB.Connection”)
Conn.Open “driver=;dbq=”& DbPath
Set rs=Server.CreatObject(“ADODB.Recordset”)
Rs.Open 数据表名或SQL指令,Connection对象,Recordset类型,锁定类型
… …
%>
它的各步骤及参数意义如下:
第一行程序:利用Server对象的MapPath函数,取得要打开数据库的完整的文件路径,并存储在变量DbPath中。这其中,数据库名是我们需要指定的参数,应该用我们要打开的数据库的实际名称替代。如果数据库名是直接作为常量出现,要用引号将其括起来,并且不能丢掉扩展名。例如数据库是Test.mdb,则该行程序成为:DbPath=Server.MapPath(“Test.mdb”)。
第二行程序:建立一个ADO对象集中的Connection对象,也即连接对象。这是建立数据库连接的初始步骤。执行这行程序后,Conn成为一个连接对象。
第三行程序:利用连接对象Conn的Open方法打开一个指定的数据库。因为我们要打开的是Access数据库,所以要指定ODBC驱动程序参数,表示要透过Access的ODBC驱动程序来访问数据库:driver=;。另一个参数dbq= & DbPath,运算后等效于dbq=Server.MapPath(数据库名) ,是利用了第一行的Server.MapPath(数据库名)函数,用来指定要打开的数据库文件。到这里,就已经打开了数据库名指定的数据库。如果数据库名是“test.mdb”,则打开Access数据库Test.mdb。在这一行里指定的参数,要严格按照格式原样写出,不能省略或改动,也没有可变参数。
第四行程序:建立一个ADO对象集中的Recordset对象,以便利用Recordset对象操作数据库(当然,这只是对数据库操作的多种方式之一)。执行这行后,rs就成为一个Recordset对象。
第五行程序:利用rs对象的Open方法打开数据库中的数据表。这其中有四个参数,其意义如下:
数据表名或SQL指令串:在这个参数里指定要打开的数据库内的数据表名称,或者是用SQL的Select指令串确定的数据表的指定范围数据,例如,数据库Test.mdb中有数据表Number,则该参数成为“Number”,注意引号不能丢;若想打开数据表Number中xh字段值小于90的数据记录,则该参数可能成为如下的形式:
“Select * From Number Where xh < 90”。
Connection对象:指定已经打开的数据库的Connection对象,在这里固定是Conn,注意无须引号的。
Recordset类型:表示打开数据表的方式,有四种选择。数字0表示只读方式,且当前记录只能下移;数字1表示可读写方式,当前记录可自由上下移动,但不能及时看到别的用户建立的新记录,除非重新启动;数字2表示可读写方式,当前记录可自由移动,而且可以及时看到别的用户增加的新记录;数字3表示只读方式,但当前记录可以自由移动。一般选择2为好,除非为了禁止数据被修改。
锁定类型:这个参数指定数据库的锁定功能。因为网络上的数据库都是多用户的,很可能同时有多个用户在操作数据库。为了避免错误,让同一时间只可能有一个用户修改数据,就要用锁定功能。有四种选择:数字1表示只读方式锁定,用户不能更改数据;数字2表示悲观锁定,当一个用户用rs对象开始修改数据时就锁定数据库,直到用户用rs.Update更新记录后,才解除锁定;数字3表示乐观锁定,只有在数据写入数据库中时候才锁定,不保险,慎用!数字4表示批次乐观锁定,只有在使用rs.UpdateBatch成批更新数据时候才锁定数据记录。属于很少使用的。一般地,使用悲观锁定比较安全,但是效率要低些。
二、使用Recordset对象操作数据
用上面的方法打开数据库,是利用了Recordset对象建立的数据库连接,然后的对数据操作,也要使用该对象。
用rs.open “数据表名”,Conn,2,2 方式打开数据表,就可以方便的对数据进行操作:
常见的操作对象:
rs.addnew :添加一个新记录在数据表末尾。
rs.delete :删除当前记录。
rs.eof :判断是否已过最后记录。
rs.bof :判断是否移过首记录。
rs.update :数据修改生效。
rs(“字段名”):当前记录指定字段的值。
从数据表中提取数据:用x=rs(“字段名”)的格式,提取数据表中当前记录指定字段的值。
向数据表中填入或修改数据:用rs(“字段名”)=数据值或变量的方式,修改当前记录指定字段的值。
三、使用SQL指令操作数据库
在使用SQL指令对数据库进行操作时,要用如下方式打开数据库和操作:
<%
DbPath=Server.MapPath(数据库名)
Set Conn=Server.CreatObject(“ADODB.Connection”)
Conn.Open “driver=;dbq=”& DbPath
Sql=操作数据库的指令串
Conn.Execute sql
… …
%>
四、使用DSN连接数据库
在以上连接数据库的方式中,都是在程序中指定数据库,指定ODBC驱动程序。如果数据源有变化,就需要修改程序。如果在系统级别上,预先定义好数据源DSN,就可以避免这个麻烦。
在定义DSN的过程中,就已经指定好了数据源需要的ODBC驱动程序,也指定好了数据库文件的实际路径和名字,我们在程序中,只需要引用预先定义的数据源名DSN即可。
设定义好的DSN为test,则打开数据库的方式为:
五、结束语
在ASP程序中,建立数据库的连接和访问数据库,有很多方式和技术细节,在此难以一一详述。实际上,对SQL Server数据库,DBF数据库,文本文件,电子表格文件等,也都可以很方便的打开和访问,与对Access数据库的访问大同小异而已。如果说方便,Access应该是首选。如果考虑安全保密性,SQL数据库更好些。使用系统数据源DSN的方式建立对数据库的连接,具有更大的灵活性,也更简便些。‘柒’ 数据库怎么连接,
楼上说的是java那边的 我来说说C这边的吧
我不知道你对代码的了解度程是什么 也太笼统了 不好说 我整理了下 vs基本现在用的就这几种
数据库 只要加载到SQLSERVER里就行了
程序链接数据库的话 方法很多
1: webconfig文件
<configuration>
<connectionStrings>
<add name="ConnectionString1" connectionString="Data Source=LEUU\LEUU;Initial Catalog=学生成绩管理;Integrated Security =True" providerName="System.Data.SqlClient"/>
</connectionStrings>
</configuration>
name是连接字符串的名字
connectionString 是他的值。。
Data Source表示数据源,也就是sql服务的路径和名称,一般为IP地址
user id 是帐号, p.....。。
Initial Catalog表示数据库名称
Integrated Security=True表示打开数库链接时集成windows身份验证
1号方法 需要使用下面2号方法来调用 只不过可以在代码中不用定义configuration的连接语句
不过 必需new
--------------------------------------------------------------------------------------------------
2 代码中直接调用 SqlConnection类连接数据库
(其实这样不好 如果忘了关conn 别的地方就没法再打开 还不抱错 囧 不过你懂的调用数据库次数少话 小程序这么写简单)
如果连接微软的Sql Server7.0及以后版本数据库,使用SqlConnection类建立连接效率较高。而连接其它支持ODBC的数据库,必须使用OleDbConnection类。使用SqlConnection类必须引用如下命名空间:
Using System.Data;
using System.Data.SqlClient;
使用OleDbConnection类必须引用如下命名空间:
Using System.Data;
using System.Data.OleDb;
使用SqlConnection类建立连接的例子如下:
string txtConn="DATABASE=Northwind;SERVER=localhost;UID=sa;PWD=;";
SqlConnection conn=new SqlConnection(txtConn);//建立连接
其中DATABASE为数据库名称,这里为Northwind,必须安装微软Sql Server数据库系统,并安装自带的数据库例子Northwind,才能使用。UID为用户名,PWD为密码,Northwind数据库安装后的用户名为sa,密码为空。SERVER为所使用的数据库服务器,这里数据库服务器和数据库应用程序在同一台计算机中,因此为localhost,中文意义是本地主机。
使用OleDbConnection类建立连接的例子如下:
string txtConn=//将作为OleDbConnection类对象conn的属性ConnectionString的值
"Provider=Microsoft.Jet.OLEDB.4.0;DataSource=D:\\VC#\\studentI.mdb";
OleDbConnection conn=new OleDbConnection(txtConn);//建立数据库连接
Provider为所使用的数据库驱动程序,DataSource为数据库的位置。也可以使用Visual Studio.Net建立连接,见例子8_10B。方法Open()和Close(),打开和关闭数据库连接。
-----------------------------------------------------------------------------------------
3 所谓的dbhelper类(以前自己写的 可以多楚调用 高手别笑哈 这是一个单独的cs文件 调用的话 new就行)
private static SqlConnection conn;
public static SqlConnection Conn
{
get
{
string sqlconn = ConfigurationManager.ConnectionStrings["Sqlcon"].ConnectionString;
if (conn == null)
{
conn = new SqlConnection(sqlconn);
conn.Open();
}
else if (conn.State == System.Data.ConnectionState.Closed)
{
conn.Open();
}
else if (conn.State == System.Data.ConnectionState.Broken)
{
conn.Close();
conn.Open();
}
return conn;
}
}
public static SqlDataReader GetProcReader(string sqlproc)
{
SqlCommand commd = new SqlCommand();
commd.Connection = Conn;
commd.CommandType = CommandType.StoredProcere;
commd.CommandText = sqlproc;
SqlDataReader reader = commd.ExecuteReader();
return reader;
}
public static SqlDataReader GetProcReader(string sqlproc, params SqlParameter[] para)
{
SqlCommand commd = new SqlCommand();
commd.Connection = Conn;
commd.CommandType = CommandType.StoredProcere;
commd.CommandText = sqlproc;
commd.Parameters.AddRange(para);
SqlDataReader reader = commd.ExecuteReader();
return reader;
}
public static int GetProcCommand(string sqlproc)
{
SqlCommand commd = new SqlCommand();
commd.Connection = Conn;
commd.CommandType = CommandType.StoredProcere;
commd.CommandText = sqlproc;
int num = commd.ExecuteNonQuery();
return num;
}
public static int GetProcCommand(string sqlproc, params SqlParameter[] para)
{
SqlCommand commd = new SqlCommand();
commd.Connection = Conn;
commd.CommandType = CommandType.StoredProcere;
commd.CommandText = sqlproc;
commd.Parameters.AddRange(para);
int num = commd.ExecuteNonQuery();
return num;
}