Skill

Database Interaction এবং Automation (ডেটাবেস ইন্টারঅ্যাকশন এবং অটোমেশন)

ভিবিএ (VBA) - Computer Programming

283

VBA তে ডেটাবেস ইন্টারঅ্যাকশন এবং অটোমেশন (Database Interaction and Automation in VBA)

VBA (Visual Basic for Applications) ব্যবহার করে আপনি এক্সেল বা অন্য অফিস অ্যাপ্লিকেশন থেকে ডেটাবেসের সাথে ইন্টারঅ্যাক্ট এবং অটোমেটেড ডেটা প্রক্রিয়াকরণ করতে পারেন। ডেটাবেস ইন্টারঅ্যাকশন আপনাকে বিভিন্ন ডেটাবেসের মধ্যে ডেটা সংগ্রহ, আপডেট, ইনসার্ট এবং ডিলিট করার ক্ষমতা দেয়, যা আপনাকে দক্ষতার সাথে ডেটা পরিচালনা করতে সহায়ক।

VBA তে ডেটাবেস ইন্টারঅ্যাকশন সাধারণত ADO (ActiveX Data Objects) বা DAO (Data Access Objects) এর মাধ্যমে সম্পন্ন করা হয়। ADO এবং DAO দুটি পদ্ধতি যা আপনাকে রিলেশনাল ডেটাবেস যেমন SQL Server, Access, বা MySQL এর সাথে সংযোগ স্থাপন এবং ডেটা অপারেশন করতে দেয়।

এখানে, আমরা ADO ব্যবহার করে ডেটাবেস ইন্টারঅ্যাকশন এবং অটোমেশন কীভাবে করা যায় তা দেখবো।


ADO (ActiveX Data Objects) এবং ডেটাবেস ইন্টারঅ্যাকশন

ADO হল একটি Data Access লাইব্রেরি যা ডেটাবেসের সাথে যোগাযোগ করতে ব্যবহৃত হয়। এটি আপনাকে SQL কমান্ড পাঠাতে, ডেটাবেস থেকে ডেটা আনতে এবং ডেটাবেসে ডেটা ইনসার্ট, আপডেট বা ডিলিট করতে সহায়ক।

ADO তে ডেটাবেসের সাথে সংযোগ (Connecting to a Database with ADO)

ADO ব্যবহার করে ডেটাবেসের সাথে সংযোগ স্থাপন করতে হলে আপনাকে Connection Object, Recordset Object, এবং Command Object ব্যবহার করতে হবে।

ADO ডেটাবেস সংযোগের উদাহরণ:
Sub ConnectToDatabase()
    Dim conn As Object
    Dim rs As Object
    Dim sql As String
    
    ' ADO Connection তৈরি
    Set conn = CreateObject("ADODB.Connection")
    conn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\path\to\your\database.accdb;"
    conn.Open
    
    ' SQL Query তৈরি
    sql = "SELECT * FROM Customers"
    
    ' SQL Query চালানো এবং ডেটা রিট্রিভ করা
    Set rs = CreateObject("ADODB.Recordset")
    rs.Open sql, conn
    
    ' ডেটা প্রদর্শন করা
    While Not rs.EOF
        Debug.Print rs.Fields("CustomerName").Value
        rs.MoveNext
    Wend
    
    ' সংযোগ বন্ধ করা
    rs.Close
    conn.Close
End Sub

এখানে, ADO ব্যবহার করে Access ডেটাবেসে সংযোগ স্থাপন করা হয়েছে, এবং Customers টেবিল থেকে সমস্ত রেকর্ড নেওয়া হয়েছে। এই রেকর্ডগুলির মধ্যে CustomerName ফিল্ডের মান Immediate Window-এ প্রদর্শিত হবে।

ADO তে SQL কমান্ড ব্যবহার (Executing SQL Commands)

ADO তে SQL কমান্ড ব্যবহার করে ডেটাবেসে INSERT, UPDATE, DELETE ইত্যাদি অপারেশন করা যেতে পারে।

উদাহরণ:

Sub InsertDataToDatabase()
    Dim conn As Object
    Dim sql As String
    
    ' ADO Connection তৈরি
    Set conn = CreateObject("ADODB.Connection")
    conn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\path\to\your\database.accdb;"
    conn.Open
    
    ' SQL Insert কমান্ড
    sql = "INSERT INTO Customers (CustomerName, ContactName, Country) VALUES ('John Doe', 'John', 'USA')"
    
    ' SQL কমান্ড এক্সিকিউট করা
    conn.Execute sql
    
    ' সংযোগ বন্ধ করা
    conn.Close
End Sub

এখানে, Customers টেবিলে একটি নতুন রেকর্ড ইনসার্ট করা হয়েছে।


DAO (Data Access Objects) তে ডেটাবেস ইন্টারঅ্যাকশন

DAO হল একটি আরেকটি ডেটাবেস অ্যাক্সেস টুল যা Access ডেটাবেসের সাথে কাজ করতে উপযুক্ত। যদিও ADO আধুনিক ডেটাবেস অ্যাক্সেসের জন্য বেশি ব্যবহৃত হয়, তবে DAO Microsoft Access ডেটাবেসের জন্য একটি কার্যকরী টুল।

DAO দিয়ে Access ডেটাবেসের সাথে কাজ করা:

Sub ConnectToAccessDatabaseDAO()
    Dim db As Object
    Dim rs As Object
    Dim sql As String
    
    ' DAO ডেটাবেস সংযোগ তৈরি
    Set db = OpenDatabase("C:\path\to\your\database.accdb")
    
    ' SQL Query তৈরি
    sql = "SELECT * FROM Customers"
    
    ' SQL Query চালানো
    Set rs = db.OpenRecordset(sql)
    
    ' রেকর্ডের মান দেখানো
    While Not rs.EOF
        Debug.Print rs!CustomerName
        rs.MoveNext
    Wend
    
    ' সংযোগ বন্ধ করা
    rs.Close
    db.Close
End Sub

এখানে, DAO ব্যবহার করে Access ডেটাবেসের Customers টেবিল থেকে ডেটা রিট্রিভ করা হয়েছে এবং CustomerName ফিল্ডের মান Immediate Window-এ প্রদর্শিত হয়েছে।


