لینک کردن جداول Access به SQLServer آموزش کامل و بهینه سازی

لینک کردن جداول اکسس به SQLServer: راهنمای جامع اتصال و بهینه‌سازی

مایکروسافت اکسس به عنوان یک ابزار قدرتمند برای مدیریت پایگاه داده‌های کوچک تا متوسط شناخته می‌شود، اما زمانی که نیاز به مقیاس‌پذیری بیشتر، امنیت بالاتر و عملکرد بهتر باشد، اتصال آن به یک بک‌اند (Backend) قدرتمند مانند SQL Server یک راهکار ایده‌آل است. لینک کردن جداول Access به SQLServer به کاربران امکان می‌دهد تا از رابط کاربری و قابلیت‌های فرم‌سازی Access استفاده کنند، در حالی که داده‌ها به صورت مرکزی و امن در SQL Server ذخیره و مدیریت می‌شوند. این رویکرد به ویژه برای برنامه‌های کاربردی دسکتاپ که نیاز به مدیریت داده‌های چند کاربره و حجم بالا دارند، مفید است.

چرا جداول اکسس را به SQL Server لینک کنیم؟

انتقال یا لینک کردن جداول از Access به SQL Server مزایای متعددی دارد:

مقیاس‌پذیری و عملکرد: SQL Server برای مدیریت حجم عظیمی از داده‌ها و تعداد زیاد کاربران همزمان طراحی شده است، که بهبود قابل توجهی در عملکرد و پاسخگویی برنامه شما ایجاد می‌کند.
امنیت پیشرفته: SQL Server قابلیت‌های امنیتی بسیار پیشرفته‌ای مانند رمزگذاری داده‌ها، مجوزهای دقیق کاربران و audit trail را ارائه می‌دهد.
قابلیت اطمینان و بازیابی: ویژگی‌های قوی SQL Server برای پشتیبان‌گیری، بازیابی و High Availability (در دسترس بودن بالا) از داده‌های شما در برابر از دست رفتن محافظت می‌کند.
یکپارچگی داده‌ها: SQL Server ابزارهای پیشرفته‌ای برای اطمینان از یکپارچگی داده‌ها (مانند کلیدهای اصلی و خارجی، محدودیت‌ها و تریگرها) ارائه می‌دهد.
دسترسی چند کاربره: چندین کاربر می‌توانند به طور همزمان و بدون مشکل به داده‌ها دسترسی داشته باشند و آنها را ویرایش کنند.

اکسس به شما امکان می‌دهد تا به راحتی جداول را به SQL Server لینک کنید و ده‌ها جدول موجود در پایگاه داده اکسس خود را به جداول موجود در SQL Server متصل کنید. این کار به شما امکان می‌دهد تا فرم‌ها، گزارش‌ها و کوئری‌های موجود خود را همچنان در اکسس نگه دارید، اما داده‌ها از SQL Server خوانده و نوشته شوند.

روش‌های لینک کردن جداول به SQL Server

چندین روش برای لینک کردن جداول اکسس به SQL Server وجود دارد که شامل استفاده از رابط کاربری اکسس (UI) و برنامه‌نویسی با VBA می‌شود.

 1. استفاده از رابط کاربری اکسس (UI)

ساده‌ترین روش برای لینک کردن جداول، استفاده از ابزارهای داخلی اکسس است.

الف) ابزار Linked Table Manager (مدیریت جداول لینک شده)

این ابزار برای مدیریت لینک‌های موجود استفاده می‌شود، اما برای ایجاد لینک‌های جدید نیز کاربرد دارد:

1. فایل Access خود را باز کنید.
2. به تب “External Data” بروید.
3. در گروه “Import & Link”، روی “Linked Table Manager” کلیک کنید.
4. در پنجره باز شده، تیک “Always prompt for new location” را بزنید.
5. روی “Check All” یا “Select All” کلیک کنید و سپس “OK” را بزنید.
6. یک پنجره مرورگر ظاهر می‌شود که از شما می‌خواهد مکان جدید جداول لینک شده را مشخص کنید. اینجاست که شما باید به منبع داده SQL Server اشاره کنید.

