中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

通過ADO.NET存取文件
來源:易賢網 閱讀:1150 次 日期:2014-08-20 14:00:03
溫馨提示:易賢網小編為您整理了“通過ADO.NET存取文件”,方便廣大網友查閱!

有時我們需要把一些大的數據對象如圖片、可執行文件、視頻和文檔等數據存入數據庫。在MS SQL Server中,這要用到Image數據類型,可以保存多達2G的數據。以下給出一個通過ADO.NET和MS SQL Server實現的小小的例子。

先創建一個測試數據表。

在查詢分析器中輸入并執行以下語句:

Create table [imgtable](

[imgid] [int] IDENTITY(1,1) NOT NULL,

[imgname] [varchar](100) COLLATE Chinese_PRC_CI_AS NULL,

[imgData] [image] NULL,

PRIMARY KEY CLUSTERED

[imgid]

) ON [PRIMARY]

) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

這要在你所選的數據庫中就多了一個名叫imgtable的表。

VS中的代碼如下:

using System;

using System.Drawing;

using System.Collections;

using System.ComponentModel;

using System.Windows.Forms;

using System.Data;

using System.Data.SqlClient;

using System.IO;

namespace ADO_Demo

{

/// <summary>

/// Form1 的摘要說明。

/// </summary>

public class ADO_Demo : System.Windows.Forms.Form

{

private System.Windows.Forms.Button button1;

private System.Windows.Forms.Button button2;

private System.Windows.Forms.PictureBox pictureBox1;

private System.Windows.Forms.OpenFileDialog openFileDialog1;

private System.Windows.Forms.Button button3;

/// <summary>

/// 必需的設計器變量。

/// </summary>

private System.ComponentModel.Container components = null;

public ADO_Demo()

{

//

// Windows 窗體設計器支持所必需的

//

InitializeComponent();

//

// TODO: 在 InitializeComponent 調用后添加任何構造函數代碼

//

}

/// <summary>

/// 清理所有正在使用的資源。

/// </summary>

protected override void Dispose( bool disposing )

{

if( disposing )

{

if (components != null)

{

components.Dispose();

}

}

base.Dispose( disposing );

}

#region Windows 窗體設計器生成的代碼

/// <summary>

/// 設計器支持所需的方法 - 不要使用代碼編輯器修改

/// 此方法的內容。

/// </summary>

private void InitializeComponent()

{

this.button1 = new System.Windows.Forms.Button();

this.button2 = new System.Windows.Forms.Button();

this.pictureBox1 = new System.Windows.Forms.PictureBox();

this.openFileDialog1 = new System.Windows.Forms.OpenFileDialog();

this.button3 = new System.Windows.Forms.Button();

this.SuspendLayout();

//

// button1

//

this.button1.Location = new System.Drawing.Point(368, 48);

this.button1.Name = "button1";

this.button1.Size = new System.Drawing.Size(104, 23);

this.button1.TabIndex = 0;

this.button1.Text = "保存圖片";

this.button1.Click += new System.EventHandler(this.button1_Click);

//

// button2

//

this.button2.Location = new System.Drawing.Point(368, 120);

this.button2.Name = "button2";

this.button2.Size = new System.Drawing.Size(104, 23);

this.button2.TabIndex = 1;

this.button2.Text = "顯示圖片";

this.button2.Click += new System.EventHandler(this.button2_Click);

//

// pictureBox1

//

this.pictureBox1.Location = new System.Drawing.Point(8, 16);

this.pictureBox1.Name = "pictureBox1";

this.pictureBox1.Size = new System.Drawing.Size(312, 288);

this.pictureBox1.TabIndex = 2;

this.pictureBox1.TabStop = false;

//

// openFileDialog1

//

this.openFileDialog1.FileOk += new System.ComponentModel.CancelEventHandler(this.openFileDialog1_FileOk);

//

// button3

//

this.button3.Location = new System.Drawing.Point(368, 200);

this.button3.Name = "button3";

this.button3.Size = new System.Drawing.Size(104, 23);

this.button3.TabIndex = 1;

this.button3.Text = "讀取文件并打開";

this.button3.Click += new System.EventHandler(this.button3_Click);

//

// ADO_Demo

//

this.AutoScaleBaseSize = new System.Drawing.Size(6, 14);

this.ClientSize = new System.Drawing.Size(496, 317);

this.Controls.Add(this.pictureBox1);

this.Controls.Add(this.button2);

this.Controls.Add(this.button1);

this.Controls.Add(this.button3);

this.Name = "ADO_Demo";

this.Text = "ADO_Demo";

this.ResumeLayout(false);

}

#endregion

/// <summary>

/// 應用程序的主入口點。

/// </summary>

[STAThread]

static void Main()

{

application.Run(new ADO_Demo());

}

 

/// <summary>

/// 點擊打開文件對話框確定按鈕,將文件保存到數據庫中

/// </summary>

/// <param name="sender"></param>

/// <param name="e"></param>

private void openFileDialog1_FileOk(object sender, System.ComponentModel.CancelEventArgs e)

{

string filename = this.openFileDialog1.FileName;

SqlConnection conn = new SqlConnection("server=192.168.2.200;integrated security = sspi;database = northwind");

SqlCommand cmd = new SqlCommand("insert imgtable values(@imgname,@imgData)",conn);

SqlParameter pm = new SqlParameter("@imgname",SqlDbType.VarChar,100);

pm.Value = filename;

SqlParameter pm1 = new SqlParameter("@imgData",SqlDbType.Image);

FileStream fs = new FileStream(filename,FileMode.Open);

int len = (int)fs.Length;

byte[] fileData = new byte[len];

fs.Read(fileData,0,len);

fs.Close();

pm1.Value = fileData;

cmd.Parameters.Add(pm);

cmd.Parameters.Add(pm1);

conn.Open();

try

{

cmd.ExecuteNonQuery();

}

catch(Exception ex)

{

MessageBox.Show(ex.Message);

}

}

private void button1_Click(object sender, System.EventArgs e)

{

this.openFileDialog1.ShowDialog();

}

/// <summary>

/// 從數據庫中讀取bitmap圖片并顯示

/// </summary>

/// <param name="sender"></param>

/// <param name="e"></param>

private void button2_Click(object sender, System.EventArgs e)

{

SqlConnection conn = new SqlConnection("server=192.168.2.200;integrated security = sspi;database = northwind");

SqlCommand cmd = new SqlCommand("select * from imgtable where imgname like '%bmp%'",conn);

conn.Open();

SqlDataReader dr;

try

{

dr = cmd.ExecuteReader();

dr.Read();

System.Data.SqlTypes.SqlBinary sb = dr.GetSqlBinary(2);

//或byte[] imageData = (byte[])dr[2];

MemoryStream ms = new MemoryStream(sb.Value);//在內存中操作圖片數據

Bitmap bmp = new Bitmap(Bitmap.FromStream(ms));

this.pictureBox1.Image = bmp;

dr.Close();

}

catch(Exception ex)

{

MessageBox.Show(ex.Message);

}

finally

{

conn.Close();

}

}

/// <summary>

/// 讀取文件并保存到硬盤,然后打開文件

/// </summary>

/// <param name="sender"></param>

/// <param name="e"></param>

private void button3_Click(object sender, System.EventArgs e)

{

SqlConnection conn = new SqlConnection("server=192.168.2.200;integrated security = sspi;database = northwind");

SqlCommand cmd = new SqlCommand("select * from imgtable where imgname like '%doc'",conn);

conn.Open();

SqlDataReader dr;

try

{

dr = cmd.ExecuteReader();

dr.Read();

System.Data.SqlTypes.SqlBinary sb = dr.GetSqlBinary(2);

//或byte[] imageData = (byte[])dr[2];

//FileStream fs = new FileStream(@"C: emp.bmp",FileMode.Create);

string filename = @"C:\" + System.IO.Path.GetFileName(dr.GetString(1));

FileStream fs = new FileStream(filename,FileMode.Create);

fs.Write(sb.Value,0,sb.Value.Length);

fs.Close();

//this.pictureBox1.Image = Image.FromFile(@"C: emp.bmp");

System.Diagnostics.Process.Start(filename);

dr.Close();

}

catch(Exception ex)

{

MessageBox.Show(ex.Message);

}

finally

{

conn.Close();

}

}

}

}