ডেটাবেস অটোমেশন (Database Automation)

VBA তে ডেটাবেস অটোমেশন ব্যবহারকারীর কাজের প্রক্রিয়া অটোমেট করতে এবং ডেটাবেসের সাথে বিভিন্ন কার্য সম্পাদন করতে ব্যবহৃত হয়। উদাহরণস্বরূপ, VBA ব্যবহার করে আপনি ডেটাবেস থেকে তথ্য এনে এক্সেল শীটে কপি করতে পারেন, বা নির্দিষ্ট সময়ে ডেটাবেসে তথ্য আপডেট করতে পারেন।

ডেটাবেস থেকে ডেটা এক্সেল শীটে কপি করা:

Sub ImportDataFromDatabase()
    Dim conn As Object
    Dim rs As Object
    Dim sql As String
    Dim i As Integer
    
    ' ADO Connection তৈরি
    Set conn = CreateObject("ADODB.Connection")
    conn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\path\to\your\database.accdb;"
    conn.Open
    
    ' SQL Query তৈরি
    sql = "SELECT * FROM Customers"
    
    ' SQL Query চালানো
    Set rs = CreateObject("ADODB.Recordset")
    rs.Open sql, conn
    
    ' ডেটাবেসের ডেটা এক্সেল শীটে কপি করা
    i = 1
    While Not rs.EOF
        Cells(i, 1).Value = rs.Fields("CustomerName").Value
        Cells(i, 2).Value = rs.Fields("ContactName").Value
        i = i + 1
        rs.MoveNext
    Wend
    
    ' সংযোগ বন্ধ করা
    rs.Close
    conn.Close
End Sub

এখানে, Customers টেবিল থেকে ডেটা রিট্রিভ করা হচ্ছে এবং এক্সেল শীটের A এবং B কলামে কপি করা হচ্ছে।


ডেটাবেস অটোমেশন এবং রিপোর্ট তৈরি

VBA ব্যবহার করে ডেটাবেস থেকে তথ্য সংগ্রহ করে স্বয়ংক্রিয়ভাবে রিপোর্ট তৈরি করা যায়। উদাহরণস্বরূপ, আপনি ডেটাবেস থেকে সমস্ত অর্ডার তথ্য এনে একটি সেল রিপোর্ট তৈরি করতে পারেন এবং সেই রিপোর্টটি প্রিন্ট বা ইমেইল করতে পারেন।

ডেটাবেস থেকে রিপোর্ট তৈরি এবং প্রিন্ট করা:

Sub GenerateAndPrintReport()
    Dim conn As Object
    Dim rs As Object
    Dim sql As String
    Dim ws As Worksheet
    Set ws = ThisWorkbook.Sheets("ReportSheet")
    
    ' ADO Connection তৈরি
    Set conn = CreateObject("ADODB.Connection")
    conn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\path\to\your\database.accdb;"
    conn.Open
    
    ' SQL Query তৈরি
    sql = "SELECT * FROM Orders"
    
    ' SQL Query চালানো
    Set rs = CreateObject("ADODB.Recordset")
    rs.Open sql, conn
    
    ' রিপোর্ট শীটে ডেটা রিট্রিভ করা
    ws.Cells(1, 1).Value = "Order ID"
    ws.Cells(1, 2).Value = "Customer Name"
    ws.Cells(1, 3).Value = "Order Date"
    
    i = 2
    While Not rs.EOF
        ws.Cells(i, 1).Value = rs.Fields("OrderID").Value
        ws.Cells(i, 2).Value = rs.Fields("CustomerName").Value
        ws.Cells(i, 3).Value = rs.Fields("OrderDate").Value
        i = i + 1
        rs.MoveNext
    Wend
    
    ' রিপোর্ট প্রিন্ট করা
    ws.PrintOut
    
    ' সংযোগ বন্ধ করা
    rs.Close
    conn.Close
End Sub

এখানে, Orders টেবিল থেকে অর্ডারের ডেট

া সংগ্রহ করা হয়েছে এবং এক্সেল শীটে প্রিন্টের জন্য প্রস্তুত করা হয়েছে।


সারসংক্ষেপ

  • ADO এবং DAO ব্যবহৃত হয় ডেটাবেসের সাথে যোগাযোগ করার জন্য। ADO তে আপনি SQL কমান্ড পাঠাতে এবং রেকর্ডস রিট্রিভ করতে পারেন।
  • ডেটাবেস অটোমেশন ব্যবহার করে আপনি ডেটাবেসে ডেটা ইনসার্ট, আপডেট, ডিলিট এবং ডেটা এক্সেল শীটে রিট্রিভ করতে পারেন।
  • VBA তে ডেটাবেস ইন্টারঅ্যাকশন এবং অটোমেশন ব্যবহার করে আপনি অনেক কাজ স্বয়ংক্রিয়ভাবে সম্পন্ন করতে পারেন, যেমন রিপোর্ট তৈরি, ডেটা প্রক্রিয়াকরণ, ফাইল এক্সপোর্ট ইত্যাদি।

VBA এর মাধ্যমে ডেটাবেসের সাথে যোগাযোগ এবং অটোমেশন কার্যকরীভাবে কাজ করতে সাহায্য করে, যা সময় সাশ্রয়ী এবং প্রক্রিয়া সহজ করে তোলে।

Content added By

Access, SQL Server, এবং অন্যান্য ডেটাবেসের সাথে ইন্টারঅ্যাকশন

VBA (Visual Basic for Applications) ব্যবহার করে আপনি Excel বা অন্যান্য Microsoft Office অ্যাপ্লিকেশন থেকে বিভিন্ন ডেটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারেন, যেমন Microsoft Access, SQL Server, এবং অন্যান্য সম্পর্কিত ডেটাবেস সিস্টেম। এটি আপনাকে ডেটা পড়া, লেখা, আপডেট এবং মুছে ফেলা করার সুযোগ দেয়, এবং এক্সেলকে আরও শক্তিশালী একটি ডেটাবেস টুলে পরিণত করে।

এই প্রক্রিয়াটি সাধারণত ADO (ActiveX Data Objects) বা DAO (Data Access Objects) লাইব্রেরি ব্যবহার করে করা হয়। ADO অধিকতর আধুনিক এবং ব্যাপকভাবে ব্যবহৃত।


