在VB里如何将图片写入到数据库?多谢你的帮助了。救命的了

zengjun1980 2002-04-18 02:52:08
在VB里如何将图片写入到数据库?多谢你的帮助了。救命的了
...全文
96 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
gump2000 2002-04-18
  • 打赏
  • 举报
回复
AppendChunk 和 GetChunk 方法范例
该范例使用 AppendChunk 和 GetChunk 方法用其他记录中的数据填写图像字段。

Public Sub AppendChunkX()

Dim cnn1 As ADODB.Connection
Dim rstPubInfo As ADODB.Recordset
Dim strCnn As String
Dim strPubID As String
Dim strPRInfo As String
Dim lngOffset As Long
Dim lngLogoSize As Long
Dim varLogo As Variant
Dim varChunk As Variant

Const conChunkSize = 100

' 打开连接。
Set cnn1 = New ADODB.Connection
strCnn = "Provider=sqloledb;" & _
"Data Source=srv;Initial Catalog=pubs;User Id=sa;Password=; "
cnn1.Open strCnn

' 打开 pub_info 表。
Set rstPubInfo = New ADODB.Recordset
rstPubInfo.CursorType = adOpenKeyset
rstPubInfo.LockType = adLockOptimistic
rstPubInfo.Open "pub_info", cnn1, , , adCmdTable

' 提示复制徽标。
strMsg = "Available logos are : " & vbCr & vbCr
Do While Not rstPubInfo.EOF
strMsg = strMsg & rstPubInfo!pub_id & vbCr & _
Left(rstPubInfo!pr_info, InStr(rstPubInfo!pr_info, ",") - 1) & _
vbCr & vbCr
rstPubInfo.MoveNext
Loop
strMsg = strMsg & "Enter the ID of a logo to copy:"
strPubID = InputBox(strMsg)

' 将徽标大块复制到变量中。
rstPubInfo.Filter = "pub_id = '" & strPubID & "'"
lngLogoSize = rstPubInfo!logo.ActualSize
Do While lngOffset < lngLogoSize
varChunk = rstPubInfo!logo.GetChunk(conChunkSize)
varLogo = varLogo & varChunk
lngOffset = lngOffset + conChunkSize
Loop

' 从用户处得到数据。
strPubID = Trim(InputBox("Enter a new pub ID:"))
strPRInfo = Trim(InputBox("Enter descriptive text:"))

' 添加新记录,大块复制徽标。
rstPubInfo.AddNew
rstPubInfo!pub_id = strPubID
rstPubInfo!pr_info = strPRInfo

lngOffset = 0 ' 重置位移。
Do While lngOffset < lngLogoSize
varChunk = LeftB(RightB(varLogo, lngLogoSize - lngOffset), _
conChunkSize)
rstPubInfo!logo.AppendChunk varChunk
lngOffset = lngOffset + conChunkSize
Loop
rstPubInfo.Update

' 显示新添加的数据。
MsgBox "New record: " & rstPubInfo!pub_id & vbCr & _
"Description: " & rstPubInfo!pr_info & vbCr & _
"Logo size: " & rstPubInfo!logo.ActualSize

' 删除新记录,因为这只是演示。
rstPubInfo.Requery
cnn1.Execute "DELETE FROM pub_info " & _
"WHERE pub_id = '" & strPubID & "'"

rstPubInfo.Close
cnn1.Close

End Sub

lihonggen0 2002-04-18
  • 打赏
  • 举报
回复

