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. 2019-7-29-win10-uwp-如何使用DataTemplate

    title author date CreateTime categories win10 uwp 如何使用DataTemplate lindexi 2019-7-29 10:2:32 +0800 2 ...

  2. CodeForces - 1162E Thanos Nim (博弈论)

    Alice and Bob are playing a game with nn piles of stones. It is guaranteed that nn is an even number ...

  3. Java 学习笔记(3)——函数

    之前的几篇文章中,总结了java中的基本语句和基本数据类型等等一系列的最基本的东西,下面就来说说java中的函数部分 函数基础 在C/C++中有普通的全局函数.类成员函数和类的静态函数,而java中所 ...

  4. vs2019 解决方案加载报错

    1. 如图 解决方案: 1.先关闭vs: 2.把C:/Users/<users name>/AppData/Local/Microsoft/VisualStudio/14.0/Compon ...

  5. 【Ubuntu】查看端口占用及关闭

    1.查看已连接的服务端口 (ESTABLISHED) netstat有一个快捷键[ss] netstat -a ss -a 2.查看所有的服务端口(LISTEN,ESTABLISHED) netsta ...

  6. 记录我的 python 学习历程-Day11 两个被忽视的坑、补充知识点、函数名的应用、新版格式化输出、迭代器

    补充知识点 函数形参中默认参数的陷阱 针对不可变数据类型,它是没有陷阱的 def func(name, sex='男'): print(name) print(sex) func('Dylan') # ...

  7. asp.net保留两位小数

    1.System.Globalization.NumberFormatInfo provider = new System.Globalization.NumberFormatInfo();provi ...

  8. VC++取MD5算法记录下以后用得到(转)

    这个是网上扒下来的 作者已经无法知道是谁了 MD5.h #ifndef MD5_H #define MD5_H #include <string> #include <fstream ...

  9. Java 迭代器须知 | “for each”与迭代器的关系

    Iterator接口包含4个方法: 通过反复调用next方法就可以逐个访问集合中的每个元素.需要注意,如果到达了集合的末尾,再次调用next方法将会抛出一个NoSuchElementException ...

  10. 「洛谷P1233」木棍加工 解题报告

    P1233 木棍加工 题目描述 一堆木头棍子共有n根,每根棍子的长度和宽度都是已知的.棍子可以被一台机器一个接一个地加工.机器处理一根棍子之前需要准备时间.准备时间是这样定义的: 第一根棍子的准备时间 ...