ب) لینک کردن جداول جدید از طریق ODBC

این روش برای ایجاد لینک‌های جدید از ابتدا استفاده می‌شود:

1. فایل Access خود را باز کنید.
2. به تب “External Data” بروید.
3. در گروه “Import & Link”، روی “ODBC Database” کلیک کنید.
4. در پنجره “Get External Data”، گزینه “Link to the data source by creating a linked table” را انتخاب کنید و “OK” را بزنید.
5. در پنجره “Select Data Source”، تب “Machine Data Source” یا “File Data Source” را انتخاب کنید.
* اگر DSN (Data Source Name) از قبل تنظیم شده دارید، آن را انتخاب کنید.
* اگر DSN ندارید یا می‌خواهید یک اتصال DSN-less ایجاد کنید، روی “New…” کلیک کنید و “SQL Server” را به عنوان درایور خود انتخاب کنید.
6. تنظیمات اتصال SQL Server را وارد کنید (نام سرور، اعتبارنامه، پایگاه داده).
7. پس از موفقیت‌آمیز بودن اتصال، لیستی از جداول موجود در SQL Server ظاهر می‌شود. جداولی را که می‌خواهید لینک کنید انتخاب کرده و “OK” را بزنید.

 2. لینک کردن جداول با استفاده از کد VBA

لینک کردن جداول به صورت برنامه‌نویسی با VBA به شما انعطاف‌پذیری بیشتری می‌دهد و برای اتوماسیون فرآیند لینک کردن چندین جدول یا برنامه‌هایی که نیاز به تغییر پویا منبع داده دارند، بسیار مفید است.

الف) لینک کردن یک جدول خاص

این مثال نشان می‌دهد که چگونه یک جدول خاص را با استفاده از DSN-less connection string لینک کنید. قبل از اجرای این کد، رشته اتصال و نام جدول را مطابق با محیط خود تغییر دهید.


Sub LinkSingleTable()
    Dim db As DAO.Database
    Dim tdf As DAO.TableDef
    Dim strConnect As String
    Dim strTable As String
    
    Set db = CurrentDb
    strTable = "YourSQLServerTable" ' نام جدول در SQL Server
    
    ' رشته اتصال DSN-less. پارامترهای سرور، پایگاه داده و اعتبارنامه‌ها را تغییر دهید.
    strConnect = "ODBC;DRIVER={ODBC Driver 17 for SQL Server};SERVER=YourServerName;DATABASE=YourDatabaseName;UID=YourUsername;PWD=YourPassword;"
    
    ' بررسی کنید که آیا جدول از قبل لینک شده است یا خیر
    On Error Resume Next
    Set tdf = db.TableDefs(strTable)
    On Error GoTo 0
    
    If Not tdf Is Nothing Then
        ' اگر جدول از قبل لینک شده است، لینک موجود را حذف کنید
        db.TableDefs.Delete strTable
        Set tdf = Nothing
    End If
    
    ' ایجاد TableDef جدید برای لینک کردن
    Set tdf = db.CreateTableDef(strTable)
    tdf.Connect = strConnect
    tdf.SourceTableName = strTable
    db.TableDefs.Append tdf
    
    MsgBox "جدول '" & strTable & "' با موفقیت لینک شد.", vbInformation
    
    Set tdf = Nothing
    Set db = Nothing
End Sub

توضیح کد:
این تابع `LinkSingleTable` یک اتصال DSN-less برای لینک کردن یک جدول منفرد از SQL Server به پایگاه داده Access فعلی ایجاد می‌کند. متغیر `strConnect` حاوی جزئیات اتصال به SQL Server است که شامل درایور ODBC، نام سرور، نام پایگاه داده، نام کاربری و رمز عبور می‌شود. این کد ابتدا بررسی می‌کند که آیا جدول مورد نظر (`YourSQLServerTable`) از قبل لینک شده است یا خیر. در صورت وجود، لینک قبلی را حذف کرده و سپس یک `TableDef` جدید ایجاد می‌کند، رشته اتصال و نام منبع جدول را تنظیم کرده و آن را به مجموعه `TableDefs` پایگاه داده فعلی اضافه می‌کند.

