VB数据库操作实例
来源:网络收集 点击: 时间:2024-03-15《书库管理系统》是一个最简单的数据库操作实例,它包括浏览、添加、修改、删除功能的数据库操作,使用数据链接控件Adodc链接数据库、数据显示控件MSHFlexGrid显示数据库中的记录。 在新建工程时工具箱中是没有Adodc控件和MSHFlexGrid控件的,我们必须点击菜单中的【工程】-【部件】,在对话框中勾选“Microsoft ADO Data Control 6.0 (SP6)”和“Microsoft Hierarchical FlexGrid Control 6.0 (SP4)”,最后点击【确定】,这样Adodc控件和MSHFlexGrid控件就已经放置在工具箱中了。 其中Adodc控件的ConnectionString属性值是:Provider=Microsoft.Jet.OLEDB.4.0;Data Source=家庭书架.mdb;Persist Security Info=False,它设置链接了“家庭书架.mdb”这个Access数据库,RecordSourc属性值是:select 图书登记表.ID,图书登记表.名称,图书登记表.书号,图书登记表.作者,图书登记表.出版社,图书登记表.出借状态,出借记录.借书人,出借记录.电话,出借记录.地址,图书登记表.备注,图书登记表.出借记录 from 图书登记表,出借记录 where 图书登记表.ID=出借记录.zhuID ORDER BY 图书登记表.ID,因为在“家庭书架.mdb”数据库中包含图书登记表和出借记录二个数据表,这是多表链接的典型的SQL语句。Adodc的这二个属性值在VB的属性窗口进行编辑,你可以将上述属性值直接输入到相应的属性中,设置Visible的值为False,目的是在运行中不显示这个控件,其他属性默认值即可。 MSHFlexGrid控件的名称我们修改为MS1,它的属性设置稍稍比较麻烦: 首先将它的DataSource属性在属性窗口设置为Adodc1; 然后在对象窗口右击控件,在下拉菜单中点击【属性】,在“通用”标签中修改行为3,修改列为11,修改固定行为0,修改固定列为0,如果数据链接没有问题,在属性的“带区”标签中可以看到列标题和列名称已经设置了,其他属性页的属性可以容许默认值,中点击【确定】即可。 另外在属性窗口设置MSHFlexGrid控件的BackColorBkg属性为H00FFE0E0,这个属性是控件底色的设置,然后设置BackColorFixed属性为H00C0FFFF,这个属性是控件数据显示标题的底色。其他默认值即可。 最后放置三个按钮,一个标签,三个Frame控件,在Frame1、Frame2、Frame3控件中分别放置9个标签(数组),8个文本框,一个下拉选择框,一个按钮,在Frame2、Frame3控件中分别放置一个标签,设置这个标签的Visible值为False,其他设置参考下图: 设置和调整控件如上图后,设置数据库,在程序目录新建一个Access数据库,修改数据库的名称为“家庭书架.mdb”,新建二个数据表,分别是:“图书登记表”和“出借记录”: 在“图书登记表”中添加字段:“ID”为自动编号、主键,“名称”为文本、大小50,“书号”为文本、大小30,“作者”为文本、大小40,“出版社”为文本、大小60,“出借状态”为文本、大小20,“出借记录”为数字、长整型,“备注”为文本、大小50; 在“出借记录”中添加字段:“ID”为自动编号、主键,“zhuID”为数字、长整型,“名称”为文本、大小50,“借书人”为文本、大小20,“电话”为文本、大小20,“地址”为文本、大小50。 数据库设置成功。

