Trang chủ
Bài viết mới
Diễn đàn
Bài mới trên hồ sơ
Hoạt động mới nhất
VIDEO
Mùa Tết
Văn Học Trẻ
Văn Học News
Media
New media
New comments
Search media
Đại Học
Đại cương
Chuyên ngành
Triết học
Kinh tế
KHXH & NV
Công nghệ thông tin
Khoa học kĩ thuật
Luận văn, tiểu luận
Phổ Thông
Lớp 12
Ngữ văn 12
Lớp 11
Ngữ văn 11
Lớp 10
Ngữ văn 10
LỚP 9
Ngữ văn 9
Lớp 8
Ngữ văn 8
Lớp 7
Ngữ văn 7
Lớp 6
Ngữ văn 6
Tiểu học
Thành viên
Thành viên trực tuyến
Bài mới trên hồ sơ
Tìm trong hồ sơ cá nhân
Credits
Transactions
Xu: 0
Đăng nhập
Đăng ký
Có gì mới?
Tìm kiếm
Tìm kiếm
Chỉ tìm trong tiêu đề
Bởi:
Hoạt động mới nhất
Đăng ký
Menu
Đăng nhập
Đăng ký
Install the app
Cài đặt
Chào mừng Bạn tham gia Diễn Đàn VNKienThuc.com -
Định hướng Forum
Kiến Thức
- HÃY TẠO CHỦ ĐỀ KIẾN THỨC HỮU ÍCH VÀ CÙNG NHAU THẢO LUẬN Kết nối:
VNK X
-
VNK groups
| Nhà Tài Trợ:
BhnongFood X
-
Bhnong groups
-
Đặt mua Bánh Bhnong
KHOA HỌC KỸ THUẬT
Kỹ thuật - Cơ kí
Cách chèn hình ảnh trực tiếp vào database trong C Sharp (P1)
JavaScript is disabled. For a better experience, please enable JavaScript in your browser before proceeding.
You are using an out of date browser. It may not display this or other websites correctly.
You should upgrade or use an
alternative browser
.
Trả lời chủ đề
Nội dung
<blockquote data-quote="hoangphuong2003" data-source="post: 67620" data-attributes="member: 1882"><p><strong>Trong bài viết này tôi sẽ hướng dẫn bạn cách chèn hình ảnh trực tiếp vào database. Cách này tuy làm cho database lớn/nặng nhưng nó cũng giải quyết rất nhiều vấn đề trong quá trình lập trình</strong>.</p><p>Ở đây, csdl tôi sử dụng là ms Access và MS SQLserver.</p><p>Database là Access</p><p><strong>1.</strong> Bạn tạo 1 file access có tên TestDB.mdb nằm trong thư mục bindebug của ứng dụng(chỗ khác cũng không sao, tùy).Tạo 1 bảng có tên tblSinhvien có cấu trúc như sau:</p><p>Tên field Kiểu dữ liệu</p><p>MSSV Text(15)</p><p>hinhAnh OLE Object</p><p><strong>2.</strong> Tạo 1 Windows Form Application Project có tên Store_Retrieve_Image_From_DB.</p><p><strong>3</strong>. Tạo lớp có tên ConnectDB.cs với nội dung sau:</p><p></p><p>using System;</p><p>using System.Collections.Generic;</p><p>using System.Text;</p><p>using System.Data;</p><p>using System.Data.OleDb;namespace Store_Retrieve_Image_From_DB</p><p>{</p><p>public class ConnectDB</p><p>{</p><p>private OleDbConnection con;</p><p>private DataSet ds;</p><p>private OleDbDataAdapter daSV;</p><p>///</p><p>/// Phương thức constructor khởi tạo kết nối đến database</p><p>///</p><p>public ConnectDB()</p><p>{</p><p>try</p><p>{</p><p>con = new OleDbConnection();</p><p>con.ConnectionString = "Provider=microsoft.jet.OLEDB.4.0;Data Source="+</p><p>System.Windows.Forms.Application.StartupPath+"TestDB.mdb";</p><p>con.Open();</p><p>}</p><p>catch (Exception)</p><p>{</p><p>throw;</p><p>}</p><p>}</p><p>///</p><p>/// Lấp về tất cả các mẫu tin trong bảng tblSinhvien</p><p>///</p><p>///</p><p>public DataSet GetTable()</p><p>{</p><p>ds = new DataSet();</p><p>daSV = new OleDbDataAdapter("select * from tblSinhvien", con);</p><p>daSV.Fill(ds, "tblSinhvien");</p><p>return ds;</p><p>}</p><p>///</p><p>/// Cập nhật các thay đổi của người dùng</p><p>///</p><p>public void UpdateSV()</p><p>{</p><p>try</p><p>{</p><p>OleDbCommandBuilder bd = new OleDbCommandBuilder(daSV);</p><p>daSV.Update(ds, "tblSinhvien");</p><p>}</p><p>catch (Exception)</p><p>{</p><p>throw;</p><p>}</p><p>}</p><p>}</p><p>}</p><p>Lớp này dùng để đọc dữ liệu từ database cũng như cập nhật dữ liệu xuống database.</p><p><strong>4</strong>. Thiết kế MainForm như hình</p><p><img src="https://thanglong-aptech.com/wp-content/uploads/2010/12/dbimage_cs_01.png" alt="" class="fr-fic fr-dii fr-draggable " data-size="" style="" /></p><p></p><p>5. Code cho Form:</p><p>using System;</p><p>using System.Collections.Generic;</p><p>using System.ComponentModel;</p><p>using System.Data;</p><p>using System.Drawing;</p><p>using System.IO;</p><p>using System.Windows.Forms;namespace Store_Retrieve_Image_From_DB</p><p>{</p><p>public partial class MainForm : Form</p><p>{</p><p>private ConnectDB conDB;</p><p>private DataSet ds = new DataSet();</p><p>private BindingSource bs;</p><p>private DataTable dtSV;</p><p>public MainForm()</p><p>{</p><p>InitializeComponent();</p><p>}</p><p>private void MainForm_Load(object sender, EventArgs e)</p><p>{</p><p>try</p><p>{</p><p>conDB = new ConnectDB();</p><p>ds = conDB.GetTable();</p><p>dtSV = ds.Tables["tblSinhvien"];</p><p>bs = new BindingSource(ds, "tblSinhvien");</p><p>bs.CurrentItemChanged += new EventHandler(bs_CurrentItemChanged);</p><p>dataGridView1.DataSource = bs;</p><p>bindingNavigator1.BindingSource = bs;</p><p>}</p><p>catch (Exception ex)</p><p>{</p><p>MessageBox.Show(ex.ToString());</p><p>}</p><p>}</p><p>///</p><p>/// Sự kiện xảy ra khi binding source có sự thay đổi do người</p><p>/// dùng chọn các dòng trên lưới hặc nhấn các nút di chuyển.</p><p>///</p><p>///</p><p>///</p><p>void bs_CurrentItemChanged(object sender, EventArgs e)</p><p>{</p><p>DataRowView row = (DataRowView)bs.Current;</p><p>try</p><p>{</p><p>Byte[] i = (byte[])row["hinhAnh"];</p><p>MemoryStream stmBLOBData = new MemoryStream(i);</p><p>picHinhAnh.Image = Image.FromStream(stmBLOBData);</p><p>}</p><p>catch (Exception ex)</p><p>{</p><p>picHinhAnh.Image = null;</p><p>MessageBox.Show(ex.ToString());</p><p>}</p><p>}</p><p>private void btnLuu_Click(object sender, EventArgs e)</p><p>{</p><p>try</p><p>{</p><p>DataRow dr = dtSV.NewRow();</p><p>dr["MSSV"] = txtMSSV.Text;</p><p>if (picHinhAnh.Image != null)</p><p>{</p><p>MemoryStream ms = new MemoryStream();</p><p>picHinhAnh.Image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);</p><p>Byte[] bytBLOBData = new Byte[ms.Length];</p><p>ms.Position = 0;</p><p>ms.Read(bytBLOBData, 0, Convert.ToInt32(ms.Length));</p><p>dr["hinhAnh"] = bytBLOBData;</p><p>dtSV.Rows.Add(dr);</p><p>conDB.UpdateSV();</p><p>}</p><p>}</p><p>catch (Exception ex)</p><p>{</p><p>MessageBox.Show(ex.ToString());</p><p>}</p><p>}</p><p>private void btnLoadHinh_Click(object sender, EventArgs e)</p><p>{</p><p>OpenFileDialog dlg = new OpenFileDialog();</p><p>dlg.Filter = "JPG Files(*.JPG)|*.JPG|GIF Files(*.GIF)|*.GIF";</p><p>if (dlg.ShowDialog(this) == DialogResult.OK)</p><p>{</p><p>picHinhAnh.Image = Image.FromFile(dlg.FileName);</p><p>}</p><p>}</p><p>}</p><p>}</p><p>[java]</p><p>Chú ý:</p><p>Để đọc dữ liệu hình ảnh ra ta dùng 1 mảng Byte để chứa giá trị của field hình ảnh. Sau đó muốn hiển thị nó lên PictureBox ta phải dùng MemoryStream để đưa ra:</p><p>[java]</p><p>Byte[] i = (byte[])row["hinhAnh"];</p><p>MemoryStream stmBLOBData = new MemoryStream(i);</p><p>picHinhAnh.Image = Image.FromStream(stmBLOBData);</p><p>Để cập nhật dữ liệu vào db, ta phải lấy ảnh từ PictureBox vào 1 MemoryStream:</p><p>?</p><p>1</p><p>2</p><p>MemoryStream ms = new MemoryStream();</p><p>picHinhAnh.Image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);</p><p>Rồi sau đó mới chuyển nó thành mảng Byte rồi cung cấp cho 1 datarow để update xuống database.</p><p></p><p>Byte[] bytBLOBData = new Byte[ms.Length];</p><p>ms.Position = 0;</p><p>ms.Read(bytBLOBData, 0, Convert.ToInt32(ms.Length));</p><p>dr["hinhAnh"] = bytBLOBData;</p><p>dtSV.Rows.Add(dr);</p><p></p><p>Chạy ứng dụng, kết quả như hình sau:</p><p><img src="https://thanglong-aptech.com/wp-content/uploads/2010/12/dbimage_cs_02.png" alt="" class="fr-fic fr-dii fr-draggable " data-size="" style="" /></p><p></p><p>Theo vovanhai</p><p><strong>Nguồn</strong>: <strong><em>Chèn hình ảnh trực tiếp vào database trong C sharp(P1)</em></strong></p><p>___________________________________________</p><p>Học tiếng anh chuyên ngành công nghệ thông tin</p></blockquote><p></p>
[QUOTE="hoangphuong2003, post: 67620, member: 1882"] [B]Trong bài viết này tôi sẽ hướng dẫn bạn cách chèn hình ảnh trực tiếp vào database. Cách này tuy làm cho database lớn/nặng nhưng nó cũng giải quyết rất nhiều vấn đề trong quá trình lập trình[/B]. Ở đây, csdl tôi sử dụng là ms Access và MS SQLserver. Database là Access [B]1.[/B] Bạn tạo 1 file access có tên TestDB.mdb nằm trong thư mục bindebug của ứng dụng(chỗ khác cũng không sao, tùy).Tạo 1 bảng có tên tblSinhvien có cấu trúc như sau: Tên field Kiểu dữ liệu MSSV Text(15) hinhAnh OLE Object [B]2.[/B] Tạo 1 Windows Form Application Project có tên Store_Retrieve_Image_From_DB. [B]3[/B]. Tạo lớp có tên ConnectDB.cs với nội dung sau: using System; using System.Collections.Generic; using System.Text; using System.Data; using System.Data.OleDb;namespace Store_Retrieve_Image_From_DB { public class ConnectDB { private OleDbConnection con; private DataSet ds; private OleDbDataAdapter daSV; /// /// Phương thức constructor khởi tạo kết nối đến database /// public ConnectDB() { try { con = new OleDbConnection(); con.ConnectionString = "Provider=microsoft.jet.OLEDB.4.0;Data Source="+ System.Windows.Forms.Application.StartupPath+"TestDB.mdb"; con.Open(); } catch (Exception) { throw; } } /// /// Lấp về tất cả các mẫu tin trong bảng tblSinhvien /// /// public DataSet GetTable() { ds = new DataSet(); daSV = new OleDbDataAdapter("select * from tblSinhvien", con); daSV.Fill(ds, "tblSinhvien"); return ds; } /// /// Cập nhật các thay đổi của người dùng /// public void UpdateSV() { try { OleDbCommandBuilder bd = new OleDbCommandBuilder(daSV); daSV.Update(ds, "tblSinhvien"); } catch (Exception) { throw; } } } } Lớp này dùng để đọc dữ liệu từ database cũng như cập nhật dữ liệu xuống database. [B]4[/B]. Thiết kế MainForm như hình [IMG]https://thanglong-aptech.com/wp-content/uploads/2010/12/dbimage_cs_01.png[/IMG] 5. Code cho Form: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.IO; using System.Windows.Forms;namespace Store_Retrieve_Image_From_DB { public partial class MainForm : Form { private ConnectDB conDB; private DataSet ds = new DataSet(); private BindingSource bs; private DataTable dtSV; public MainForm() { InitializeComponent(); } private void MainForm_Load(object sender, EventArgs e) { try { conDB = new ConnectDB(); ds = conDB.GetTable(); dtSV = ds.Tables["tblSinhvien"]; bs = new BindingSource(ds, "tblSinhvien"); bs.CurrentItemChanged += new EventHandler(bs_CurrentItemChanged); dataGridView1.DataSource = bs; bindingNavigator1.BindingSource = bs; } catch (Exception ex) { MessageBox.Show(ex.ToString()); } } /// /// Sự kiện xảy ra khi binding source có sự thay đổi do người /// dùng chọn các dòng trên lưới hặc nhấn các nút di chuyển. /// /// /// void bs_CurrentItemChanged(object sender, EventArgs e) { DataRowView row = (DataRowView)bs.Current; try { Byte[] i = (byte[])row["hinhAnh"]; MemoryStream stmBLOBData = new MemoryStream(i); picHinhAnh.Image = Image.FromStream(stmBLOBData); } catch (Exception ex) { picHinhAnh.Image = null; MessageBox.Show(ex.ToString()); } } private void btnLuu_Click(object sender, EventArgs e) { try { DataRow dr = dtSV.NewRow(); dr["MSSV"] = txtMSSV.Text; if (picHinhAnh.Image != null) { MemoryStream ms = new MemoryStream(); picHinhAnh.Image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg); Byte[] bytBLOBData = new Byte[ms.Length]; ms.Position = 0; ms.Read(bytBLOBData, 0, Convert.ToInt32(ms.Length)); dr["hinhAnh"] = bytBLOBData; dtSV.Rows.Add(dr); conDB.UpdateSV(); } } catch (Exception ex) { MessageBox.Show(ex.ToString()); } } private void btnLoadHinh_Click(object sender, EventArgs e) { OpenFileDialog dlg = new OpenFileDialog(); dlg.Filter = "JPG Files(*.JPG)|*.JPG|GIF Files(*.GIF)|*.GIF"; if (dlg.ShowDialog(this) == DialogResult.OK) { picHinhAnh.Image = Image.FromFile(dlg.FileName); } } } } [java] Chú ý: Để đọc dữ liệu hình ảnh ra ta dùng 1 mảng Byte để chứa giá trị của field hình ảnh. Sau đó muốn hiển thị nó lên PictureBox ta phải dùng MemoryStream để đưa ra: [java] Byte[] i = (byte[])row["hinhAnh"]; MemoryStream stmBLOBData = new MemoryStream(i); picHinhAnh.Image = Image.FromStream(stmBLOBData); Để cập nhật dữ liệu vào db, ta phải lấy ảnh từ PictureBox vào 1 MemoryStream: ? 1 2 MemoryStream ms = new MemoryStream(); picHinhAnh.Image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg); Rồi sau đó mới chuyển nó thành mảng Byte rồi cung cấp cho 1 datarow để update xuống database. Byte[] bytBLOBData = new Byte[ms.Length]; ms.Position = 0; ms.Read(bytBLOBData, 0, Convert.ToInt32(ms.Length)); dr["hinhAnh"] = bytBLOBData; dtSV.Rows.Add(dr); Chạy ứng dụng, kết quả như hình sau: [IMG]https://thanglong-aptech.com/wp-content/uploads/2010/12/dbimage_cs_02.png[/IMG] Theo vovanhai [B]Nguồn[/B]: [B][I]Chèn hình ảnh trực tiếp vào database trong C sharp(P1)[/I][/B] ___________________________________________ Học tiếng anh chuyên ngành công nghệ thông tin [/QUOTE]
Tên
Mã xác nhận
Gửi trả lời
KHOA HỌC KỸ THUẬT
Kỹ thuật - Cơ kí
Cách chèn hình ảnh trực tiếp vào database trong C Sharp (P1)
Top