C# IO流的操作(二)

文件在操作系统中是以二进制(01)的形式保存到磁盘上的,在C#程序当中,我们可以通过读取流将文件读取到byte[]当中(读到内存中),也可以通过写入流将byte[]写入文件(保存到磁盘上)。下面将演示一例文件与数据库结合的示例——将文件保存到数据库,再从数据库还原为文件。

 

写入文件到数据库部分代码:

 /// <summary>
 /// 写入按钮事件
 /// </summary>
 private void button1_Click(object sender, EventArgs e)
 {
     //将文件读取到字节数组
     FileStream fs = new FileStream("test.docx", FileMode.Open);
     byte[] bytes = new byte[(int)fs.Length];
     fs.Read(bytes, 0, bytes.Length);

     //保存到数据库
     using (SqlConnection conn = new SqlConnection("server=.;uid=sa;pwd=123456;database=test"))
     {
         conn.Open();
         string sql = "insert into 文件表([file]) values(@file)";
         SqlCommand cmd = new SqlCommand(sql, conn);
         cmd.Parameters.Add(new SqlParameter("@file", bytes));
         int i = cmd.ExecuteNonQuery();
         if (i > 0)
         {
             MessageBox.Show("文件写入成功");
         }
     }
 }

 

读取数据库byte[]到本地磁盘文件的代码:

/// <summary>
/// 读取按钮事件
/// </summary>
private void button2_Click(object sender, EventArgs e)
{
    using (SqlConnection conn = new SqlConnection("server=.;uid=sa;pwd=123456;database=test"))
    {
        conn.Open();
        string sql = "select [file] from 文件表";
        SqlCommand cmd = new SqlCommand(sql, conn);

        SqlDataReader sdr = cmd.ExecuteReader();
        if (sdr.Read())
        {
            byte[] bytes = (byte[])sdr["file"];

            //直接写入字节数组到文件(写法1)
            File.WriteAllBytes("test-new.docx", bytes);
            MessageBox.Show("文件保存成功");

            //将字节数组读取到流,然后用流写入文件(写法2)
            FileInfo file = new FileInfo("test-new.docx");
            FileStream fs = file.OpenWrite();
            fs.Write(bytes, 0, bytes.Length);
            fs.Close();

            //将字节数组写入内存流,直接从内存流中加载图片显示
            MemoryStream ms = new MemoryStream();
            ms.Write(bytes, 0, bytes.Length);
            this.pictureBox1.Image = Image.FromStream(ms);
        }
        sdr.Close();
    }
}

 

说明:

1)数据库file字段是sql关键字,所以用[]括号括起来[file]。此外file字段要设置为image类型。

2)上述的代码部分演示了保存本地word文件到数据库,再从数据库还原为word文档的过程,对于图片(包括gif动画)也是一样的操作方式。

转载于:https://www.cnblogs.com/guwei4037/p/8074470.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值