1. Access Database এর সাথে ইন্টারঅ্যাকশন (Using ADO)

Microsoft Access এর ডেটাবেসের সাথে VBA ব্যবহার করে যোগাযোগ করতে আপনি ADO (ActiveX Data Objects) লাইব্রেরি ব্যবহার করবেন। ADO ব্যবহার করে আপনি Access ডেটাবেস থেকে ডেটা নিয়ে আসতে, ইনসার্ট, আপডেট এবং ডিলিট করতে পারেন।

Access ডেটাবেসে ডেটা কানেক্ট এবং কুয়েরি চালানো:

  1. ADO লাইব্রেরি সক্রিয় করা:
    • VBA এডিটর থেকে Tools > References এ যান।
    • সেখানে Microsoft ActiveX Data Objects 6.1 Library (বা অন্য ভার্সন) নির্বাচন করুন।
  2. Access ডেটাবেসে সংযোগ এবং কুয়েরি চালানো:
Sub AccessDBInteraction()
    Dim conn As Object
    Dim rs As Object
    Dim sql As String
    Dim dbPath As String
    
    ' ডেটাবেস ফাইলের পাথ
    dbPath = "C:\path\to\your\accessfile.accdb"
    
    ' ADO কানেকশন সেটআপ
    Set conn = CreateObject("ADODB.Connection")
    conn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" & dbPath
    conn.Open
    
    ' কুয়েরি চালানো
    sql = "SELECT * FROM Employees"
    Set rs = conn.Execute(sql)
    
    ' রেকর্ডস দেখানো
    Do While Not rs.EOF
        MsgBox rs.Fields("EmployeeName").Value
        rs.MoveNext
    Loop
    
    ' কানেকশন বন্ধ করা
    rs.Close
    conn.Close
End Sub

এখানে:

  • conn.ConnectionString Access ডেটাবেসের পাথে সংযোগ তৈরি করে।
  • conn.Execute কুয়েরি চালায় এবং ফলাফল নেয়।
  • rs.Fields ব্যবহার করে কুয়েরি রিটার্ন হওয়া রেকর্ড থেকে ডেটা অ্যাক্সেস করা হয়।

2. SQL Server এর সাথে ইন্টারঅ্যাকশন (Using ADO)

SQL Server এর সাথে ইন্টারঅ্যাক্ট করার জন্যও ADO ব্যবহৃত হয়, যেখানে আপনি SQL Server এর সার্ভার নাম, ডেটাবেস নাম এবং ইউজার ক্রেডেনশিয়ালস ব্যবহার করে সংযোগ তৈরি করেন।

SQL Server-এ সংযোগ এবং কুয়েরি চালানো:

Sub SQLServerInteraction()
    Dim conn As Object
    Dim rs As Object
    Dim sql As String
    Dim server As String
    Dim database As String
    
    ' SQL Server সার্ভার এবং ডেটাবেসের পাথ
    server = "your_server_name"
    database = "your_database_name"
    
    ' ADO কানেকশন সেটআপ
    Set conn = CreateObject("ADODB.Connection")
    conn.ConnectionString = "Provider=SQLOLEDB;Data Source=" & server & ";Initial Catalog=" & database & ";Integrated Security=SSPI;"
    conn.Open
    
    ' SQL কুয়েরি চালানো
    sql = "SELECT * FROM Employees"
    Set rs = conn.Execute(sql)
    
    ' রেকর্ডস দেখানো
    Do While Not rs.EOF
        MsgBox rs.Fields("EmployeeName").Value
        rs.MoveNext
    Loop
    
    ' কানেকশন বন্ধ করা
    rs.Close
    conn.Close
End Sub

এখানে:

  • conn.ConnectionString SQL Server-এ সংযোগ তৈরি করে।
  • Integrated Security=SSPI বলে যে, Windows Authentication ব্যবহার করা হবে।

3. MySQL এর সাথে ইন্টারঅ্যাকশন (Using ADO)

MySQL ডেটাবেসের সাথে সংযোগ করার জন্য ADO ব্যবহার করা যায়, তবে আপনাকে MySQL ODBC ড্রাইভার ইনস্টল করতে হবে। এরপর, আপনি ADO এর মাধ্যমে MySQL ডেটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারবেন।

MySQL ডেটাবেসে সংযোগ এবং কুয়েরি চালানো:

Sub MySQLInteraction()
    Dim conn As Object
    Dim rs As Object
    Dim sql As String
    Dim server As String
    Dim database As String
    
    ' MySQL সার্ভার এবং ডেটাবেসের পাথ
    server = "your_server_address"
    database = "your_database_name"
    
    ' ADO কানেকশন সেটআপ
    Set conn = CreateObject("ADODB.Connection")
    conn.ConnectionString = "Driver={MySQL ODBC 8.0 ANSI Driver};Server=" & server & ";Database=" & database & ";User=root;Password=your_password;"
    conn.Open
    
    ' SQL কুয়েরি চালানো
    sql = "SELECT * FROM Employees"
    Set rs = conn.Execute(sql)
    
    ' রেকর্ডস দেখানো
    Do While Not rs.EOF
        MsgBox rs.Fields("EmployeeName").Value
        rs.MoveNext
    Loop
    
    ' কানেকশন বন্ধ করা
    rs.Close
    conn.Close
End Sub

এখানে, MySQL ODBC 8.0 ANSI Driver ব্যবহার করা হয়েছে MySQL ডেটাবেসের সাথে সংযোগ করার জন্য।


4. DAO (Data Access Objects) ব্যবহার করে ডেটাবেসের সাথে ইন্টারঅ্যাকশন

VBA তে আপনি DAO (Data Access Objects) ব্যবহার করেও Access ডেটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারেন। DAO মূলত Access ডেটাবেসের সাথে কাজ করতে উন্নত কিন্তু ADO এর তুলনায় অনেকটা পুরনো প্রযুক্তি। তবে, যদি আপনি পুরনো VBA অ্যাপ্লিকেশনগুলোর সাথে কাজ করেন, তবে DAO ব্যবহার করার প্রয়োজন হতে পারে।

DAO ব্যবহার করে Access ডেটাবেসে কুয়েরি চালানো:

Sub DAOExample()
    Dim db As Object
    Dim rs As Object
    Dim sql As String
    
    ' Access ডেটাবেসের পাথ
    Set db = OpenDatabase("C:\path\to\your\accessfile.accdb")
    
    ' SQL কুয়েরি
    sql = "SELECT * FROM Employees"
    Set rs = db.OpenRecordset(sql)
    
    ' রেকর্ডস দেখানো
    Do While Not rs.EOF
        MsgBox rs.Fields("EmployeeName").Value
        rs.MoveNext
    Loop
    
    ' রেকর্ডস এবং ডেটাবেস বন্ধ করা
    rs.Close
    db.Close
End Sub

এখানে, DAO ব্যবহৃত হচ্ছে Access ডেটাবেস থেকে ডেটা এক্সেস করতে।


5. ডেটা ম্যানিপুলেশন এবং ইভেন্ট হ্যান্ডলিং

আপনি ডেটাবেস থেকে ডেটা পড়া, আপডেট, ইনসার্ট বা ডিলিট করার পাশাপাশি, VBA এর মাধ্যমে ডেটাবেস ইভেন্ট যেমন BeforeUpdate, AfterUpdate ইত্যাদি হ্যান্ডল করতে পারেন।

Data Manipulation Example (Insert, Update, Delete)

Sub InsertRecord()
    Dim conn As Object
    Dim sql As String
    Set conn = CreateObject("ADODB.Connection")
    conn.ConnectionString = "Provider=SQLOLEDB;Data Source=your_server_name;Initial Catalog=your_db_name;Integrated Security=SSPI;"
    conn.Open
    
    ' Insert Query
    sql = "INSERT INTO Employees (EmployeeName, Age) VALUES ('John Doe', 30)"
    conn.Execute sql
    
    conn.Close
End Sub

এখানে, Insert কুয়েরি ব্যবহার করা হয়েছে একটি নতুন রেকর্ড ডেটাবেসে যোগ করার জন্য।


উপসংহার

VBA দিয়ে আপনি Access, SQL Server, MySQL এবং অন্যান্য ডেটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারেন। আপনি ADO এবং DAO এর মাধ্যমে ডেটা এক্সেস, কুয়েরি চালানো, রেকর্ড পড়া, ইনসার্ট করা এবং আপডেট করতে পারেন। এর মাধ্যমে Excel বা অন্যান্য Office অ্যাপ্লিকেশনে ডেটাবেসের সাথে কাজ করা সহজ হয়ে যায় এবং স্বয়ংক্রিয়ভাবে ডেটা ম্যানিপুলেশন করা যায়।

Content added By

ADO (ActiveX Data Objects) হল একটি শক্তিশালী টুল যা VBA (Visual Basic for Applications)-এ ডেটাবেসের সাথে ইন্টারঅ্যাক্ট করতে ব্যবহৃত হয়। ADO এর মাধ্যমে আপনি SQL Server, Access, Excel, MySQL বা অন্য যেকোনো ODBC বা OLE DB সাপোর্টিং ডেটাবেসের সাথে সংযুক্ত হতে এবং ডেটা ম্যানিপুলেট করতে পারবেন। ADO ডেটাবেসের সাথে যোগাযোগ করার জন্য সহজ একটি API সরবরাহ করে যা ব্যবহারকারীকে ডেটা রিট্রিভ (Retrieve), আপডেট, ডিলিট এবং ইনসার্ট করার সুবিধা প্রদান করে।

এখানে, আমরা ADO ব্যবহার করে ডেটা ম্যানিপুলেশন, যেমন ডেটা রিট্রিভাল, ইনসার্ট, আপডেট, এবং ডিলিট করার পদ্ধতিগুলি দেখাবো।


ADO ব্যবহার শুরু করা

ADO ব্যবহার করার জন্য প্রথমে Microsoft ActiveX Data Objects Library রেফারেন্স যোগ করতে হবে:

  1. VBA এ Tools মেনু থেকে References অপশন নির্বাচন করুন।
  2. "Microsoft ActiveX Data Objects 6.1 Library" (বা আপনার সিস্টেমের অনুযায়ী অন্য সংস্করণ) চেক করুন।
  3. OK ক্লিক করুন।

এখন, আপনি ADO এর ফাংশনালিটি ব্যবহার করতে প্রস্তুত।


ADO এর মূল উপাদানগুলি

  1. Connection Object: ডেটাবেসের সাথে সংযোগ স্থাপন করতে ব্যবহৃত হয়।
  2. Recordset Object: ডেটা রিট্রিভ এবং ম্যানিপুলেট করতে ব্যবহৃত হয়।
  3. Command Object: SQL কোয়েরি এক্সিকিউট করতে ব্যবহৃত হয়।
  4. Parameter Object: SQL স্টেটমেন্টে প্যারামিটার ব্যবহার করতে ব্যবহৃত হয়।

ADO দিয়ে ডেটাবেস সংযোগ স্থাপন

  1. Connection Object তৈরি করতে:

    Dim conn As Object
    Set conn = CreateObject("ADODB.Connection")
    
    ' ডেটাবেসের সাথে সংযোগ তৈরি করা
    conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\path\to\your\database.mdb"

এখানে, conn অবজেক্টে Open মেথড ব্যবহার করে একটি Access ডেটাবেসের সাথে সংযোগ স্থাপন করা হয়েছে।


ADO দিয়ে ডেটা রিট্রিভাল (Retrieving Data)

ডেটাবেস থেকে ডেটা রিট্রিভ করার জন্য, Recordset Object ব্যবহার করা হয়। নিচে একটি উদাহরণ দেখানো হলো যেখানে SELECT SQL স্টেটমেন্ট ব্যবহার করে ডেটা রিট্রিভ করা হচ্ছে।

Sub RetrieveData()
    Dim conn As Object
    Dim rs As Object
    Dim sql As String
    
    ' Connection তৈরি করা
    Set conn = CreateObject("ADODB.Connection")
    conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\path\to\your\database.mdb"
    
    ' SQL স্টেটমেন্ট সেট করা
    sql = "SELECT * FROM Customers"
    
    ' Recordset তৈরি করা এবং SQL Query চালানো
    Set rs = CreateObject("ADODB.Recordset")
    rs.Open sql, conn
    
    ' ডেটা পড়া এবং প্রদর্শন করা
    Do Until rs.EOF
        MsgBox rs.Fields("CustomerName").Value  ' CustomerName ফিল্ডের মান দেখানো
        rs.MoveNext
    Loop
    
    ' রিসোর্স বন্ধ করা
    rs.Close
    conn.Close
