C#中通過使用Connection類來實(shí)現(xiàn)打開/關(guān)閉數(shù)據(jù)庫的代碼實(shí)例
為了訪問數(shù)據(jù)庫,就要提供數(shù)據(jù)庫連接類,在C#中,是通過Connection類來實(shí)現(xiàn)的
四種類型的連接方式
- SQLConnection
- ADOConnection
- OractleConnection
- ODBCConnection
以SQLConnection方式實(shí)現(xiàn)數(shù)據(jù)庫的連接:
- SQL Server數(shù)據(jù)庫
- windows 身份信息驗(yàn)證
步驟:
- 引用命名空間 using System.Data.SqlClient;
- 將連接方法聲明值字符串中
- 創(chuàng)建Connection對(duì)象
- 調(diào)用方法
為了節(jié)省系統(tǒng)資源提高系統(tǒng)性能,最好使用完數(shù)據(jù)庫就關(guān)閉連接,在C#語言中由于GC(垃圾回收機(jī)制)的存在,會(huì)在以后的某個(gè)時(shí)刻釋放資源,它是非決定性的,并不能確定這個(gè)過程在什么時(shí)候發(fā)生,當(dāng)忘記關(guān)閉數(shù)據(jù)庫是可以u(píng)sing語句確保對(duì)象退出時(shí)立即被釋放,從而達(dá)到關(guān)閉數(shù)據(jù)庫的作用,還有一種通過try..catch..final..語句控制連接數(shù)據(jù)庫的關(guān)閉來提高性能
代碼實(shí)現(xiàn)如下:
using System;
using System.Data.SqlClient; //引入命名空間
namespace Csharpone
{
class Program
{
static void Main(string[] args)
{
//windows 身份信息驗(yàn)證 下面的csharp01為新建的數(shù)據(jù)庫名稱
string constr = "Server.;integrated security=SSPI;Initial Catalog=csharp01";
SqlConnection mysqlCon = new SqlConnection(constr); //實(shí)例化
mysqlCon.Open(); //打開數(shù)據(jù)庫
Console.WriteLine("數(shù)據(jù)庫打開"); //正常打印說明沒問題,否則會(huì)拋出異常
//SQ驗(yàn)證方式 name是你設(shè)置的數(shù)據(jù)庫的用戶名,pwd是密碼 csharp02是數(shù)據(jù)庫名稱
string constr1 = "Server.;user=name; pwd=mima; database=csharp02";
SqlConnection mysqlCon1 = new SqlConnection(constr1); //實(shí)例化
mysqlCon1.Open(); //打開數(shù)據(jù)庫
Console.WriteLine("SQL方式 數(shù)據(jù)庫打開");
/*通過using語句實(shí)現(xiàn)數(shù)據(jù)庫的關(guān)閉
using (mysqlCon1) {
mysqlCon1.Open();
Console.WriteLine("數(shù)據(jù)成功打開"); //執(zhí)行完立即關(guān)閉
}
//通過try..catch..finally..
try
{
mysqlCon.Open();
Console.WriteLine("數(shù)據(jù)庫關(guān)閉");
}
catch
{
}
finally
{
mysqlCon.Close();
Console.WriteLine("關(guān)閉數(shù)據(jù)庫");
}*/
//以上兩種方式結(jié)合使用,確保數(shù)據(jù)庫占用資源得到釋放
try
{
using (mysqlCon)
{
mysqlCon.Open();
Console.WriteLine("打開數(shù)據(jù)庫");
}
}
catch
{
}
finally
{
mysqlCon.Close();
Console.WriteLine("關(guān)閉數(shù)據(jù)庫");
}
Console.Read();
}
}
}
MySQL數(shù)據(jù)庫代碼如下:
using System;
using MySql.Data.MySqlClient; //導(dǎo)入引用,并且添加命名空間
namespace CSharp連接Mysql
{
class Program
{
static void Main(string[] args)
{
string connectStr = "server=localhost;port=3306;database=czhenya01;user=root;password=123456;";
//并沒有建立數(shù)據(jù)庫連接
MySqlConnection conn = new MySqlConnection(connectStr);
try
{
conn.Open(); //建立連接,打開數(shù)據(jù)庫
Console.WriteLine("打開數(shù)據(jù)庫成功");
}catch (Exception ex)
{
Console.WriteLine(ex.ToString());
}
finally
{
conn.Close(); //關(guān)閉連接
}
Console.ReadKey();
}
}
}
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
- C# 數(shù)據(jù)庫鏈接字符串加密解密工具代碼詳解
- C# 操作 access 數(shù)據(jù)庫的實(shí)例代碼
- C#實(shí)現(xiàn)復(fù)制數(shù)據(jù)庫 C#將A數(shù)據(jù)庫數(shù)據(jù)轉(zhuǎn)到B數(shù)據(jù)庫
- C# 操作PostgreSQL 數(shù)據(jù)庫的示例代碼
- C#連接Oracle數(shù)據(jù)庫使用Oracle.ManagedDataAccess.dll
- C#實(shí)現(xiàn)連接SQL Server2012數(shù)據(jù)庫并執(zhí)行SQL語句的方法
- C#連接到sql server2008數(shù)據(jù)庫的實(shí)例代碼
- C#連接加密的Sqlite數(shù)據(jù)庫的方法
- C#實(shí)現(xiàn)Excel表數(shù)據(jù)導(dǎo)入Sql Server數(shù)據(jù)庫中的方法
- C#使用ODBC與OLEDB連接數(shù)據(jù)庫的方法示例
- C#實(shí)現(xiàn)的ACCESS數(shù)據(jù)庫操作類完整實(shí)例
- c#實(shí)現(xiàn)幾種數(shù)據(jù)庫的大數(shù)據(jù)批量插入
- 詳解C#把DataTable中數(shù)據(jù)一次插入數(shù)據(jù)庫的方法
相關(guān)文章
C#/VB.NET?實(shí)現(xiàn)彩色PDF轉(zhuǎn)為灰度PDF
本文以C#代碼為例介紹如何實(shí)現(xiàn)將彩色PDF文件轉(zhuǎn)為灰度(黑白)的PDF文件,即將PDF文檔里面的彩色圖片或者文字等通過調(diào)用方法轉(zhuǎn)為文檔頁面為灰色調(diào)、無彩色效果的文檔??靵砀S小編一起學(xué)習(xí)吧2021-11-11
Unity C#打包AssetBundle與場(chǎng)景詳解
這篇文章主要給大家介紹了關(guān)于Unity C#打包AssetBundle與場(chǎng)景的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02
WPF利用ScottPlot實(shí)現(xiàn)動(dòng)態(tài)繪制圖像
ScottPlot是基于.Net的一款開源免費(fèi)的交互式可視化庫,支持Winform和WPF等UI框架,本文主要為大家詳細(xì)介紹了如何WPF如何使用ScottPlot實(shí)現(xiàn)動(dòng)態(tài)繪制圖像,需要的可以參考下2023-12-12
C#使用TCP協(xié)議實(shí)現(xiàn)數(shù)據(jù)發(fā)送和接受的方法
這篇文章主要介紹了c#使用TCP協(xié)議實(shí)現(xiàn)數(shù)據(jù)發(fā)送和接受,使用TCP協(xié)議實(shí)現(xiàn)數(shù)據(jù)的發(fā)送和接受包括客戶端和服務(wù)端兩個(gè)部分,本文通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04
c#實(shí)現(xiàn)適配器模式的項(xiàng)目實(shí)踐
適配器模式將一個(gè)類的接口轉(zhuǎn)換成客戶希望的另一個(gè)接口,使得原本由于接口不兼容而不能一起工作的那些類可以一起工作,本文主要介紹了c#實(shí)現(xiàn)適配器模式的項(xiàng)目實(shí)踐,感興趣的可以一起來了解一下2023-08-08
C#實(shí)現(xiàn)簡(jiǎn)單學(xué)生信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)簡(jiǎn)單學(xué)生信息管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06

