日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
C#連接數(shù)據(jù)庫特殊方法兩則

用過VS2005和VS2008的開發(fā)人員肯定知道在安裝這個(gè)IDE的時(shí)候會(huì)自動(dòng)安裝了一個(gè)精簡版的SQL數(shù)據(jù)庫服務(wù)SqlExpress,這個(gè)數(shù)據(jù)庫系統(tǒng)少了最重要的企業(yè)管理器,也就是說不能用它來建數(shù)據(jù)表和一些可視化操作。如果碰到項(xiàng)目中要用到SQL數(shù)據(jù)庫的時(shí)候也不能附加到數(shù)據(jù)庫服務(wù)里面去,導(dǎo)致項(xiàng)目在連接數(shù)據(jù)庫的時(shí)候會(huì)提示找不到數(shù)據(jù)庫文件而讀取失敗。那么,這個(gè)精簡版的SQL數(shù)據(jù)庫服務(wù)是不是意味著一無是處呢?

其實(shí)未必,只要我們在連接數(shù)據(jù)庫的時(shí)候利用好它就可以了~~

在這里我介紹兩種C#中連接數(shù)據(jù)庫的方法。一種需要附加數(shù)據(jù)庫,一種則不要,只需要安裝這個(gè)精簡版的SQL就可以了…

方法一:

連接代碼:

string strconn;
strconn = "Data Source=(local);";
strconn += "Initial Catalog=student;";
strconn += "User ID=sa;";
strconn += "Password=;"; 
SqlConnection con = new SqlConnection(strconn);
//通過用戶名和密碼連接數(shù)據(jù)庫
//SqlConnection con = new SqlConnection("Data Source=(local);
Initial Catalog=library;Integrated Security=True"); 
//通過系統(tǒng)用戶驗(yàn)證連接數(shù)據(jù)庫
con.Open();
SqlDataAdapter thisadapter = new SqlDataAdapter
("select * from reader where 條形碼='" + txm + "'", con);
SqlCommandBuilder thisbuilder = new SqlCommandBuilder(thisadapter);
DataSet thisdataset = new DataSet();
thisadapter.Fill(thisdataset, "reader");
…… //接下去就是對(duì)數(shù)據(jù)的操作了

這種方法必須要附加數(shù)據(jù)庫文件才可以訪問…

優(yōu)點(diǎn)是可以通過企業(yè)管理器直接對(duì)數(shù)據(jù)庫進(jìn)行可視化操作,比如對(duì)記錄進(jìn)行全權(quán)修改…萬一碰到數(shù)據(jù)有錯(cuò)誤,在系統(tǒng)里面不好修改的時(shí)候可以進(jìn)行強(qiáng)制維護(hù)。同時(shí),如果后期更新系統(tǒng),增加新的數(shù)據(jù)庫需求,比如增加字段就可以在里面操作。

當(dāng)然這也算是缺點(diǎn),亂改數(shù)據(jù)可能導(dǎo)致破壞數(shù)據(jù)庫的一些規(guī)則和數(shù)據(jù)一致性,嚴(yán)重的話會(huì)導(dǎo)致災(zāi)難性的數(shù)據(jù)崩潰。

方法二:

連接代碼:

SqlConnectionStringBuilder connectstringbuilder = 
new SqlConnectionStringBuilder();
connectstringbuilder.DataSource = @"(local)\sqlexpress";
//指定數(shù)據(jù)庫服務(wù)
connectstringbuilder.AttachDBFilename=@"|DataDirectory|\data\library.mdf";
//數(shù)據(jù)庫文件,采用相對(duì)地址的方式來指定。注意格式
connectstringbuilder.IntegratedSecurity = true;   
connectstringbuilder.UserInstance = true;
SqlConnection thisconnection =
new SqlConnection(connectstringbuilder.ConnectionString);
SqlDataAdapter thisadapter =
new SqlDataAdapter
("select * from reader where 條形碼='" +txm + "'", thisconnection);
DataSet dt = new DataSet();
thisadapter.Fill(dt, "info");
……//接下去就是對(duì)數(shù)據(jù)的操作了

這個(gè)方法最大的有點(diǎn)就是允許我們不用安裝600M(MSSQL2000)或者1G(MSSQL2005)的數(shù)據(jù)庫系統(tǒng),只需要安裝SQL精簡版的數(shù)據(jù)庫服務(wù)(22M左右)就可以了。而且不用去附加數(shù)據(jù)庫…

但是這種優(yōu)點(diǎn)也帶來致命的缺點(diǎn),就是第一次連接數(shù)據(jù)庫的時(shí)候會(huì)有點(diǎn)慢,這不要緊,但它會(huì)重新格式數(shù)據(jù)庫文件的一些結(jié)構(gòu),導(dǎo)致一些數(shù)據(jù)格式發(fā)生變化,因此連接之后這樣的數(shù)據(jù)庫文件是不能再次被附加到數(shù)據(jù)庫系統(tǒng)中的(會(huì)報(bào)錯(cuò))。也就是說后期如果要修改數(shù)據(jù)庫,比如增加字段和表等是不太可能實(shí)現(xiàn)的。

不過這也在一定的程度上帶來了安全性。

以上這兩種數(shù)據(jù)庫連接方式各有千秋,是否要使用就看你的系統(tǒng)實(shí)際應(yīng)用需求了…

(注:這兩種方法在VS2005+MSSQL調(diào)試通過…)

【編輯推薦】

  1. 淺談C#中的接口問題
  2. 淺談C# 4.0中的動(dòng)態(tài)類型和動(dòng)態(tài)編程
  3. 深入理解C# 3.0的五項(xiàng)主要改進(jìn)

當(dāng)前標(biāo)題:C#連接數(shù)據(jù)庫特殊方法兩則
瀏覽路徑:http://www.5511xx.com/article/coijjgi.html