C#连接数据库:Connection对象

1.Connection对象概述

  Connection对象是一个连接对象,主要功能是建立与物理数据库的连接。其主要包括4种访问数据库的对象类,也可称为数据提供程序,分别介绍如下。

    SQL Server数据提供程序,位于System.Data.SqlClient命名空间。

    ODBC数据提供程序,位于System.Data.Odbc命名空间。

    OLEDB数据提供程序,位于System.Data.OleDb命名空间。

    Oracle数据提供程序,位于System.Data.OracleClient命名空间。

说明:根据使用数据库的不同,引入不同的命名空间,然后通过命名空间中的Connection对象连接类连接数据库。例如,连接SQL Server数据库,首先要通过using System.Data.SqlClient命令引用SQL Server数据提供程序,然后才能调用空间下的SqlConnection类连接数据库。

2.连接数据库

  以SQL Server数据库为例,如果要连接SQL Server数据库,必须使用System.Data.SqlClient命名空间下的SqlConnection类。所以首先要通过using System.Data.SqlClient命令引用命名空间,连接数据库之后,通过调用SqlConnection对象的Open方法打开数据库。通过SqlConnection对象的State属性判断数据库的连接状态。

界面:


代码:
```
private void btn1_Click(object sender, EventArgs e)
{
if (txt1.Text == "")
{
MessageBox.Show("请输入要连接的数据库名称!");
}
else
{
try
{
string connString = "server=.;database=" + txt1.Text.Trim() + ";uid=test;pwd=test;connect timeout=5"; //**
SqlConnection sqlConnection = new SqlConnection(connString); //**
sqlConnection.Open(); //**

                if (sqlConnection.State == ConnectionState.Open)
{
lab2.Text = "数据库【" + txt1.Text.Trim() + "】已经连接并打开!";
}
}
catch
{
MessageBox.Show("数据库连接失败!");
}
}
}
##3.关闭连接
&emsp;&emsp;<b>当对数据库操作完毕后,要关闭与数据库的连接,释放占用的资源。可以通过调用SqlConnection对象的Close方法或Dispose方法关闭与数据库的连接。这两种方法的主要区别是:Close方法用于关闭一个连接,而Dispose方法不仅关闭一个连接,而且还清理连接所占用的资源。当使用Close方法关闭连接后,可以再调用Open方法打开连接,不会产生任何错误。而如果使用Dispose方法关闭连接,就不可以直接用Open方法打开连接,必须再次重新初始化连接再打开。</b><br>
<b>界面:</b>
<center><img src="https://img2018.cnblogs.com/blog/1849125/202001/1849125-20200131124009357-1639087622.png" width="350" height="300"> <img src="https://img2018.cnblogs.com/blog/1849125/202001/1849125-20200131124106628-328825224.png" width="350" height="300"></center>
<b>代码:</b>
    SqlConnection sqlConnection; //***
/// <summary>
/// 连接数据库
/// </summary>
private void btn1_Click_1(object sender, EventArgs e)
{
if (txt1.Text == "")
{
MessageBox.Show("请输入数据库名称:");
}
else
{
try
{
string connString = "server=.;database=" + txt1.Text.Trim() + ";uid=test;pwd=test;connect timeout=5"; //***
sqlConnection = new SqlConnection(connString); //***
sqlConnection.Open(); //*** if (sqlConnection.State == ConnectionState.Open)
{
btn1.Text = "连接成功";
}
}
catch(Exception ex)
{
MessageBox.Show(ex.Message);
txt1.Text = "";
}
}
} /// <summary>
/// 使用Close方法关闭连接并重新调用Open方法连接数据库
/// </summary>
private void btn2_Click(object sender, EventArgs e)
{
try
{
string str = ""; sqlConnection.Close(); //***
if (sqlConnection.State == ConnectionState.Closed)
{
str = "数据库已经成功关闭\n";
} sqlConnection.Open(); //***
if (sqlConnection.State == ConnectionState.Open)
{
str += "数据库已经成功打开\n";
} rtbox1.Text = str;
}
catch (Exception ex)
{
rtbox1.Text = ex.Message;
}
} /// <summary>
/// 使用Dispose方法关闭连接并重新调用Open方法连接数据库
/// </summary>
private void btn3_Click(object sender, EventArgs e)
{
try
{
sqlConnection.Dispose(); //***
sqlConnection.Open(); //***
}
catch (Exception ex)
{
rtbox1.Text = ex.Message;
}
}

(1)C#连接数据库:Connection对象的更多相关文章

  1. ADO.NET系列之Connection对象

    ADO.NET系列之Connection对象 ADO.NET系列之Command对象 ADO.NET系列之DataAdapter对象 ADO.NET系列之事务和调用存储过程 ADO.NET概念 ADO ...

  2. C#与数据库访问技术总结(三)之 Connection对象的常用方法

    说明:前面(一)(二)总结了数据库连接的概念以及连接数据库的字符串中的各个参数的含义.这篇随笔介绍connection对象的常用方法. Connection对象的常用方法 Connection类型的对 ...

  3. 事务处理中如何获取同一个connection 对象

    运用线程内部的map属性,将对象绑定到ThreadLocal中: 具体实现: 1.新建一个绑定Connection对象的单例类 public class ConnectionBind { privat ...

  4. Connection 对象简介 方法解读 JDBC简介(四)

    通过驱动管理器DriverManager的getConnection方法,可以创建到指定URL的连接     Connection conn = DriverManager.getConnection ...

  5. 自己写的JdbcUtils小工具-----得到Connection对象

    Properties文件中存放键值对------(可看对Properties文件的解析) static代码块是在构造函数之前执行的,而且只执行一次,即类首次加载时. 也就是只加载一次配置文件和加载数据 ...

  6. 8.1.1 Connection 对象

    Connect是sqllite3模块中最基本的也是最重要的一个类,其主要方法如下表所示: 方法 说明 execute(sql[,parameters]) 执行一条SQL语句 executemany(s ...

  7. ADO.net Connection对象简介

    Connection对象 学习的是刘皓的文章  ADO.NET入门教程(四) 品味Connection对象 这篇文章开始水平一般起来了,主要介绍了要优雅的使用这个对象 1 用try...catch.. ...

  8. 用户注册调优 及Connection对象

    调优的方法: (1)减少Connection对象的销毁与创建 我们可以在服务器启动时 预先创建好二十个Connection对象 因为每次Coonection对象的创建与销毁会浪费大量的时间  我们需要 ...

  9. c3p0连接池获得的Connection执行close方法后是否真的销毁Connection对象?

    问题描述: jfinal做的api系统中,在正常调用接口一段时间后,突然再调用接口的时候,该请求无响应api系统后台也无错误信息 (就是刚开始接口调用是正常的,突然就无响应了) 于是啊,就开始找错误. ...

随机推荐

  1. HBase 原理

    遗留问题: 数据在更新时首先写入Log(WAL log)和内存(MemStore)中,MemStore中的数据是排序的,当MemStore累计到一定阈值时,就会创建一个新的MemStore,并且将老的 ...

  2. javascript继承的几种方法

    继承是面向对象编程中很重要的概念,在其它面向对象的语言中大都很简单,例如java中有关键词extends来实现 javascript语言在ES6也新增了extends关键词可以实现继承,用法与java ...

  3. centos安装pip,zipimport.ZipImportError报错

    安装pip下载pip安装包wget https://bootstrap.pypa.io/get-pip.py 执行以下报错 python get-pip.py ##报错内容(zipimport.Zip ...

  4. [工具] Git版本管理(知识总结)

    对以下文档进行了简要总结,方面复习: [工具] Git版本管理(一)(基本操作) [工具] Git版本管理(二)(分支) [工具] Git版本管理(三)(工作流) [工具] Git版本管理(四)(贡献 ...

  5. java如何实现在线支付讲解

    转载:https://www.cnblogs.com/haorun/p/6728466.html 国内电子商务系统实现的基本流程如下: 客户在系统内下订单 -> 系统根据订单生成支付宝接口url ...

  6. 集合排序Comparable和Comparator有什么区别?

    Comparable和Comparator兄弟俩长得是真像.但是,需要注意下,使用中它们还是有不少区别的.下面,就一探究竟吧. 一.Comparator 做过集合排序的童鞋应该知道,可以使用Colle ...

  7. 日志冲突解决方案(基于gradle)

    日志冲突解决方案 前提:我使用gradle管理项目 最近在项目中需要用curator客户端操作zookeeper,在maven仓库拉取的jar包导致日志冲突,会报以下的错误: 经常会有如上图2处红色框 ...

  8. TieredMergePolicy

    setFloorSegmentMB多少MB一个层级,在此区间的segment分为一个floor. setMaxMergeAtOnce一次merge多少个segment. setSegmentsPerT ...

  9. C#调用Fortran生成的DLL的方法报内存不足

    最近在研究一个程序,公司给的,程序是VB写的,程序里面还有一个计算的模型,用Fortran语言写的. 在调试到这个模型里面的方法时报错,说是内存不足,于是就在网上查找方法,看了两篇博客之后问题解决了. ...

  10. NETCore下IConfiguration和IOptions的用法

    NETCore下IConfiguration和IOptions的用法 https://www.cnblogs.com/RainingNight/p/strongly-typed-options-con ...