C# 读写ACCESS的OLE对象,演示图片与长文件的读写

2010021512020698.gif

网络上的读写OLE对象的代码是多,不过多是转载的,大部分人从来都没实际测试过,只是COPY来COPY去。我重来没看到一个真正可以运行的东东。
没办法,只有自力更生,花了一点时间出了点研究成果,写到这里做个记录。

关键代码如下:

******* void button1_Click(object sender, EventArgs e)  //写入图片
        {
            OpenFileDialog dlg = new OpenFileDialog();
            dlg.Filter = "All   Files|*.*";
            if (dlg.ShowDialog() == DialogResult.OK)
            {
                string fileName = dlg.FileName;

                FileStream fs = new FileStream(fileName, FileMode.Open, FileAccess.Read);
                byte[] buffer = new byte[fs.Length];
                fs.Read(buffer, 0, buffer.Length);
                fs.Close();

                //pictureBox1.Image = Image.FromFile(fileName);

                OleDbConnection cn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Application.StartupPath + "\\db1.mdb" + ";Persist Security Info=True");
                cn.Open();

                OleDbCommand cmd = new OleDbCommand("INSERT INTO  list1(pic)  VALUES(@img)", cn);
                ((OleDbParameter)cmd.Parameters.Add("@img", OleDbType.Binary)).Value = buffer;
                cmd.ExecuteNonQuery();
            }  
 

          
    }

        ******* void button2_Click(object sender, EventArgs e)  //读取图片
        {
            OleDbConnection cn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Application.StartupPath + "\\db1.mdb" + ";Persist Security Info=True");
            cn.Open();

            OleDbDataAdapter oda = new OleDbDataAdapter("select  pic  from  list1 where 编号=10", cn);
           

            DataTable dt = new DataTable();
            oda.Fill(dt);

            cn.Close();

            byte[] buffer = dt.Rows[0][0] as byte[];
            MemoryStream ms = new MemoryStream(buffer);

            pictureBox1.Image = Image.FromStream(ms);
        }

        ******* void button3_Click(object sender, EventArgs e)  //写入长文本
        {
            OpenFileDialog dlg = new OpenFileDialog();
            dlg.Filter = "TXT Files|*.txt";
            if (dlg.ShowDialog() == DialogResult.OK)
            {
                string fileName = dlg.FileName;

                FileStream fs = new FileStream(fileName, FileMode.Open, FileAccess.Read);
                byte[] buffer = new byte[fs.Length];
                fs.Read(buffer, 0, buffer.Length);
                fs.Close();

                //pictureBox1.Image = Image.FromFile(fileName);

                OleDbConnection cn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Application.StartupPath + "\\db1.mdb" + ";Persist Security Info=True");
                cn.Open();

                OleDbCommand cmd = new OleDbCommand("INSERT INTO  list1(pic)  VALUES(@img)", cn);
                ((OleDbParameter)cmd.Parameters.Add("@img", OleDbType.Binary)).Value = buffer;
                cmd.ExecuteNonQuery();
            }  
        }

        ******* void button4_Click(object sender, EventArgs e)  //载入长文本
        {
            OleDbConnection cn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Application.StartupPath + "\\db1.mdb" + ";Persist Security Info=True");
            cn.Open();

            OleDbDataAdapter oda = new OleDbDataAdapter("select  pic  from  list1 where 编号=12", cn);

            DataTable dt = new DataTable();
            oda.Fill(dt);

            cn.Close();

            byte[] buffer = dt.Rows[0][0] as byte[];
            //MemoryStream ms = new MemoryStream(buffer);
            richTextBox1.Text =System.Text.Encoding.Default.GetString(buffer);


        }

转载于:https://www.cnblogs.com/hackpig/archive/2010/02/15/1668441.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/299465.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RHCE课程-初级部分6、编辑工具VIM,网络配置,进程优先,日志文件简介。

我们通常用各种编辑工具来处理文本文件 常用的编辑工具:VIVIMEMACSVI和VIM的区别它们都是多模式编辑器,不同的是vim 是vi的升级版本,它不仅兼容vi的所有指令,而且还有一些新的特性在里面。vim的这些优势主要体现在以下几个方面:易…

WPF等待动画

WPF开发者QQ群: 340500857 | 微信群 -> 进入公众号主页 加入组织欢迎转发、分享、点赞、在看,谢谢~。 01—效果预览效果预览(更多效果请下载源码体验):02—代码如下一、CycleLoading.cs 代码如下using System.Win…

假期别在家里要发霉了?可以靠他们度过无聊时光

全世界只有3.14 % 的人关注了青少年数学之旅在这个资讯丰富且易获取的时代,越来越多的人不愿意花时间阅读书籍,碎片化阅读成了主流。人们获取的东西多而杂,很难系统、全面。海量信息对人是冲击,更是诱惑。谁不想了解天下奇闻&…

cs6序列号 mac版photoshop_重磅!Parallels Desktop 16 M1版发布

Parallels 现已发布 Parallels Desktop 16 技术预览版,可以在搭载 M1 芯片的 Mac 电脑上运行。该公司表示,它创建了一个 “使用 Apple M1 Mac 芯片硬件辅助虚拟化的新虚拟化引擎”,允许用户在虚拟机中运行基于 Arm 的操作系统,例如…