ب) لینک کردن تمام جداول

این کد تمام جداول موجود در یک پایگاه داده SQL Server را شناسایی کرده و آنها را به صورت لینک شده به Access اضافه می‌کند. این رویکرد برای مهاجرت کامل بک‌اند Access به SQL Server بسیار کارآمد است.


Sub LinkAllTablesFromSQLServer()
    Dim db As DAO.Database
    Dim rst As DAO.Recordset
    Dim tdf As DAO.TableDef
    Dim strConnect As String
    Dim strSQL As String
    Dim strTableName As String
    
    Set db = CurrentDb
    
    ' رشته اتصال DSN-less. پارامترهای سرور، پایگاه داده و اعتبارنامه‌ها را تغییر دهید.
    strConnect = "ODBC;DRIVER={ODBC Driver 17 for SQL Server};SERVER=YourServerName;DATABASE=YourDatabaseName;UID=YourUsername;PWD=YourPassword;"
    
    ' SQL برای دریافت لیست تمام جداول از SQL Server
    ' این کوئری به جدول سیستمی sys.tables در SQL Server دسترسی پیدا می کند.
    strSQL = "SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE = 'BASE TABLE' AND TABLE_SCHEMA = 'dbo';"
    
    ' باز کردن رکوردست از SQL Server برای دریافت لیست جداول
    Set rst = db.OpenConnection(strConnect).OpenRecordset(strSQL)
    
    ' حذف تمام جداول لینک شده موجود برای جلوگیری از تکرار
    For Each tdf In db.TableDefs
        If tdf.Connect <> "" Then ' اگر Connect property خالی نباشد، به این معنی است که یک جدول لینک شده است
            db.TableDefs.Delete tdf.Name
        End If
    Next tdf
    
    ' حلقه زدن بر روی رکوردست و لینک کردن هر جدول
    If Not rst.EOF Then
        rst.MoveFirst
        Do While Not rst.EOF
            strTableName = rst!TABLE_NAME
            
            ' ایجاد TableDef جدید برای لینک کردن
            Set tdf = db.CreateTableDef(strTableName)
            tdf.Connect = strConnect
            tdf.SourceTableName = strTableName
            db.TableDefs.Append tdf
            
            rst.MoveNext
        Loop
    End If
    
    MsgBox "تمام جداول SQL Server با موفقیت لینک شدند.", vbInformation
    
    rst.Close
    Set rst = Nothing
    Set tdf = Nothing
    Set db = Nothing
End Sub

توضیح کد:
تابع `LinkAllTablesFromSQLServer` برای لینک کردن خودکار تمام جداول کاربر (`BASE TABLE`) از شمای `dbo` در یک پایگاه داده SQL Server به Access طراحی شده است. این کد از همان رشته اتصال DSN-less استفاده می‌کند. ابتدا با استفاده از `INFORMATION_SCHEMA.TABLES` از SQL Server، فهرستی از نام جداول را بازیابی می‌کند. قبل از لینک کردن جداول جدید، تمام جداول لینک شده موجود در Access را حذف می‌کند تا از تکرار یا خطا جلوگیری شود. سپس، در یک حلقه، برای هر نام جدول بازیابی شده از SQL Server، یک `TableDef` جدید در Access ایجاد کرده و آن را لینک می‌کند.

نکات مهم در مورد رشته اتصال (Connection String)

رشته اتصال مهمترین بخش در لینک کردن جداول است. دو نوع اصلی وجود دارد:

DSN (Data Source Name): یک نام پیکربندی شده در سیستم عامل است که شامل جزئیات اتصال به پایگاه داده می‌شود.


    "ODBC;DSN=YourDSNName;UID=YourUsername;PWD=YourPassword;"
    

