注意:我要存储文件二进制流的列的类型是text,不是image类型。

我已经实现了从数据库中读取text类型的二进制流,,现在就是不知道怎么存进去.

我的部分关键代码:

StreamReader sr = new StreamReader(FilePath, System.Text.Encoding.GetEncoding("GB2312"), true);

string filetext = sr.ReadLine();//这是要存进数据库的文件二进制流文本

他们告诉我具体该用FileStream这个类来读取...但是我不知道怎么用...

上面我的代码存到数据库后,我再读取出来二进制流转换成文件后,图片就无浏览..估计是我的代码是没有读完二进制流就保存到数据库了...

说明:上面如果保存图片二进制流成功存到数据库后,在数据库看到的值可能是:“BM諪”是这样的..

我的这种方法是错误的...希望大家能帮我看看,应该怎么改...

非常感谢..

问题补充:

数据库存储二进制流的列的类型不是image,而是text类型 ,我的读取二进制字符串已经可以转换成文件了...现在就是把二进制字符串保存到数据库的时候有问题..

这是我把文件转换为二进制字符串的代码

string FilePath = this.openFileDialog1.FileName;                        //得到文件路径

string filename = FilePath.Substring(FilePath.LastIndexOf("\\") + 1);   //得到上传文件的文名

string filetext =string.Empty;

FileStream fs = new FileStream(FilePath, FileMode.OpenOrCreate, FileAccess.Read);

Byte[] fileByte = new Byte[(int)fs.Length];

fs.Read(fileByte, 0, fileByte.Length);

filetext = System.Text.Encoding.Default.GetString(fileByte); //将指定字节数组中的说有字节解码为一个字符串

fs.Close();

其他回答 共4条

System.IO.FileStream fs = new System.IO.FileStream(图片路径, FileMode.OpenOrCreate, FileAccess.Read);

byte[] fileByte = new byte[fs.Length];

fs.Read(fileByte, 0, (int)fs.Length);

然后将fileByte存到库里就行了。

回答者: kgdxpr | 四级 | 2010-5-19 16:59

text,你就当string处理就行了

思路就是先得到图片文件的对象,然后转成byte[]

然后转成string

text存储二进制文件不如image好,可能小文件速度变的慢

回答者: howeverlee | 五级 | 2010-5-19 17:04

FileStream stream;

IFormatter iFormatter = new BinaryFormatter();