华为二面!!!面试官直接问我Java中到底什么是NIO?这不是直接送分题???

华为二面!!!面试官直接问我Java中到底什么是NIO?这不是直接送分题???什么是NIO缓冲区(Buffer)缓冲区类型获取缓冲区核心属性核心方法非直接缓冲区和直接缓冲区非直接缓冲区直接缓冲区通道(Chann…

REST

REST 定义了一组体系架构原则,您可以根据这些原则设计以系统资源为中心的 Web 服务REST 对 Web 的影响非常大,由于其使用相当方便,已经普遍地取代了基于 SOAP 和 WSDL 的接口设计。REST Web 服务,其具体实现应该遵循四个基本设计原…

Delphi中的容器类(3)

TBucketList和TObjectBucketList类 从Delphi6开始,VCL的Contnrs单元中又增加了两个新的容器类TBucketList和TObjectBucketList。TBucketList实际上也是一个简单基于哈希表的指针-指针对列表。接口定义如下: TBucketList class(TCustomBucketList)… pu…

修改PATH导致fedora无法登录XWindow

用过fedora的都了解到,如果要使用像ifconfig,arp等这些外部命令,就必需加入路径,有点麻烦(我懒人一个-_-)。所以我就在/etc/profile文件结尾处加入了一行:export PATH$PATH:/sbin很好,感觉上没问…

一文读懂哈希和一致性哈希算法

哈希 Hash 算法介绍哈希算法也叫散列算法, 不过英文单词都是 Hash, 简单一句话概括, 就是可以把任意长度的输入信息通过算法变换成固定长度的输出信息, 输出信息也就是哈希值, 通常哈希值的格式是16进制或者是10进制, 比如下面的使用 md5 哈希算法的示例md5("123456"…

延迟开学?这些教育读书公众号可以帮助孩子学习! 你都关注了吗?

全世界只有3.14 % 的人关注了青少年数学之旅受新型冠状病毒疫情影响,日前,教育部印发《关于2020年春季学期延期开学的通知》。推迟开学时间,意味着寒假的延长。为此,小编精选这些优质的教育号和读书号帮助孩子学习!理想…

go方法的深入探究(7.21增补)

2019独角兽企业重金招聘Python工程师标准>>> 1)哪些类型可以有方法: 1)只能对命名类型和命名类型的指针编写方法; 2)不能对接口类型和接口类型的指针编写方法; 3)只能在定义命名类型…

element文件上传有文件但是后台接收为空_程序员提高篇:大规格文件(G)是如何做分片优化的?...

作者:凹凸实验室 链接:https://juejin.im/post/5ebb4346e51d451ef53793ad整体思路第一步是结合项目背景,调研比较优化的解决方案。 文件上传失败是老生常谈的问题,常用方案是将一个大文件切片成多个小文件,并行请求接口…

你连简单的枚举类都不知道,还敢说自己会Java???滚出我的公司

枚举类型是Java 5中新增的特性,它是一种特殊的数据类型,之所以特殊是因为它既是一种类(class)类型却又比类类型多了些特殊的约束,但是这些约束的存在也造就了枚举类型的简洁性、安全性以及便捷性。当需要定义一组常量时,强烈建议使…

爱情第七课,被爱的秘密

我们都想要被爱。 这和懒着,却想有好东西吃时的心态一样。但爱的需要却和生理需要不同,它是一种更高级的精神需要。 在小时候,我们还不懂得什么是爱时,就接收到父母爱的信号:被照顾,被养育,被善…

很好用的ISO制作软件

我一直在用 很小 很实在转载于:https://blog.51cto.com/windows2008/114161

Asp.NET Core 中如何加密 Configuration ?

咨询区 Ovi:web.config 已进入历史垃圾堆,请问现在的 asp.net core 如何更好的做到将敏感信息(password,token) 存储到 configuration 中?换句话说:是否可以自动化解密 appsettings.json 中的 configuration p 节中加密的内容。回…

时隔两年 重新当码农

FIGHTING 转载于:https://www.cnblogs.com/zy691357966/p/5480494.html

早教机器人刷固件_机器人线刷包_机器人刷机包_机器人固件包_机器人救砖包 - 线刷宝ROM中心...

线刷宝用户协议本协议是用户 (自然人、法人或社会团体)与杭州登先网络科技有限公司(以下简称"登先网络")之间关于"线刷宝"软件产品(以下简称"本软件产品")的法律协议。一旦安装、复制或以其他方式使用本软件产品,即表示同意接受协议各…

绝对硬核!万物有“理”,科学原来如此有趣!

▲ 点击查看假如在生活中,你不小心将生鸡蛋和熟鸡蛋混在一起了,那么此时你要如何分辨,哪个鸡蛋是生的,哪个是熟的呢?假若你曾学过力学,那你一定能够轻易的分辨这个生熟问题。我们把这两个鸡蛋放在桌上&…

最近有粉丝向我请教Java泛型,于是重温了一下,希望学弟面试顺利

什么是泛型? 泛型(Generic type 或者 generics)是对 Java 语言的类型系统的一种扩展,以支持创建可以按类型进行参数化的类。可以把类型参数看作是使用参数化类型时指定的类型的一个占位符,就像方法的形式参数是运行时…