直接把整個文件讀取到內存中的數組里對于小文件來說是沒問題的,但如果是大文件,特別是大小都超過了物理內存的文件,可能會導致嚴重的內存問題,需要分段讀取,并分段寫到數據庫。

更多信息請查看IT技術專欄

更多信息請查看網絡編程
易賢網手機網站地址:通過ADO.NET存取文件
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網

中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
99精品欧美一区二区三区小说| 精品国产乱子伦一区| 91精品国产综合久久精品| 亚洲一区二区三区三| av在线免费不卡| 亚洲精品欧美激情| 欧美三级一区二区| 蜜臀av性久久久久蜜臀aⅴ四虎| 日韩亚洲电影在线| 国产成人自拍网| 亚洲综合无码一区二区| 日韩一区二区中文字幕| 国产91在线观看| 日产国产高清一区二区三区| 亚洲欧洲精品一区二区精品久久久| 欧美变态口味重另类| 国产一区二区电影| 久久中文娱乐网| 国产精品影视天天线| 一区二区三区小说| 中文字幕高清一区| 欧美日韩免费电影| 中文成人av在线| 91丨porny丨在线| 2023国产精品自拍| 日韩色在线观看| 欧美极品xxx| 欧美精品一区二区高清在线观看| 欧美一级免费观看| 成人激情开心网| 欧洲国内综合视频| 精品日韩99亚洲| 91浏览器入口在线观看| 麻豆国产精品视频| 一区二区三区不卡在线观看| 日韩免费电影网站| 欧美视频一区二区| 99r国产精品| 国内成人精品2018免费看| 亚洲在线视频免费观看| 欧美国产日韩在线观看| 日韩精品一区二| 欧美日韩国产综合一区二区| 91看片淫黄大片一级在线观看| 国产在线国偷精品免费看| 亚洲福利一区二区| 一区二区三区日韩精品| 中文字幕巨乱亚洲| 国产喂奶挤奶一区二区三区| 日韩视频在线观看一区二区| 欧美三级在线视频| 欧美写真视频网站| 欧洲另类一二三四区| 色哟哟在线观看一区二区三区| 成人自拍视频在线| 成人永久免费视频| 国产99久久精品| 国产精品亚洲成人| 高清beeg欧美| 99riav一区二区三区| proumb性欧美在线观看| 成人app在线| 一本久道中文字幕精品亚洲嫩| 9色porny自拍视频一区二区| 成人中文字幕电影| 美女在线视频一区| 黄色成人免费在线| 国产成人免费网站| 99国内精品久久| 在线看国产日韩| 欧美视频在线观看一区| 欧美日韩在线电影| 欧美性videosxxxxx| 蜜桃视频一区二区三区 | 不卡一区二区在线| 91原创在线视频| 欧美在线观看一区二区| 9191成人精品久久| 亚洲精品在线观看网站| 欧美激情一区二区三区全黄| 欧美巨大另类极品videosbest | 日本一区二区高清| 中文字幕在线一区免费| 亚洲乱码国产乱码精品精98午夜 | 日韩精品一二三区| 国产美女视频一区| 色噜噜狠狠一区二区三区果冻| 欧美一级高清片| 国产精品成人免费在线| 秋霞午夜鲁丝一区二区老狼| 成人国产在线观看| 日韩一区二区影院| 亚洲男人天堂av| 国产在线精品不卡| 欧美挠脚心视频网站| 久久精品免视看| 免费观看一级欧美片| 色综合久久综合网| 国产欧美日韩亚州综合| 日本不卡中文字幕| 在线亚洲免费视频| 欧美国产欧美亚州国产日韩mv天天看完整| 有码一区二区三区| eeuss鲁片一区二区三区| 日韩亚洲欧美高清| 亚洲福利视频一区二区| 不卡视频一二三| 久久精品夜色噜噜亚洲a∨| 日本va欧美va精品发布| 91在线视频在线| 久久九九影视网| 男男成人高潮片免费网站| 久久99久国产精品黄毛片色诱| 久久精品99久久久| 欧美性xxxxx极品少妇| 欧美一级电影网站| 视频一区二区三区中文字幕| 国产成人午夜精品影院观看视频| 91国产视频在线观看| 国产丝袜美腿一区二区三区| 亚洲图片自拍偷拍| 国产精品一级片| 777奇米四色成人影色区| 亚洲欧洲精品一区二区三区| 亚洲成人午夜电影| 精品视频1区2区| 中文字幕一区av| 国产真实乱子伦精品视频| 欧美日韩在线播放三区| 日本一区二区三区久久久久久久久不| 久久精品国产精品青草| 欧美日韩一区精品| 一区二区在线看| 99久久免费视频.com| 国产视频一区二区在线| 国产米奇在线777精品观看| 在线综合+亚洲+欧美中文字幕| 亚洲蜜臀av乱码久久精品| 国产成人精品亚洲午夜麻豆| 欧美成va人片在线观看| 日本三级韩国三级欧美三级| 精品日韩在线一区| 麻豆传媒一区二区三区| 欧美夫妻性生活| 亚洲成年人影院| 欧美男人的天堂一二区| 九九精品一区二区| 欧美大片在线观看一区二区| 日日夜夜精品视频天天综合网| 欧美体内she精高潮| 中文字幕亚洲区| 欧美日本免费一区二区三区| 午夜激情一区二区| 日本高清成人免费播放| 亚洲精品乱码久久久久久久久| 91色在线porny| 免费观看在线综合| 日韩欧美国产精品一区| 久热成人在线视频| 国产欧美一区二区精品秋霞影院| 日日摸夜夜添夜夜添亚洲女人| 久久久久亚洲综合| 国产999精品久久| 中文字幕亚洲电影| 色菇凉天天综合网| 日韩高清在线一区| 国产精品乱码一区二区三区软件| 国产精品一二三四五| 久久久综合视频| www.亚洲色图.com| 亚洲综合清纯丝袜自拍| 日韩美女一区二区三区| 国产在线精品不卡| 中文字幕中文字幕在线一区| 欧美在线999| 亚洲电影第三页| 日韩一区和二区| 国产一区二区电影| 一区二区在线观看免费| 欧美日韩亚洲国产综合| 理论电影国产精品| 亚洲欧洲无码一区二区三区| 欧美日韩一区二区三区四区五区| 国产在线一区二区| 亚洲美女屁股眼交3| 日韩一区二区免费在线电影| 国产成人免费高清| 一级女性全黄久久生活片免费| 久久久久亚洲综合| 欧美日韩一级二级三级| 免费久久精品视频| 亚洲免费观看在线视频| 欧美一级一区二区| 在线亚洲+欧美+日本专区| 精品亚洲国内自在自线福利| 亚洲欧美在线另类| 欧美va亚洲va香蕉在线| 69久久夜色精品国产69蝌蚪网| 成人永久看片免费视频天堂| 蜜臀av一区二区在线观看|