End Sub

এখানে, SELECT * FROM Customers SQL স্টেটমেন্ট ব্যবহার করা হয়েছে এবং Recordset এর মাধ্যমে ডেটা রিট্রিভ করা হয়েছে। rs.Fields("CustomerName").Value দিয়ে CustomerName ফিল্ডের মান পড়া হচ্ছে।


ADO দিয়ে ডেটা ইনসার্ট (Inserting Data)

ডেটাবেসে নতুন রেকর্ড ইনসার্ট করার জন্য INSERT INTO SQL স্টেটমেন্ট ব্যবহার করা হয়।

Sub InsertData()
    Dim conn As Object
    Dim sql As String
    
    ' Connection তৈরি করা
    Set conn = CreateObject("ADODB.Connection")
    conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\path\to\your\database.mdb"
    
    ' SQL ইনসার্ট স্টেটমেন্ট তৈরি করা
    sql = "INSERT INTO Customers (CustomerName, ContactName, Country) VALUES ('John Doe', 'John', 'USA')"
    
    ' SQL স্টেটমেন্ট চালানো
    conn.Execute sql
    
    ' রিসোর্স বন্ধ করা
    conn.Close
End Sub

এখানে, INSERT INTO SQL স্টেটমেন্ট ব্যবহার করে Customers টেবিলে একটি নতুন রেকর্ড যোগ করা হচ্ছে। conn.Execute sql এর মাধ্যমে SQL স্টেটমেন্টটি এক্সিকিউট করা হচ্ছে।


ADO দিয়ে ডেটা আপডেট (Updating Data)

ডেটাবেসের কোনো রেকর্ড আপডেট করতে UPDATE SQL স্টেটমেন্ট ব্যবহার করা হয়।

Sub UpdateData()
    Dim conn As Object
    Dim sql As String
    
    ' Connection তৈরি করা
    Set conn = CreateObject("ADODB.Connection")
    conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\path\to\your\database.mdb"
    
    ' SQL আপডেট স্টেটমেন্ট তৈরি করা
    sql = "UPDATE Customers SET ContactName = 'Jane Doe' WHERE CustomerName = 'John Doe'"
    
    ' SQL স্টেটমেন্ট চালানো
    conn.Execute sql
    
    ' রিসোর্স বন্ধ করা
    conn.Close
End Sub

এখানে, UPDATE SQL স্টেটমেন্ট ব্যবহার করে Customers টেবিলের CustomerName এর মান John Doe থেকে Jane Doe এ পরিবর্তন করা হয়েছে।


ADO দিয়ে ডেটা ডিলিট (Deleting Data)

ডেটাবেস থেকে কোনো রেকর্ড মুছে ফেলতে DELETE SQL স্টেটমেন্ট ব্যবহার করা হয়।

Sub DeleteData()
    Dim conn As Object
    Dim sql As String
    
    ' Connection তৈরি করা
    Set conn = CreateObject("ADODB.Connection")
    conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\path\to\your\database.mdb"
    
    ' SQL ডিলিট স্টেটমেন্ট তৈরি করা
    sql = "DELETE FROM Customers WHERE CustomerName = 'John Doe'"
    
    ' SQL স্টেটমেন্ট চালানো
    conn.Execute sql
    
    ' রিসোর্স বন্ধ করা
    conn.Close
End Sub

এখানে, DELETE SQL স্টেটমেন্ট ব্যবহার করে Customers টেবিল থেকে CustomerName এর মান John Doe এর রেকর্ড মুছে ফেলা হয়েছে।


ADO দিয়ে প্যারামিটারাইজড কুয়েরি (Parameterized Query)

ADO-তে Parameter অবজেক্ট ব্যবহার করে SQL কুয়েরিতে প্যারামিটার ব্যবহার করা যায়। এর মাধ্যমে SQL ইনজেকশন থেকে রক্ষা পাওয়া যায় এবং কোডের নিরাপত্তা বাড়ে।

Sub InsertWithParameter()
    Dim conn As Object
    Dim cmd As Object
    Dim sql As String
    
    ' Connection তৈরি করা
    Set conn = CreateObject("ADODB.Connection")
    conn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\path\to\your\database.mdb"
    
    ' Command Object তৈরি করা
    Set cmd = CreateObject("ADODB.Command")
    cmd.ActiveConnection = conn
    cmd.CommandText = "INSERT INTO Customers (CustomerName, ContactName, Country) VALUES (?, ?, ?)"
    
    ' Parameters যোগ করা
    cmd.Parameters.Append cmd.CreateParameter(, 8, 1, 255, "John Doe")  ' CustomerName
    cmd.Parameters.Append cmd.CreateParameter(, 8, 1, 255, "John")  ' ContactName
    cmd.Parameters.Append cmd.CreateParameter(, 8, 1, 255, "USA")  ' Country
    
    ' Execute করা
    cmd.Execute
    
    ' রিসোর্স বন্ধ করা
    conn.Close
End Sub

এখানে, CreateParameter মেথড ব্যবহার করে প্যারামিটারযুক্ত কুয়েরি তৈরি করা হয়েছে এবং SQL ইনজেকশন রোধ করা হয়েছে।


উপসংহার

  • ADO ব্যবহার করে আপনি Connection Object, Recordset Object, Command Object ইত্যাদি ব্যবহার করে ডেটাবেসের সাথে ইন্টারঅ্যাক্ট করতে পারেন।
  • ADO দিয়ে SELECT, INSERT, UPDATE, DELETE SQL স্টেটমেন্টগুলো কার্যকর করতে পারেন।
  • Parameterized Queries ব্যবহারের মাধ্যমে আপনি SQL ইনজেকশন রোধ করতে পারেন এবং কোডের নিরাপত্তা বৃদ্ধি করতে পারেন।