《 在VB中存取数据库中的图片 》

 


  一、 数据库的设计

  数据库可以采用微软的Access97或者SQL Server来进行,首先新建一张表,取名为Table,添加三个字段,分别是:姓名 Char型(SQL Server中)文本型(Access中);编号Char型(SQL Server中)文本型(Access中);照片image型(SQL Server中)OLE对象(Access中),设计好后存盘。为了可以进行远程调用,我们采用ODBC的方法进行,双击打开控制面板里的ODBC数据源,界面如图1所示:
  点“系统DSN”选项卡,按“添加”按钮选择对应的数据源驱动程序Access的*.mdb或者SQL Server,依照添加向导加添加数据源,下面就可以开始程序的编写了。
  二、 程序的编写

  运行VB,新建一个工程。本程序采用ADO控件和动态链接库访问数据库,需要加入ADO的运行库,单击“工程\引用”菜单,出现引用对话框,选择Microsoft ActiveX Data Objects2.0 Library并确定。
  添加一个Form,四个Label控件,两个TextBox控件,一个PictureBox控件,一个ADODC控件,三个CommandButton控件,一个CommandDialog控件,如果ADODC和CommandDialog控件没有出现在工具框上,请单击菜单“工程\部件”。点“控件”选项卡,在其中选中Microsoft ADO Data Control 6.0(OLEDB)和Microsoft Common Dialog Control 6.0两项按“确定”按钮。
  下面是以上各个控件的一些属性:
  Form1.MaxButton=False
  Label1.Caption=姓名:
  Label2.Caption=编号:
  Label3.Name= ResName
  Label3.BackColor= &H80000009&
  Label3.BorderStyle=1-Fixed Single
  Label3.DataField=姓名
  Label3.DataSource= AdoCtr
  Label4.Name= ResNumb
  Label4.BackColor= &H80000009&
  Label4.BorderStyle=1-Fixed Single
  Label4.DataField=编号
  Label4.DataSource= AdoCtr
  Text1.Name= Names
  Text2.Name= Numb
  CommonDialog1.Name= CDlg
  Adodc1.Name=AdoCtr
  CommonButton1.Name=PreView
  CommonButton1.Caption=预览
  CommonButton2.Name=Save
  CommonButton2.Caption=保存
  CommonButton3.Name= Update
  CommonButton3.Caption=更新
  PictureBox1.Name= PicBox
  PictureBox1.AutoSize=False
  PictureBox1.AutoRedraw=False
  PictureBox1.DataField=照片
  PictureBox1.DataSource=AdpCtr
  下面是程序代码:
  ′此工程需有Microsoft ActiveX Data Object 2.1 Library(msado15.dll)
  Dim Constr As String ′ODBC路径
  Dim FileName As String ′图片文件名
  Const BLOCKSIZE = 4096 ′每次读写块的大小




 


gump2000 2002-04-18
  • 打赏
  • 举报
回复
http://www.csdn.net/Expert/TopicView1.asp?id=639194
http://www.csdn.net/Expert/TopicView1.asp?id=623309
http://www.csdn.net/Expert/TopicView1.asp?id=610149

太多了,自己找找吧
方法也很多
gump2000 2002-04-18
  • 打赏
  • 举报
回复
http://www.applevb.com/sourcecode/dbpic.zip
再给您几个网站去看看
www.applevb.com
www.vbgood.com
www.vbeden.com
www.21code.com
gump2000 2002-04-18
  • 打赏
  • 举报
回复
http://www.applevb.com/sourcecode/dbpic.zip
ayuu 2002-04-18
  • 打赏
  • 举报
回复
http://www.china-pub.com/computers/emook/1162/info.htm

你一看就明白了!:-)
gump2000 2002-04-18
  • 打赏
  • 举报
回复
搜索以前的文章吧,太多了
已经博主授权,源码转载自 https://pan.quark.cn/s/6cfea8426862 内存辅助教程是一项专为初学者设计的课程,其目的是协助那些对计算机内存管理缺乏了解的学员构建起必要的基础知识。内存管理是计算机科学中的一个核心概念,对于深入理解和优化程序运行表现具有决定性作用。在此教程中,我们将系统性地研究内存的运行原理,探讨内存的分配与释放方法,以及借助内存辅助工具来增强程序运行效率。我们需要明确内存的定义。内存,亦称为RAM(随机存取存储器),是计算机用于临时存储数据与程序的关键组件。当CPU执行工作负载时,它必须迅速获取这些信息,而内存正是提供这种快速存取途径的设施。内存的存储容量及其传输速度直接决定了计算机处理数据的效率。在编程领域,内存管理主要包含两大方面:内存的分配与内存的释放。内存分配指的是为变量或数据结构在内存中预留空间的过程,而内存释放则是将已不再被使用的内存空间归还给操作系统,以此来防止内存资源的泄漏。不当的内存管理可能引发程序运行中断或性能降低的问题。本教程或许会涉及以下几个关键的学习要点:1. **内存种类**:熟悉不同种类的内存,例如栈内存、堆内存以及静态内存各自的特性。栈内存主要用于存放自动变量,其管理由编译器自动完成;堆内存则要求程序员自行进行分配和释放操作;静态内存是在程序编译阶段就已经被分配好的。2. **内存的分配与释放**:掌握运用C++中的`new`与`delete`,或是C语言中的`malloc`和`free`来实现动态内存的分配和释放。同时,需理解内存泄漏的概念及其可能带来的风险。3. **内存辅助工具**:介绍用于内存调试的实用工具,比如Valgrind,它能够帮助检测内存泄漏、未初始化的内存访问等异常情况,以及性...

1,217

社区成员

发帖
与我相关
我的任务
社区描述
VB 数据库(包含打印,安装,报表)
社区管理员
  • 数据库(包含打印,安装,报表)社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