stream = new FileStream("图片);

//序列化

formatter.Serialize(stream, "目标");

stream.Close();

//读取的时候用反序列化

formatter.Deserialize()

//转化为图片格式

回答者: hack6500 | 三级 | 2010-5-19 18:19

private Byte[] getphoto(string photopath)   //读取照片文件到字节数组

{

string str = photopath;

FileStream file = new FileStream(str, FileMode.Open, FileAccess.Read);

Byte[] byteData = new Byte[file.Length];

file.Read(byteData, 0, byteData.Length);

file.Close();

return byteData;

}

SQL Server下图片的插入与读取时间:2010-04-25 21:57:08来源:网络 作者:未知 点击:385次

下午向数据库SQL SERVER中遇到添加图片类型数据的问题,本以为在界面管理器中可以直接(通过指定路径把图片的数据保存起来)添加图片却不然。网上搜了下找到了相关的较专业的资料,整合解读一下:

下午向数据库SQL SERVER中遇到添加图片类型数据的问题,本以为在界面管理器中可以直接(通过指定路径把图片的数据保存起来)添加图片却不然。网上搜了下找到了相关的较专业的资料,整合解读一下:

两种方法:

第一就是在数据库中存储图片的路径,然后在程序中根据读取的路径读取图片;这种方法简单、容易使用,但是在图片过多时不好管理。

第二种就是将图片转换成二进制存储于数据库中,sql server 2005有个image数据类型,专门用于存储图片,Image数据类型存储的是长度不确定的二进制数据,最大长度是2GB。

第二种方法(详情请参阅:详述的过程)

简述过程:

当然首先得有存储图片字段的数据库、表。

如何插入图片:

大致流程:其他图片格式--》image类型的转化--》到MemoryStream流的转换--》到二进制的转换--》插入到数据库。

如何得到图片:

大致流程:选取数据库中的image类型字段--》转化为二进制流--》转化为MemoryStream流--》转化为Image图片格式类型。

其它:如何插入读取一个文件、如何保存数据库中的image字段到一个文件。。

本篇文章来源于:开发学院 http://edu.codepub.com   原文链接:http://edu.codepub.com/2010/0425/22271.php

C#图片转换成二进制流并且保存到sql server数据库的更多相关文章

  1. java中如何把图片转换成二进制流的代码

    在学习期间,把开发过程经常用到的一些代码段做个备份,下边代码内容是关于java中如何把图片转换成二进制流的代码,应该能对各朋友也有用处. public byte[] SetImageToByteArr ...

  2. C#将image中的显示的图片转换成二进制

    原文:C#将image中的显示的图片转换成二进制 1.将Image图像文件存入到数据库中 我们知道数据库里的Image类型的数据是"二进制数据",因此必须将图像文件转换成字节数组才 ...

  3. [转]C#将image中的显示的图片转换成二进制

    本文转自:http://www.cnblogs.com/shuang121/archive/2012/07/09/2582654.html .将Image图像文件存入到数据库中 我们知道数据库里的Im ...

  4. java将图片转换成二进制

    package com.oumyye.图片; import java.awt.image.BufferedImage; import java.io.ByteArrayInputStream; imp ...

  5. C#中 将图片保存到Sql server 中

    private void Form1_Load(object sender, EventArgs e) { #region 保存数据库 string url = @"C:\Users\Adm ...

  6. net9:图片文件转换成二进制流存入SQL数据库,以及从数据库中读取二进制流输出文件

    原文发布时间为:2008-08-10 -- 来源于本人的百度文章 [由搬家工具导入] using System;using System.Data;using System.Configuration ...

  7. PDF转换成二进制字符串写入 HTTP 输出流

    最近项目需要做电子签章,需要网页打开PDF签章后保存:正好复习哈二进制和流的转换: 文件转换成二进制字符串写入HTTP输出流 protected void Page_Load(object sende ...

  8. php将文件转换成二进制输出[转]

    header( "Content-type: image/jpeg"); $PSize = filesize('1.jpg'); $picturedata = fread(fope ...

  9. 减少HTTP请求之将图片转成二进制并生成Base64编码,可以在网页中通过url查看图片(大型网站优化技术)

    在网站开发过程中,对于页面的加载效率一般都想尽办法求快.那么,怎么让才能更快呢?减少页面请求 是一个优化页面加载速度很好的方法.上一篇博文我们讲解了 “利用将小图标合成一张背景图来减少HTTP请求”, ...

随机推荐

  1. 5G频谱到底有多值钱?

    继9月召开5G峰会并发布“5GFAST”战略后,美国于当地时间11月14日正式启动5G频谱拍卖.“这些频谱对于部署5G服务和应用程序至关重要,而我们并没有就此止步.”美国联邦通信委员会(FCC)主席A ...

  2. mysql-innodb的事务日志

    [参考书籍:mysql技术内幕 INNODB存储引擎][参考了一些博客内容] 事务的隔离性由锁机制来实现,事务的原子性,一致性,持久性通过INNODB的redo log和undo log来完成. re ...

  3. VC++ PathFindFileName函数,由文件路径获得文件名

    1.PathFindFileName函数的作用是返回路径中的文件名. PTSTR PathFindFileName( __in PTSTR pPath ); pPath是指向文件路径字符串的指针,函数 ...

  4. Python3基础 str """ 多行字符串

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  5. P2472 [SCOI2007]蜥蜴(网络最大流)

    P2472 [SCOI2007]蜥蜴 题目描述 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的距离为1,蜥蜴的跳跃距 ...

  6. Codeforces Round #528 div1

    完了,看来上一次的flag要应验了,我大概是真的要掉成pupil了吧.. A - Connect Three 这个就是找到x的中间值,y的中间值,然后切一下,然后把所有的点挂到这条边上.但是我做的还是 ...

  7. 51nod 1076 2条不相交的路径(边双连通分量)

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1076 题意: 思路: 边双连通分量,跑一遍存储一下即可. #includ ...

  8. 简易页面场景滚动的jquery插件

    (function($){ $.extend($.fn, { scene_scroll:function(arg_obj){ // 参数检测 // 场景数组 var $scene_arr = arg_ ...

  9. MVC ---- T4(1)

    T4 模板编辑插件:tangibleT4EditorPlusModellingToolsVS2012.msi 下载地址:http://t4-editor.tangible-engineering.co ...

  10. Android广播接收器里弹出对话框

    不多说,直接上车... public class MyReceiver extends BroadcastReceiver { @Override public void onReceive(fina ...