ADO ব্যবহার করে ডেটাবেসে ডেটা ম্যানিপুলেট করার মাধ্যমে আপনি এক্সেল বা অন্য ডেটাবেস সিস্টেমের সাথে আরও ইফেক্টিভ

লি কাজ করতে পারেন।

Content added By

SQL Queries এবং Data Filtering

SQL (Structured Query Language) হলো একটি প্রোগ্রামিং ভাষা যা ডেটাবেস পরিচালনা এবং তথ্যের সাথে কাজ করার জন্য ব্যবহৃত হয়। SQL তে queries ব্যবহার করে আপনি ডেটাবেস থেকে তথ্য নির্বাচন, যোগ, আপডেট এবং মুছে ফেলতে পারেন। Data Filtering হলো একটি প্রক্রিয়া যেখানে আপনি নির্দিষ্ট শর্ত পূরণ করা ডেটা বের করার জন্য SQL কুয়েরি ব্যবহার করেন।

এখানে SQL Queries এবং Data Filtering সম্পর্কে বিস্তারিত আলোচনা করা হলো।


1. SQL Queries

SQL কুয়েরি বা প্রশ্ন হলো এমন একটি কমান্ড যা ডেটাবেস থেকে তথ্য নির্বাচন বা ম্যানিপুলেট করার জন্য ব্যবহৃত হয়। SQL কুয়েরি সাধারণত বিভিন্ন ধরনের কমান্ডের মাধ্যমে তৈরি করা হয়, যেমন SELECT, INSERT, UPDATE, DELETE ইত্যাদি।

SELECT Query

SELECT কুয়েরি ব্যবহার করে আপনি একটি ডেটাবেস থেকে তথ্য নির্বাচন করতে পারেন।

SELECT column1, column2, ...
FROM table_name;

এখানে:

  • column1, column2,...: সেগুলি হল সেলেক্ট করতে চাওয়া কলামসমূহ।
  • table_name: ডেটা যেখানে সঞ্চিত থাকে সেই টেবিলের নাম।

উদাহরণ:

SELECT first_name, last_name FROM employees;

এই কুয়েরি employees টেবিল থেকে first_name এবং last_name কলামগুলোকে নির্বাচন করবে।

WHERE Clause

WHERE ক্লজ ব্যবহার করে আপনি নির্দিষ্ট শর্তের ভিত্তিতে ডেটা ফিল্টার করতে পারেন।

SELECT column1, column2
FROM table_name
WHERE condition;

উদাহরণ:

SELECT first_name, last_name
FROM employees
WHERE department = 'Sales';

এখানে:

  • এই কুয়েরি employees টেবিল থেকে department কলামের মান 'Sales' যেখানে, সেই রেকর্ডগুলোকে নির্বাচন করবে।

2. Data Filtering (ডেটা ফিল্টারিং)

Data Filtering হলো ডেটাবেস থেকে নির্দিষ্ট শর্তের উপর ভিত্তি করে ডেটা বের করা। SQL তে বিভিন্ন ফিল্টারিং অপশন রয়েছে যা আপনাকে ডেটা খুব সহজে সিলেক্ট করতে সহায়ক হয়।

WHERE Clause

WHERE ক্লজ ডেটা ফিল্টার করার প্রধান উপায়। এটি সুনির্দিষ্ট শর্ত (condition) অনুযায়ী ডেটা নির্বাচন করতে ব্যবহৃত হয়।

SELECT column1, column2
FROM table_name
WHERE column1 = 'value';

উদাহরণ:

SELECT first_name, last_name
FROM employees
WHERE age > 30;

এই কুয়েরি employees টেবিল থেকে এমন সব রেকর্ড নির্বাচন করবে যেখানে age ৩০ এর বেশি।

AND, OR Operators

একাধিক শর্ত একসাথে ব্যবহারের জন্য AND এবং OR অপারেটর ব্যবহার করা হয়।

AND অপারেটর: সব শর্ত সত্য হলে তথ্য নির্বাচিত হবে।

SELECT column1, column2
FROM table_name
WHERE condition1 AND condition2;

OR অপারেটর: যেকোনো একটি শর্ত সত্য হলে তথ্য নির্বাচিত হবে।

SELECT column1, column2
FROM table_name
WHERE condition1 OR condition2;

উদাহরণ (AND):

SELECT first_name, last_name
FROM employees
WHERE department = 'Sales' AND age > 30;

এই কুয়েরি employees টেবিল থেকে এমন রেকর্ডগুলো নির্বাচন করবে যেখানে department 'Sales' এবং age ৩০ এর বেশি।

উদাহরণ (OR):

SELECT first_name, last_name
FROM employees
WHERE department = 'Sales' OR department = 'Marketing';

এই কুয়েরি employees টেবিল থেকে এমন রেকর্ডগুলো নির্বাচন করবে যেখানে department 'Sales' অথবা 'Marketing'।

BETWEEN Operator

BETWEEN অপারেটর ব্যবহার করে একটি রেঞ্জের মধ্যে থাকা ডেটা নির্বাচন করা যায়।

SELECT column1, column2
FROM table_name
WHERE column1 BETWEEN value1 AND value2;

উদাহরণ:

SELECT first_name, last_name
FROM employees
WHERE age BETWEEN 30 AND 40;

এই কুয়েরি employees টেবিল থেকে এমন সব রেকর্ড নির্বাচন করবে যেখানে age ৩০ এবং ৪০ এর মধ্যে।

IN Operator

IN অপারেটর ব্যবহার করে নির্দিষ্ট মানগুলির মধ্যে থাকা রেকর্ড নির্বাচন করা যায়।

SELECT column1, column2
FROM table_name
WHERE column1 IN (value1, value2, value3, ...);

উদাহরণ:

SELECT first_name, last_name
FROM employees
WHERE department IN ('Sales', 'Marketing', 'HR');

এই কুয়েরি employees টেবিল থেকে এমন সব রেকর্ড নির্বাচন করবে যেখানে department 'Sales', 'Marketing', অথবা 'HR'।

LIKE Operator

LIKE অপারেটর ব্যবহার করে আপনি প্যাটার্ন অনুসন্ধান করতে পারেন, বিশেষ করে যখন আপনি টেক্সট ফিল্টার করছেন।

