zoukankan      html  css  js  c++  java
  • SQL Server 存储图片

    // --------------------------上传图片并保存至数据库--------------------------------------

    // 从本地文件中读取图片

    System.IO.FileStream fs = new System.IO.FileStream(picPath, System.IO.FileMode.Open, System.IO.FileAccess.Read);

    // 创建buff存储二进制数据

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

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

    // 关闭文件流

    fs.Close();

    fs = null;

    // 创建写入数据库的SQL 语句 用占位符代表图片变量

    string comm = "insert into trafficsign (codeId ,picture) values ('" + dtInfo.Rows[0].Cells[0].Value.ToString() +"',@img,');";

    SqlCommand cmd = new SqlCommand();

    cmd.CommandType = System.Data.CommandType.Text;

    cmd.CommandText = comm;

    cmd.Connection = conn;

    // SQL 语句的参数的数据类型是Image 和创建数据库要保持一致

    cmd.Parameters.Add("@img", System.Data.SqlDbType.Image);

    cmd.Parameters[0].Value = buffbyt;

    // 执行SQL语句

    cmd.ExecuteNonQuery();

    buffbyt = null;

    MessageBox.Show("上传成功!");

    // ---------------------------------下载图片显示并存储-------------------------------------

    string sql = "select codeId as 标识编码,picture from trafficsign where id = " + id;

    SqlDataAdapter adapter = new SqlDataAdapter(sql,conn);

     

    DataSet testDataSet = new DataSet();

    // 创建DataSet,用于存储数据

    adapter.Fill(testDataSet, "result_data");

    InfoRow = testDataSet.Tables["result_data"].Rows[0];

    byte[] buffByte = null;

    buffByte = (byte[])InfoRow["picture"];

    // 创建内存的流数据

    System.IO.MemoryStream ms = new System.IO.MemoryStream(buffByte);

    // 将文件流转换成图片数据

    System.Drawing.Bitmap bmp = new Bitmap(ms);

    // 将内存中的图片数据设定为picture box 的数据源

    picBOX.Image = bmp;

    // 将内存中的图片数据存储至硬盘上

    bmp.Save(currPath + "//images// aaa.jpg"); 

  • 相关阅读:
    最佳调度问题_分支限界法
    运动员最佳配对问题
    最小重量机器设计问题
    实现银行家算法和先进先出算法_对文件读写数据
    n皇后问题_回溯法
    0-1背包_回溯法
    根据前序、中序、后序遍历还原二叉树
    矩阵连乘问题_动态规划
    最长公共子序列_动态规划
    最优二叉查找树_动态规划
  • 原文地址:https://www.cnblogs.com/oftenlin/p/2918471.html
Copyright © 2011-2022 走看看