VB.NET 操作 ACCESS OLE 字段内容

5.gif

6.gif


数据库结构:
--------------------------------------
test.mdb [放在BIN目录下]
表 test(id 自动编号, img OLE)
----------------------------------------------

代码:
----------------------------------------------------
使用 一个 openfiledialog ,两个 picturebox

----------------------------------------------------------------------
Imports System.IO
Public Class Form1
    Inherits System.Windows.Forms.Form

    Dim cnn As Data.OleDb.OleDbConnection

    Private Sub Button4_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button4.Click
        Me.Dispose(True)
    End Sub

    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        If OpenFileDialog1.ShowDialog = DialogResult.OK Then
            PictureBox1.Image = Image.FromFile(OpenFileDialog1.FileName)
        End If
    End Sub

    Private Sub DBInit()
        Try
            cnn = New Data.OleDb.OleDbConnection("Provider=Microsoft.JET.OLEDB.4.0;Data Source=" & Application.StartupPath & "\test.mdb")
            cnn.Open()
        Catch exp As OleDb.OleDbException
            MsgBox(exp.Message)
            End
        End Try
    End Sub

    Private Sub DBRelease()
        cnn.Close()
        cnn = Nothing
    End Sub

    Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
        If PictureBox1.Image Is Nothing Then
            MsgBox("请先选择图片", MsgBoxStyle.Exclamation)
            Exit Sub
        End If
        Dim fs As FileStream = New FileStream(OpenFileDialog1.FileName, FileMode.Open, FileAccess.Read)
        Dim bt(fs.Length) As Byte
        fs.Read(bt, 0, fs.Length)
        fs.Close()
        fs = Nothing
        Dim oleCmd As OleDb.OleDbCommand = New OleDb.OleDbCommand
        DBInit()
        oleCmd.Connection = cnn
        oleCmd.CommandType = CommandType.Text
        oleCmd.CommandText = "INSERT INTO test (img) VALUES (@img)"
        oleCmd.Parameters.Add("@img", OleDb.OleDbType.Binary).Value = bt
        oleCmd.ExecuteNonQuery()
        oleCmd = Nothing
        DBRelease()
        MsgBox("图片插入成功")
    End Sub

    Private Sub Button3_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button3.Click
        Dim oleCmd As OleDb.OleDbCommand = New OleDb.OleDbCommand("SELECT img FROM test WHERE id=1")
        oleCmd.CommandType = CommandType.Text
        DBInit()
        oleCmd.Connection = cnn
        Dim dr As OleDb.OleDbDataReader = oleCmd.ExecuteReader(CommandBehavior.SingleRow)
        If dr.Read Then
            If Not IsDBNull(dr.Item(0)) Then
                Dim bt() As Byte = dr.Item(0)
                Dim ms As MemoryStream = New MemoryStream(bt)
                PictureBox2.Image = Image.FromStream(ms)
            Else
                MsgBox("无图片")
            End If
        Else
            MsgBox("无数据")
        End If
        dr.Close()
        dr = Nothing
        oleCmd = Nothing
        DBRelease()
    End Sub
End Class


真有意思

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值