این رشته اتصال از یک DSN از پیش پیکربندی شده استفاده می‌کند که جزئیات سرور و پایگاه داده را در خود نگه می‌دارد.
DSN-less: تمام جزئیات اتصال مستقیماً در رشته اتصال گنجانده شده‌اند. این روش انعطاف‌پذیری بیشتری دارد و نیازی به پیکربندی DSN در هر دستگاه ندارد.


    "ODBC;DRIVER={ODBC Driver 17 for SQL Server};SERVER=YourServerName;DATABASE=YourDatabaseName;UID=YourUsername;PWD=YourPassword;"
    

این رشته اتصال DSN-less است که شامل نام درایور ODBC، نام سرور SQL Server، نام پایگاه داده، نام کاربری و رمز عبور برای احراز هویت می‌شود.

همیشه توصیه می‌شود از درایورهای ODBC به‌روز مانند “ODBC Driver 17 for SQL Server” یا نسخه‌های جدیدتر استفاده کنید تا بهترین عملکرد و سازگاری را داشته باشید.

ملاحظات عملکردی

هنگام کار با جداول لینک شده، مهم است که برای بهینه‌سازی عملکرد نکات زیر را در نظر بگیرید:

کوئری‌ها: کوئری‌های خود را بهینه کنید. از کوئری‌های Pass-Through برای عملیات‌های پیچیده استفاده کنید تا بار پردازش به SQL Server منتقل شود.
نمایه‌ها (Indexes): اطمینان حاصل کنید که جداول SQL Server دارای نمایه‌های مناسب برای فیلدهایی هستند که در کوئری‌ها، فیلترها و روابط استفاده می‌شوند.
انتقال تنها داده‌های مورد نیاز: تا حد امکان، تنها داده‌هایی را که واقعاً نیاز دارید از SQL Server درخواست کنید. از `SELECT *` بی مورد اجتناب کنید.
بررسی Plan: برای کوئری‌های کند، Plan اجرای آنها را در SQL Server بررسی کنید تا گلوگاه‌ها را شناسایی کنید.
اتصال شبکه: کیفیت و سرعت اتصال شبکه بین کلاینت Access و سرور SQL Server بر عملکرد تأثیر مستقیم دارد.

نگهداری و مدیریت

امنیت اعتبارنامه‌ها: اطلاعات ورود به SQL Server (UID, PWD) را در کد VBA به صورت هاردکد قرار ندهید، به خصوص در محیط‌های تولیدی. از روش‌های امن‌تری مانند استفاده از فایل‌های پیکربندی رمزگذاری شده یا درخواست از کاربر استفاده کنید.
به‌روزرسانی لینک‌ها: اگر اطلاعات اتصال SQL Server تغییر کند (مانند نام سرور یا پایگاه داده)، باید لینک‌های جداول را به‌روزرسانی کنید. ابزار Linked Table Manager اکسس این کار را به سادگی انجام می‌دهد. همچنین می‌توانید این کار را با استفاده از VBA و تغییر `tdf.Connect` برای هر جدول لینک شده انجام دهید.
پشتیبان‌گیری: از هر دو پایگاه داده Access (برای فرم‌ها، گزارش‌ها و کد) و SQL Server (برای داده‌ها) به طور منظم پشتیبان‌گیری کنید.

با رعایت این نکات، می‌توانید یک سیستم پایدار و کارآمد با استفاده از Access به عنوان رابط کاربری و SQL Server به عنوان بک‌اند قدرتمند داده‌ها ایجاد کنید. این رویکرد به شما امکان می‌دهد تا از بهترین ویژگی‌های هر دو پلتفرم بهره‌مند شوید و یک راه حل مقیاس‌پذیر برای نیازهای کسب‌وکار خود فراهم کنید.

 

من علی دستجردی‌ام؛ عاشق کار با دیتا، از SQL Server تا بیگ‌دیتا و هوش مصنوعی. دغدغه‌ام کشف ارزش داده‌ها و به‌اشتراک‌گذاری تجربه‌هاست. ✦ رزومه من: alidastjerdi.com ✦

عضویت
منو باخبر کن!!!
guest
نام
ایمیل

0 دیدگاه
Inline Feedbacks
دیدن تمامی کامنتها

فوتر سایت

ورود به سایت

sqlyar

هنوز عضو نیستید؟

ورود به سایت

هنوز تبت نام نکردید ؟