SELECT column1, column2
FROM table_name
WHERE column1 LIKE pattern;

উদাহরণ:

SELECT first_name, last_name
FROM employees
WHERE first_name LIKE 'J%';

এটি employees টেবিল থেকে এমন রেকর্ড নির্বাচন করবে যেখানে first_name 'J' দিয়ে শুরু হয় (যেমন: 'John', 'Jack' ইত্যাদি)।


3. SQL Query Example with Multiple Filters

SELECT first_name, last_name, department, age
FROM employees
WHERE department = 'Sales' 
AND age BETWEEN 25 AND 40
AND first_name LIKE 'J%'
ORDER BY last_name;

এখানে:

  • department = 'Sales': শুধুমাত্র 'Sales' বিভাগের কর্মচারীদের নির্বাচন করা।
  • age BETWEEN 25 AND 40: বয়স ২৫ থেকে ৪০ এর মধ্যে।
  • first_name LIKE 'J%': প্রথম নাম 'J' দিয়ে শুরু।
  • ORDER BY last_name: আউটপুটকে last_name এর ভিত্তিতে সাজানো।

4. ORDER BY এবং LIMIT

ORDER BY এবং LIMIT ব্যবহার করে আপনি ডেটা সাজাতে এবং সীমিত সংখ্যক রেকর্ড দেখতে পারেন।

ORDER BY (ডেটা সাজানো):

SELECT column1, column2
FROM table_name
ORDER BY column1 [ASC|DESC];

ASC (Ascending) হলো ছোট থেকে বড় এবং DESC (Descending) হলো বড় থেকে ছোট।

উদাহরণ:

SELECT first_name, last_name, age
FROM employees
ORDER BY age DESC;

এটি employees টেবিল থেকে সকল কর্মচারীর নাম এবং বয়স দেখাবে, এবং age এর ভিত্তিতে উল্টো (DESC) সাজাবে।

LIMIT (ফলাফল সীমাবদ্ধ করা):

SELECT column1, column2
FROM table_name
LIMIT 5;

উদাহরণ:

SELECT first_name, last_name
FROM employees
LIMIT 10;

এটি employees টেবিল থেকে প্রথম ১০টি রেকর্ড দেখাবে।


উপসংহার

SQL তে Data Filtering আপনাকে ডেটাবেস থেকে নির্দিষ্ট শর্ত অনুসারে তথ্য নির্বাচিত করতে সাহায্য করে। WHERE ক্লজ, AND, OR, BETWEEN, IN, এবং LIKE অপারেটরের মাধ্যমে আপনি আপনার অনুসন্ধান আরও সুনির্দিষ্ট করতে পারেন। ORDER BY এবং LIMIT ব্যবহার করে আপনি ডেটাকে সাজাতে এবং ফলাফল সীমাবদ্ধ করতে পারেন।

Content added By

VBA তে ডেটাবেসের সাথে অটোমেশন

VBA (Visual Basic for Applications) ব্যবহার করে আপনি বিভিন্ন ডেটাবেস, যেমন Microsoft Access, SQL Server, MySQL, এবং Excel এর মধ্যে ডেটা স্থানান্তর, আপডেট, এবং ম্যানিপুলেশন অটোমেট করতে পারেন। এটি বিশেষভাবে উপকারী যখন আপনি বড় আকারের ডেটাবেসের সাথে কাজ করছেন এবং আপনাকে ম্যানুয়ালি কাজ করতে হবে না। VBA তে ডেটাবেসের সাথে অটোমেশন সাধারণত ADO (ActiveX Data Objects) অথবা DAO (Data Access Objects) ব্যবহার করে করা হয়।

ADO (ActiveX Data Objects) ব্যবহার করে ডেটাবেস অটোমেশন

ADO হল একটি শক্তিশালী টুল যা VBA এর মাধ্যমে ডেটাবেসের সাথে ইন্টারঅ্যাক্ট করতে সাহায্য করে। ADO দিয়ে আপনি ডেটাবেসের সাথে কানেক্ট করতে পারেন, ডেটা ক্যোয়ারি করতে পারেন, এবং ডেটা ইনসার্ট বা আপডেট করতে পারেন। নিচে ADO ব্যবহার করে ডেটাবেসে কিভাবে অটোমেশন করা যায় তা বিস্তারিত আলোচনা করা হলো।


ADO দিয়ে SQL Server বা Access Database এর সাথে কানেক্ট করা

1. ADO এর সাথে ডেটাবেস কানেক্ট করতে:

ADO ব্যবহার করে SQL Server বা Access ডেটাবেসের সাথে কানেক্ট করতে, প্রথমে আপনাকে একটি Connection তৈরি করতে হবে। এটির জন্য Microsoft ActiveX Data Objects Library রেফারেন্স যোগ করা আবশ্যক।

Steps to Add ADO Reference:

  1. VBA এডিটরে (Alt + F11) যান।
  2. Tools মেনু থেকে References নির্বাচন করুন।
  3. Microsoft ActiveX Data Objects 6.1 Library অথবা কোনো উপলব্ধ ADO লাইব্রেরি সিলেক্ট করুন এবং OK ক্লিক করুন।

এখন, আপনি ADO এর মাধ্যমে ডেটাবেসের সাথে কানেক্ট করতে পারবেন।

2. SQL Server বা Access ডেটাবেসে কানেক্ট করা:

Sub ConnectToDatabase()
    Dim conn As Object
    Dim rs As Object
    Dim sqlQuery As String

    ' ADO Connection Object তৈরি
    Set conn = CreateObject("ADODB.Connection")

    ' ডেটাবেস কানেকশন স্ট্রিং সেট করুন (Access এর উদাহরণ)
    conn.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\path\to\your\database.mdb"
    
    ' কানেকশন ওপেন করুন
    conn.Open

    ' SQL ক্যোয়ারি তৈরি
    sqlQuery = "SELECT * FROM Customers"

    ' রেকর্ডসেট তৈরি এবং SQL ক্যোয়ারি চালান
    Set rs = CreateObject("ADODB.Recordset")
    rs.Open sqlQuery, conn

    ' রেকর্ডসেটের প্রথম রেকর্ডটি দেখান
    If Not rs.EOF Then
        MsgBox "First Customer: " & rs.Fields("CustomerName").Value
    End If

    ' কানেকশন বন্ধ করুন
    rs.Close
    conn.Close

    ' অবজেক্ট গুলি ক্লিনআপ করুন
    Set rs = Nothing
    Set conn = Nothing
