C# SQL server 存储的varbinary(MAX)类型的文件内容存储成文件

该文章描述了如何将数据库中varbinary(MAX)类型的Filecontent字段内容保存到文件系统的具体步骤,包括检查并创建目录,删除已存在文件,然后使用BinaryWriter将字节数组写入新文件。
摘要由CSDN通过智能技术生成

数据库存储 varbinary(MAX) 类型的 Filecontent

 public byte[] Filecontent { get; set; }

  
            
            string source = HostingEnvironment.MapPath("~/App_Data/MonthProducOperate");
            string filePath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "App_Data/MonthProducOperate", file.fileName); 
            //如果路径不存在,创建路径
            if (!Directory.Exists(source))
            {
                Directory.CreateDirectory(source); //创建一个文件路径   存储文档信息

            } 
            if (File.Exists(filePath))
            {
                File.Delete(filePath);
            }
             //第一种------------------------------------------------------
            Byte[] returnBytes = file.Filecontent;
            //byte[] returnBytes = new byte[file.CodeName.Length/2];
            //for (int i = 0; i < returnBytes.Length; i++)
            //{
            //    returnBytes[i] = Convert.ToByte(file.CodeName.Substring(1*2,2),16);
            //}
            Stream myStream = new FileStream(filePath, FileMode.Create, FileAccess.ReadWrite);
           //使用FileStream对象实例化BinaryWriter二进制写入流对象
            BinaryWriter myWriter=new BinaryWriter(myStream);
            //以二进制方式向创建的文件中写入内容
            myWriter.Write(returnBytes);
            //关闭当前二进制写入流 
            myWriter.Close();
            //关闭当前文件流 
            myStream.Close();
            //第二种---------------------------------------------------------------------
                  FileStream fs = null;
                    BinaryWriter bw = null;
                    try
                    {
                        byte[] content = file.Filecontent;
                        fs = new FileStream(source, FileMode.CreateNew);
                        bw = new BinaryWriter(fs);
                        bw.Write(content, 0, content.Length);
                    }
                    catch (Exception ex)
                    {
                        
                    }
                    finally
                    {
                        if (bw != null)
                        {
                            bw.Close();
                            bw = null;
                        }
                        if (fs != null)
                        {
                            fs.Close();
                            fs = null;
                        }
                    }
 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值