版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
訪問數(shù)據(jù)庫的機(jī)制1:使用“數(shù)據(jù)命令(Command)+數(shù)據(jù)讀取器”(Datareader)建立Connection對(duì)象(conn)?建立Command對(duì)象(comm)?建立DataReader(odr)對(duì)象?設(shè)置連接字符串?打開conn的連接設(shè)置數(shù)據(jù)命令對(duì)象comm的Connection屬性、Commandtype屬性和Commandtext屬性調(diào)用Command對(duì)象的ExcuteReader的方法,并將查詢結(jié)果賦給dr對(duì)象利用odr的hasrows屬性判斷數(shù)據(jù)讀取器對(duì)象是否包含數(shù)據(jù)記錄?利用一個(gè)循環(huán)來反復(fù)調(diào)用odr對(duì)象的Read方法,讀取返回的數(shù)據(jù)調(diào)用odr對(duì)象的Close方法來關(guān)閉數(shù)據(jù)讀取器一關(guān)閉連接。例如:登陸窗口窗體級(jí)對(duì)象DimconnAsOleDb.OleDbConnectionDimcmdAsNewOleDb.OleDbCommandDimdrAsOleDb.OleDbDataReaderDimdaAsNewOleDb.OleDbDataAdapterDimdsAsNewDataSetDimbmDataAsBindingManagerBase?按鈕的Click事件DimsqlAsStringconn=NewOleDb.OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;DataSource="&Application.StartupPath&"\stuinfo.mdb")conn.Open()cmd=NewOleDb.OleDbCommand()sql=""select*from用戶表Where用戶名二?""& & “"'cmd.Connection=conncmd.CommandType=CommandType.Textcmd.CommandText=sqldr=comm..ExecuteReader2:使用“數(shù)據(jù)適配器(DataAdapter)+數(shù)據(jù)集(DataSet)”建立Connection對(duì)象(conn)f建立Command對(duì)象(comm)~建立DataAdapter對(duì)象(oda)f建立DataSet對(duì)象(ods)~建立DataTable對(duì)象(odt)設(shè)置連接字符串一打開conn的連接設(shè)置數(shù)據(jù)命令對(duì)象comm的Connection屬性、Commandtype屬性和Commandtext屬性調(diào)用da對(duì)象的Fill方法,填充ds對(duì)象中的DataTable對(duì)象建立DataRow和DataColumn對(duì)象或者利用odt對(duì)象的相關(guān)屬性(Rows或者Columns)訪問數(shù)據(jù)集中的表。例如:DimconnAsOleDb.OleDbConnectionDimcmdAsNewOleDb.OleDbCommandDimdrAsOleDb.OleDbDataReaderDimdaAsNewOleDb.OleDbDataAdapterDimdsAsNewDataSetDimbmDataAsBindingManagerBase?窗體的Load事件DimsqlAsStringconn=NewOleDb.OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;DataSource="&Application.StartupPath&"\stuinfo.mdb")conn.Open()cmd=NewOleDb.OleDbCommand()sql="select*from學(xué)生信息表"cmd.Connection=conncmd.CommandType=CommandType.Textcmd.CommandText=sqlda.SelectCommand=cmd?如果要下面的這個(gè)對(duì)象的聲明,那么在對(duì)數(shù)據(jù)的添加修改保存時(shí)就比較簡(jiǎn)單,直接使用數(shù)據(jù)集的對(duì)應(yīng)命令即可DimobdAsNewOleDb.OleDbCommandBuilder(da)da.Fill(ds,"學(xué)生信息表")DataGridView1.DataSource=ds.Tables("學(xué)生信息表").DefaultView數(shù)據(jù)綁定1、單一綁定所謂“單一綁定”是指將單一的數(shù)據(jù)元素綁定到控件的某個(gè)屬性。例如,將TextBox控件的Text屬性與“學(xué)生信息”數(shù)據(jù)表中的“姓名”字段進(jìn)行綁定。綁定語法格式如下:控件名稱.DataBindings.Add("控件的屬性名稱",數(shù)據(jù)源,"數(shù)據(jù)成員")(1)控件的屬性名稱該參數(shù)為字符串形式,指定綁定到控件的哪一個(gè)屬性。(2)數(shù)據(jù)源該參數(shù)為變量形式,可以是DataSet、DataTable、DataView或者數(shù)組等多種形式。(3)數(shù)據(jù)成員該參數(shù)為字符串形式,是數(shù)據(jù)源的子集合。如果數(shù)據(jù)源是DataSet,那么數(shù)據(jù)成員就是“DataTable.字段名稱”;如果數(shù)據(jù)源是DataTable,那么數(shù)據(jù)成員就是“字段名稱”。例如:TextBox1.DataBindings.Add(NewBinding("Text",ds,"學(xué)生信息表.學(xué)號(hào)"))TextBox2.DataBindings.Add(NewBinding("Text",ds,"學(xué)生信息表.姓名"))2、復(fù)合綁定所謂“復(fù)合綁定”是指控件和一個(gè)以上的數(shù)據(jù)元素進(jìn)行綁定,通常是指把控件和數(shù)據(jù)集中的多條數(shù)據(jù)記錄或者多個(gè)字段值、數(shù)組中的多個(gè)數(shù)組元素進(jìn)行綁定。DataGridView、ComboBox、ListBox和CheckedListBox等控件都支持復(fù)合數(shù)據(jù)綁定。語法格式為:控件名稱?DataSource=^據(jù)源.Tables("數(shù)據(jù)成員").DefaultView例如,將DataGridView控件與數(shù)據(jù)集DataSet綁定,以便同時(shí)顯示數(shù)據(jù)表中的所有數(shù)據(jù)記錄。DataGridViewl.DataSource=ods.Tables("班級(jí)信息”).DefaultView記錄導(dǎo)航單擊【首記錄】按鈕(bntFirst),顯示數(shù)據(jù)表中的第一條記錄;單擊【上一條】按鈕(bntBack),顯示數(shù)據(jù)表中的上一條記錄;單擊【下一條】按鈕(bntNext),顯示下一條記錄;單擊【尾記錄】按鈕(bntLast),顯示最后一條記錄。1、單一綁定的控件導(dǎo)航例如:'取得代表"班級(jí)信息"數(shù)據(jù)表的CurrencyManager對(duì)象?為前面聲明的BindingManagerBase類的變量bmData賦值,使用該變量代表“班級(jí)信息”表的CurrencyManager對(duì)象,在其后需要使用代表“班級(jí)信息”表的CurrencyManager對(duì)象時(shí),就可以直接使用bmData變量而不需要使用BindingContext類來獲取bmData=Me.BindingContext(ods,"班級(jí)信息")?設(shè)定當(dāng)觸發(fā)PositionChanged事件時(shí)便執(zhí)行事件處理程序PositionChangedAddHandlerbmData.PositionChanged,AddressOfPositionChangedbntFirst單擊事件:bntLast單擊事件:bmData.Position=bmData.Count-lbntBack單擊事件:IfbmData.Position>0ThenbmData.Position-=1bntNext單擊事件:IfbmData.Position<bmData.Count—1ThenbmData.Position+=12、復(fù)合綁定控件的導(dǎo)航如果還想要對(duì)復(fù)雜綁定的控件進(jìn)行導(dǎo)航,就必須進(jìn)行判斷。也就是說要將“當(dāng)前行”(bmData.Position)作為選中行(反向顯示),其他行正常顯示,就可以實(shí)現(xiàn)導(dǎo)航。這要用到Rows集合中的Selected屬性,該屬性為True時(shí)表示該行被選中,為False時(shí)表示未被選中。例如:對(duì)DataGridView控件的導(dǎo)航DataGridView1.Rows(n).Selected=TrueDataGridView1.Rows(n).Selected=False記錄的操作1、聲明OleDbCommandBuilder對(duì)象?如果要下面的這個(gè)對(duì)象的聲明,那么在對(duì)數(shù)據(jù)的添加修改保存時(shí)就比較簡(jiǎn)單,直接使用數(shù)據(jù)集的對(duì)應(yīng)命令即可DimobdAsNewOleDb.OleDbCommandBuilder(da)對(duì)記錄的操作基本上包括“新增”、“添加”、“刪除”等操作。由于在做操作時(shí)已經(jīng)對(duì)應(yīng)更新到數(shù)據(jù)庫中,所以不需要保存按鈕。例如:“新增”按鈕TextBox1.Text=""TextBox2.Text=""ComboBox1.Text=""“添加”按鈕DimnRowAsDataRow=ds.Tables("學(xué)生信息表").NewRownRow("學(xué)號(hào)")=Trim(TextBoxl.Text)nRow("性別")=Trim(ComboBoxl.Text)ds.Tables("學(xué)生信息表").Rows.Add(nRow)da.Update(ds,"學(xué)生信息表")ds.Clear()da.Fill(ds,"學(xué)生信息表〃)“刪除”按鈕DimdelrowAsIntegerdelrow=學(xué)生信息表DataGridView.CurrentRow.Index '當(dāng)前選中行Ifdelrow>=0Anddelrow<ds.Tables("學(xué)生信息表").Rows.CountThenDimiAsIntegerds.Tables("學(xué)生信息表").Rows(delrow).Delete()da.Update(ds,"學(xué)生信息表")ds.Clear()da.Fill(ds,"學(xué)生信息表")EndIf2、沒有聲明0leDbCommandBuilder對(duì)象如果沒有聲明OleDbCommandBuilder對(duì)象,那么對(duì)數(shù)據(jù)的添加修改保存就要使用相應(yīng)的SQL語句。例如:“添加”按鈕DiminupsqlAsStringinupsql="insertinto學(xué)生信息表(學(xué)號(hào),姓名)values("&"'"&學(xué)號(hào)TextBox.Text&"',"& &姓名TextBox.Text&"')"conn.0pen()cmd=New0leDb.0leDbCommand()cmd.Connection=conncmd.CommandType=CommandType.Textcmd.CommandText=inupsqlcmd.ExecuteNonQuery()conn.Close()ds.Clear()da.Fill(ds,"學(xué)生信息表")“新增”按鈕TextBox1.Text=""TextBox2.Text=""ComboBox1.Text=""“刪除”按鈕DimdelsqlAsStringdelsql="deletefrom學(xué)生信息表where學(xué)號(hào)二&學(xué)號(hào)TextBox.Text&conn.0pen()cmd=New0leDb.0leDbCommand()cmd.Connection=conncmd.CommandType=CommandType.Textcmd.CommandText=delsqlcmd.ExecuteNonQuery()conn.Close()MessageBox.Show("刪除成功!","刪除提示")ds.Clear()da.Fill(ds,"學(xué)生信息表〃)“修改保存”按鈕DiminupsqlAsStringinupsql="update學(xué)生信息表"&"set學(xué)號(hào)二&學(xué)號(hào)TextBox.Text&"',"&"姓名二'"&姓名TextBox.Text&"'"&_"where學(xué)號(hào)二'"&學(xué)號(hào)TextBox.Text&"'"conn.Open()cmd=NewOleDb.OleDbCommand()cmd.Connection=conncmd.CommandType=CommandType.Textcmd.CommandText=inupsqlcmd.ExecuteNonQuery
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 廣東外語外貿(mào)大學(xué)《基礎(chǔ)西班牙語(II)》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東水利電力職業(yè)技術(shù)學(xué)院《雕塑造型與表現(xiàn)技法》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東石油化工學(xué)院《建筑電氣識(shí)圖》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東汕頭幼兒師范高等??茖W(xué)?!稛o機(jī)化學(xué)1》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東培正學(xué)院《音樂鑒賞與實(shí)踐》2023-2024學(xué)年第一學(xué)期期末試卷
- 廣東嶺南職業(yè)技術(shù)學(xué)院《第二外國(guó)語三》2023-2024學(xué)年第一學(xué)期期末試卷
- 大學(xué)迎新活動(dòng)總結(jié)
- 2024小單元建筑幕墻構(gòu)件
- 【全程復(fù)習(xí)方略】2020-2021學(xué)年北師大版高中數(shù)學(xué)必修一課時(shí)作業(yè)(二十七)-4.2
- 【名師一號(hào)】2020-2021學(xué)年高中英語人教版必修4-雙基限時(shí)練3
- DRG付費(fèi)常見九大問題答疑
- 中科院2022年物理化學(xué)(甲)考研真題(含答案)
- 廣東省汕尾市2023-2024學(xué)年高一上學(xué)期期末教學(xué)質(zhì)量監(jiān)測(cè)化學(xué)試卷(含答案解析)
- 《熱電阻溫度傳感器》課件
- 抖音酒店直播可行性方案
- 信訪業(yè)務(wù)培訓(xùn)班課件
- 物資清運(yùn)方案及
- 熱穩(wěn)定校驗(yàn)計(jì)算書
- 北京市房山區(qū)2023-2024學(xué)年三年級(jí)上學(xué)期期末數(shù)學(xué)試卷
- 婦產(chǎn)科課件-子宮內(nèi)膜息肉臨床診療路徑(2022版)解讀
- 人教版六年級(jí)數(shù)學(xué)上冊(cè)典型例題系列之第三單元分?jǐn)?shù)除法應(yīng)用題部分拓展篇(原卷版)
評(píng)論
0/150
提交評(píng)論