点击【视图】-【代码窗口】输入下面的代码:
模块级变量Dim ZFC As StringDim ROSX As Integer
3/12Private Sub Command1_Click()添加记录Dim FL As String, XID As LongFL = App.Path \家庭书架.mdbSet conn = OpenDatabase(FL)strSQL = Select * From 图书登记表Set rs = conn.OpenRecordset(strSQL)rs.AddNewrs!名称 = Text1(0).Textrs!书号 = Text1(1).Textrs!作者 = Text1(2).Textrs!出版社 = Text1(3).Textrs!出借状态 = Combo1.Textrs!备注 = Text1(7).TextIf Combo1.Text = 出借 Then rs!出借记录 = 1rs.Updaters.CloseSet rs = NothingstrSQL = Select * From 图书登记表 Order By ID DescSet rs = conn.OpenRecordset(strSQL)XID = rs!IDrs.CloseSet rs = NothingstrSQL = Select * From 出借记录Set rs = conn.OpenRecordset(strSQL)If Combo1.Text = 出借 Thenrs.AddNewrs!zhuID = XIDrs!名称 = Text1(0).Textrs!借书人 = Text1(4).Textrs!电话 = Text1(5).Textrs!地址 = Text1(6).Textrs.UpdateElsers.AddNewrs!zhuID = XIDrs!名称 = rs!借书人 = 没有出借rs!电话 = 无rs!地址 = 无rs.UpdateEnd Ifrs.CloseSet rs = Nothingconn.CloseMsgBox 记录添加成功!Unload Me书库管理.ShowEnd Sub
4/12Private Sub Command2_Click()修改记录If Val(Label4.Caption) = 0 ThenMsgBox 没有选择要修改的记录!Exit SubEnd IfDim FL As StringFL = App.Path \家庭书架.mdbSet conn = OpenDatabase(FL)strSQL = Select * From 图书登记表 Where ID= Val(Label4.Caption) Set rs = conn.OpenRecordset(strSQL)rs.Editrs!名称 = Text2(0).Textrs!书号 = Text2(1).Textrs!作者 = Text2(2).Textrs!出版社 = Text2(3).Textrs!出借状态 = Combo2.Textrs!备注 = Text2(7).TextIf Combo2.Text = 出借 Then rs!出借记录 = 1rs.Updaters.CloseSet rs = NothingstrSQL = Select * From 出借记录 Where zhuID= Val(Label4.Caption) Set rs = conn.OpenRecordset(strSQL)If Combo2.Text = 出借 ThenIf Not rs.EOF Thenrs.Editrs!名称 = Text2(0).Textrs!借书人 = Text2(4).Textrs!电话 = Text2(5).Textrs!地址 = Text2(6).Textrs.UpdateElsers.AddNewrs!zhuID = Val(Label4.Caption)rs!名称 = Text2(0).Textrs!借书人 = Text2(4).Textrs!电话 = Text2(5).Textrs!地址 = Text2(6).Textrs.UpdateEnd IfElseIf Not rs.EOF Thenrs.Editrs!名称 = Text2(0).Textrs!借书人 = 没有出借rs!电话 = 无rs!地址 = 无rs.UpdateElsers.AddNewrs!zhuID = Val(Label4.Caption)rs!名称 = Text2(0).Textrs!借书人 = 没有出借rs!电话 = 无rs!地址 = 无rs.UpdateEnd IfEnd Ifrs.CloseSet rs = Nothingconn.CloseMsgBox 记录修改成功!Label4.Caption = Unload Me书库管理.ShowEnd Sub
5/12添加记录连接Private Sub Command3_Click()Frame1.Visible = TrueFrame2.Visible = FalseFrame3.Visible = FalseZFC = 添加For i = 0 To 7Text1(i).Text = Next iCombo1.Text = Command1.Visible = TrueLabel5.Caption = 现在正在添加图书资料End Sub
6/12修改记录连接Private Sub Command4_Click()Frame1.Visible = FalseFrame2.Visible = TrueFrame3.Visible = FalseZFC = 修改For i = 0 To 7Text2(i).Text = Next iCombo2.Text = Label4.Caption = Command2.Visible = TrueLabel5.Caption = 现在正在修改图书资料End Sub
7/12删除记录连接Private Sub Command5_Click()Frame1.Visible = FalseFrame2.Visible = FalseFrame3.Visible = TrueZFC = 删除For i = 0 To 7Text3(i).Text = Next iCombo3.Text = Label1.Caption = Command6.Visible = TrueLabel5.Caption = 现在正在删除图书资料End Sub
8/12Private Sub Command6_Click()删除记录Dim SS As IntegerSS = MsgBox(确实要删除这个记录吗?, vbOKCancel, 删除确认!)If SS = 1 ThenIf Val(Label1.Caption) = 0 ThenMsgBox 没有选择要修改的记录!Exit SubEnd IfDim FL As String, XID As LongFL = App.Path \家庭书架.mdbSet conn = OpenDatabase(FL)strSQL = Select * From 图书登记表 Where ID= Val(Label1.Caption) Set rs = conn.OpenRecordset(strSQL)rs.Deleters.CloseSet rs = NothingstrSQL = Select * From 出借记录 Where zhuID= Val(Label1.Caption) Set rs = conn.OpenRecordset(strSQL)rs.Deleters.CloseSet rs = Nothingconn.CloseMsgBox 记录删除成功!Unload Me书库管理.ShowElseMsgBox 取消了删除记录!End IfEnd Sub
9/12页面启动事件Private Sub Form_Load()Dim strSQL As StringFrame1.Visible = FalseFrame2.Visible = FalseFrame3.Visible = FalseLabel5.Caption = 现在正在浏览图书资料MS1.BackColorBkg = HFFE0E0End Sub
10/12点击MSHFlexGrid控件中记录的事件Private Sub MS1_Click()Dim i As Integer, COLX As IntegerCOLX = MS1.ColROSX = MS1.RowIf ZFC = 添加 ThenFor i = 0 To 7Text1(i).Text = Next iCombo1.Text = ElseIf ZFC = 修改 ThenText2(0).Text = MS1.TextMatrix(ROSX, 1)Text2(1).Text = MS1.TextMatrix(ROSX, 2)Text2(2).Text = MS1.TextMatrix(ROSX, 3)Text2(3).Text = MS1.TextMatrix(ROSX, 4)Combo2.Text = MS1.TextMatrix(ROSX, 5)Text2(4).Text = MS1.TextMatrix(ROSX, 6)Text2(5).Text = MS1.TextMatrix(ROSX, 7)Text2(6).Text = MS1.TextMatrix(ROSX, 8)Text2(7).Text = MS1.TextMatrix(ROSX, 9)Label4.Caption = MS1.TextMatrix(ROSX, 0)Label5.Caption = 已经选择记录准备修改ElseIf ZFC = 删除 ThenText3(0).Text = MS1.TextMatrix(ROSX, 1)Text3(1).Text = MS1.TextMatrix(ROSX, 2)Text3(2).Text = MS1.TextMatrix(ROSX, 3)Text3(3).Text = MS1.TextMatrix(ROSX, 4)Combo3.Text = MS1.TextMatrix(ROSX, 5)Text3(4).Text = MS1.TextMatrix(ROSX, 6)Text3(5).Text = MS1.TextMatrix(ROSX, 7)Text3(6).Text = MS1.TextMatrix(ROSX, 8)Text3(7).Text = MS1.TextMatrix(ROSX, 9)Label1.Caption = MS1.TextMatrix(ROSX, 0)Label5.Caption = 已经选择记录准备删除ElseIf ZFC = ThenCL = MS1.ColFor i = 1 To MS1.Cols MS1.Col = i - 1 MS1.CellBackColor = vbWhiteNext iMS1.Col = CLEnd If MS1.Col = C0LX MS1.CellBackColor = H119911End Sub
11/12Private Sub MS1_LeaveCell()Dim i As IntegerDim CL As Integer离开该行时将该行的颜色恢复为白色CL = MS1.ColFor i = 1 To MS1.Cols MS1.Col = i - 1 MS1.CellBackColor = vbWhiteNext iMS1.Col = CLEnd Sub
12/12下面是出现运行的情况:

版权声明:
1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。
2、本站仅提供信息发布平台,不承担相关法律责任。
3、若侵犯您的版权或隐私,请联系本站管理员删除。
4、文章链接:http://www.1haoku.cn/art_354548.html