End Sub

এখানে:

  • conn.ConnectionString: Access ডেটাবেসের জন্য কানেকশন স্ট্রিং দেয়া হয়েছে। SQL Server এর জন্য এটি ভিন্ন হবে।
  • rs.Open: SQL ক্যোয়ারি চালানোর জন্য।
  • EOF: যখন রেকর্ডসেটের শেষ রেকর্ডে পৌঁছানো হয় তখন এটি TRUE হয়।

ADO দিয়ে ডেটাবেসে ডেটা ইনসার্ট, আপডেট এবং ডিলিট করা

3. ডেটাবেসে ডেটা ইনসার্ট করা

Sub InsertData()
    Dim conn As Object
    Dim sqlQuery As String

    ' ADO Connection Object তৈরি
    Set conn = CreateObject("ADODB.Connection")

    ' ডেটাবেস কানেকশন স্ট্রিং সেট করুন
    conn.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\path\to\your\database.mdb"
    conn.Open

    ' SQL ইনসার্ট ক্যোয়ারি
    sqlQuery = "INSERT INTO Customers (CustomerName, ContactName) VALUES ('John Doe', 'john@example.com')"

    ' SQL ক্যোয়ারি চালান
    conn.Execute sqlQuery

    ' কানেকশন বন্ধ করুন
    conn.Close
    Set conn = Nothing

    MsgBox "Data Inserted Successfully"
End Sub

এখানে Execute মেথড ব্যবহার করে INSERT INTO SQL ক্যোয়ারি চালানো হয়েছে।

4. ডেটাবেসে ডেটা আপডেট করা

Sub UpdateData()
    Dim conn As Object
    Dim sqlQuery As String

    ' ADO Connection Object তৈরি
    Set conn = CreateObject("ADODB.Connection")

    ' ডেটাবেস কানেকশন স্ট্রিং সেট করুন
    conn.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\path\to\your\database.mdb"
    conn.Open

    ' SQL আপডেট ক্যোয়ারি
    sqlQuery = "UPDATE Customers SET ContactName = 'Jane Doe' WHERE CustomerName = 'John Doe'"

    ' SQL ক্যোয়ারি চালান
    conn.Execute sqlQuery

    ' কানেকশন বন্ধ করুন
    conn.Close
    Set conn = Nothing

    MsgBox "Data Updated Successfully"
End Sub

এখানে, UPDATE ক্যোয়ারি ব্যবহার করে ডেটাবেসের ডেটা আপডেট করা হয়েছে।

5. ডেটাবেস থেকে ডেটা মুছে ফেলা

Sub DeleteData()
    Dim conn As Object
    Dim sqlQuery As String

    ' ADO Connection Object তৈরি
    Set conn = CreateObject("ADODB.Connection")

    ' ডেটাবেস কানেকশন স্ট্রিং সেট করুন
    conn.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\path\to\your\database.mdb"
    conn.Open

    ' SQL ডিলিট ক্যোয়ারি
    sqlQuery = "DELETE FROM Customers WHERE CustomerName = 'John Doe'"

    ' SQL ক্যোয়ারি চালান
    conn.Execute sqlQuery

    ' কানেকশন বন্ধ করুন
    conn.Close
    Set conn = Nothing

    MsgBox "Data Deleted Successfully"
End Sub

এখানে DELETE ক্যোয়ারি ব্যবহার করে ডেটাবেস থেকে ডেটা মুছে ফেলা হয়েছে।


DAO (Data Access Objects) ব্যবহার করে ডেটাবেস অটোমেশন

DAO (Data Access Objects) হল Access ডেটাবেসের জন্য বিশেষভাবে তৈরি একটি টুল। যদিও ADO বহুলভাবে ব্যবহৃত হয়, তবে DAO দিয়ে আপনি Access ডেটাবেসের সাথে কাজ করতে পারেন। DAO সাধারণত Access ডেটাবেসের জন্য ব্যবহৃত হয়, এবং এটি কোডের মধ্যে ভালো পারফরম্যান্স প্রদান করে।

DAO দিয়ে Access Database এ ডেটা পড়া:

Sub ReadDataWithDAO()
    Dim db As Object
    Dim rs As Object
    Dim sqlQuery As String

    ' DAO ডাটাবেস কানেকশন তৈরি
    Set db = CreateObject("DAO.DBEngine.120").OpenDatabase("C:\path\to\your\database.mdb")

    ' SQL ক্যোয়ারি তৈরি
    sqlQuery = "SELECT * FROM Customers"

    ' রেকর্ডসেট তৈরি এবং SQL ক্যোয়ারি চালানো
    Set rs = db.OpenRecordset(sqlQuery)

    ' রেকর্ডের প্রথম মান প্রদর্শন
    If Not rs.EOF Then
        MsgBox "Customer: " & rs.Fields("CustomerName").Value
    End If

    ' রেকর্ডসেট বন্ধ করা
    rs.Close
    db.Close
    Set rs = Nothing
    Set db = Nothing
End Sub

সারসংক্ষেপ

  • VBA ব্যবহার করে ডেটাবেস অটোমেশন করার জন্য আপনি ADO বা DAO ব্যবহার করতে পারেন।
  • ADO বহুলভাবে ব্যবহৃত হয় এবং SQL Server, MySQL, Access ইত্যাদি ডেটাবেসের সাথে কাজ করতে পারে।
  • DAO সাধারণত Microsoft Access ডেটাবেসের সাথে কাজ করতে ব্যবহৃত হয় এবং এটি Access-এ বেশি কার্যকরী।
  • VBA ব্যবহার করে আপনি SQL Queries চালাতে পারেন, ডেটা Insert, Update, Delete করতে পারেন এবং ডেটাবেস থেকে ডেটা পড়তে পারেন।

এগুলি আপনাকে আপনার ডেটাবেসের সাথে VBA ব্যবহার করে অটোমেটেডভাবে কাজ করার সুযোগ প্রদান করবে।

Content added By
Promotion

Are you sure to start over?

Loading...