ذخیره تصویر در دیتابیس vb.net

ذخیره تصویر در دیتابیس vb.net

نحوه ذخیره‌سازی فایل تصویری در پایگاه‌ داده اکسس با استفاده از VB.Net


در دنیای برنامه‌نویسی، یکی از چالش‌های رایج، ذخیره‌سازی فایل‌های تصویری در پایگاه‌ داده‌ها است. مخصوصاً زمانی که پایگاه‌ داده مورد استفاده، اکسس (Access) باشد، این موضوع بیشتر مورد توجه قرار می‌گیرد. در ادامه، به صورت کامل و جامع، روند انجام این کار با زبان برنامه‌نویسی VB.Net تشریح می‌شود. هدف اصلی، آموزش چگونگی بارگذاری یک تصویر از کاربر، تبدیل آن به قالب مناسب، و ذخیره‌سازی در پایگاه‌ داده است. همچنین، نحوه بازیابی (Read) و نمایش تصویر از دیتابیس نیز توضیح داده می‌شود.
پیش‌زمینه و مفاهیم اولیه
قبل از شروع، باید بدانید که اکسس یک پایگاه‌ داده رابطه‌ای است که به عنوان یک راهکار سبک و سریع برای پروژه‌های کوچک و متوسط شناخته می‌شود. در این پایگاه‌ داده، تصاویر معمولاً در قالب بایت‌های (byte array) ذخیره می‌شوند. بنابراین، برای ذخیره تصویر، نیاز است آن را به آرایه‌ای از بایت‌ها تبدیل کنیم. این کار، با استفاده از کلاس‌های موجود در VB.Net مانند `MemoryStream` و `BinaryReader` انجام می‌شود.
همچنین، باید توجه داشت که در طراحی جدول پایگاه‌ داده، فیلد موردنظر به عنوان نوع داده `OLE Object` یا `Long Binary Data` تعریف شده باشد تا بتواند فایل‌های تصویری بزرگ را در خود جای دهد. در این آموزش، فرض بر این است که جدول به نام `tblImages` ساخته شده است و فیلد `ImageData` از نوع بایت است.
---
ایجاد پروژه و طراحی پایگاه‌ داده
در ابتدا، باید یک پروژه وی‌بی‌نت (VB.Net) جدید در ویژوال استودیو ایجاد کنید. سپس، یک فایل اکسس جدید ساخته و جدول مورد نیاز را طراحی نمایید. برای مثال، جدول به شکل زیر است:
| ID | ImageData |

|:--:|:---------:|

| 1 | Blob |
در این جدول، `ID` کلید اصلی است و `ImageData` فیلد بایت است. پس از طراحی جدول، فایل اکسس را ذخیره کنید و مسیر آن را به خاطر بسپارید، چون در برنامه نیاز است.
---
اتصال به پایگاه‌ داده و خواندن و نوشتن داده‌ها
در کد VB.Net، باید یک اتصال به پایگاه‌ داده برقرار کنید. این کار با استفاده از کلاس `OleDbConnection` انجام می‌شود. نمونه کد پایه برای اتصال و عملیات‌های ذخیره‌سازی و بازیابی، به شرح زیر است:
vb.net  

Imports System.Data.OleDb

Imports System.IO
Public Class Form1

Dim con As New OleDbConnection("Provider=Microsoft.ACE.OLEDB.
  1. 0;Data Source=your_database_path.accdb;")


در اینجا، به جای `your_database_path.accdb`، مسیر کامل فایل اکسس خود را قرار دهید.
---
بارگذاری تصویر و تبدیل به بایت آرایه
برای ذخیره‌سازی تصویر، باید ابتدا تصویر را از فایل انتخاب کنید. این کار معمولاً با `OpenFileDialog` انجام می‌شود. پس از انتخاب تصویر، آن را به صورت بایت آرایه تبدیل می‌کنید:
vb.net  

Private Function ImageToByteArray(ByVal imagePath As String) As Byte()

Dim fileStream As New FileStream(imagePath, FileMode.Open, FileAccess.Read)

Dim binaryReader As New BinaryReader(fileStream)

Dim imageBytes As Byte() = binaryReader.ReadBytes(CType(fileStream.Length, Integer))

binaryReader.Close()

fileStream.Close()

Return imageBytes

End Function


در این تابع، مسیر فایل تصویر را می‌گیرید، و آن را به آرایه بایت تبدیل می‌کنید.
---
ذخیره تصویر در پایگاه‌ داده
حالا، با استفاده از این بایت آرایه، می‌توانید تصویر را در پایگاه‌ داده ذخیره کنید. برای این کار، یک `INSERT` ساده می‌نوی... ← ادامه مطلب در magicfile.ir
باکس دانلود (ذخیره تصویر در دیتابیس vb.net)
دانلود

پیشنهاد برای دانلود ( ذخیره تصویر در دیتابیس vb.net )

برای دانلود کردن اینجا را کلیک فرمایید

نظرات کاربران (۳)

مریم احمدی

عالی بود .. با تشکر