وارد کردن داده BULK راهنمای کامل

وارد کردن داده BULK به SQL Server: راهنمای جامع برای متخصصان پایگاه داده

وارد کردن داده به SQL Server یک نیاز رایج و حیاتی در مدیریت پایگاه‌های داده است. این فرآیند، از انتقال داده‌های موجود از یک سیستم قدیمی گرفته تا بارگذاری منظم اطلاعات از منابع خارجی، برای حفظ پویایی و کارایی پایگاه داده ضروری است. در این مقاله جامع، به بررسی چندین روش کلیدی و کارآمد برای وارد کردن داده به SQL Server می‌پردازیم، از جمله BULK INSERT، OPENROWSET(BULK…)، SQL Server Integration Services (SSIS)، BCP و Import/Export Wizard. هدف این راهنما، ارائه دیدگاهی عملی و دقیق برای متخصصان پایگاه داده و مهندسان داده است تا بتوانند بهترین روش را متناسب با نیازهای خاص خود انتخاب کنند.

وارد کردن داده با دستور BULK INSERT

دستور BULK INSERT یکی از کارآمدترین روش‌ها برای وارد کردن حجم زیادی از داده‌ها به یک جدول در SQL Server از یک فایل داده‌ای است. این دستور به شما اجازه می‌دهد تا فایل داده‌ای (مانند CSV یا TXT) را با سرعت بالا به طور مستقیم به پایگاه داده منتقل کنید. استفاده از BULK INSERT برای سناریوهایی که نیاز به بارگذاری سریع داده‌های حجیم دارند، بسیار مفید است.

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

مثال عملی BULK INSERT

فرض کنید فایل Customers.txt را در مسیر C:\CSV Data\ دارید و می‌خواهید داده‌های آن را به جدول Customers در پایگاه داده TestData وارد کنید. ابتدا باید جدول هدف را ایجاد کنیم:


USE TestData;
GO

IF OBJECT_ID('Customers') IS NOT NULL
    DROP TABLE Customers;
GO

CREATE TABLE Customers
(
    CustomerID      INT,
    CustomerName    VARCHAR(50),
    Email           VARCHAR(50),
    Phone           VARCHAR(20)
);
GO

اکنون، برای وارد کردن داده‌ها از فایل Customers.txt، از دستور BULK INSERT استفاده می‌کنیم. در این مثال، فرض می‌کنیم داده‌ها با کاما (,) از هم جدا شده‌اند و هر سطر با یک کاراکتر خط جدید (\n) به پایان می‌رسد:


BULK INSERT Customers
FROM 'C:\CSV Data\Customers.txt'
WITH
(
    FIELDTERMINATOR = ',',
    ROWTERMINATOR = '\n'
);
GO

این دستور، محتویات فایل Customers.txt را خوانده و آنها را به جدول Customers اضافه می‌کند. شما می‌توانید گزینه‌های مختلفی را در بخش WITH مشخص کنید، مانند نوع جداکننده فیلد (FIELDTERMINATOR)، جداکننده سطر (ROWTERMINATOR)، و همچنین FORMATFILE برای فایل‌های پیچیده‌تر.

وارد کردن داده با OPENROWSET(BULK…)

تابع OPENROWSET با استفاده از گزینه BULK، امکان دسترسی به داده‌های یک فایل داده‌ای را به عنوان یک مجموعه ردیف (rowset) فراهم می‌کند. این روش به شما اجازه می‌دهد تا داده‌ها را از یک فایل خارجی بخوانید، آنها را فیلتر یا تبدیل کنید و سپس در یک جدول SQL Server درج کنید. OPENROWSET(BULK…) به ویژه برای سناریوهایی که نیاز به انعطاف‌پذیری بیشتری در پردازش داده‌ها قبل از درج دارند، مفید است.

مثال عملی OPENROWSET(BULK…)

برای استفاده از OPENROWSET(BULK…)، ابتدا باید یک فرمت‌فایل XML ایجاد کنید که ساختار داده‌های فایل ورودی را توصیف کند. فرض کنید فایل Customers.txt شما به این صورت است:


1,Ali Ahmadi,ali.ahmadi@example.com,09123456789
2,Sara Karimi,sara.karimi@example.com,09351234567
3,Reza Abbasi,reza.abbasi@example.com,09219876543

فرمت‌فایل Customers.xml می‌تواند به این شکل باشد:


<?xml version="1.0"?>
<BCPFORMAT xmlns="http://schemas.microsoft.com/sqlserver/2004/bulkload/format" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
 <RECORD>
  <FIELD ID="1" xsi:type="CharTerm" TERMINATOR="," MAX_LENGTH="12" COLLATION="SQL_Latin1_General_CP1_CI_AS"/>
  <FIELD ID="2" xsi:type="CharTerm" TERMINATOR="," MAX_LENGTH="50" COLLATION="SQL_Latin1_General_CP1_CI_AS"/>
  <FIELD ID="3" xsi:type="CharTerm" TERMINATOR="," MAX_LENGTH="50" COLLATION="SQL_Latin1_General_CP1_CI_AS"/>
  <FIELD ID="4" xsi:type="CharTerm" TERMINATOR="\r\n" MAX_LENGTH="20" COLLATION="SQL_Latin1_General_CP1_CI_AS"/>
 </RECORD>
 <ROW>
  <COLUMN SOURCE="1" NAME="CustomerID" xsi:type="SQLINT"/>
  <COLUMN SOURCE="2" NAME="CustomerName" xsi:type="SQLVARYCHAR"/>
  <COLUMN SOURCE="3" NAME="Email" xsi:type="SQLVARYCHAR"/>
  <COLUMN SOURCE="4" NAME="Phone" xsi:type="SQLVARYCHAR"/>
 </ROW>
</BCPFORMAT>

با داشتن فرمت‌فایل، می‌توانید داده‌ها را مستقیماً از فایل کوئری کنید. به عنوان مثال، برای انتخاب تمامی مشتریان از فایل Customers.txt با استفاده از فرمت‌فایل Customers.xml، از کد زیر استفاده می‌کنید:


SELECT *
FROM OPENROWSET(
    BULK 'C:\CSV Data\Customers.txt',
    FORMATFILE = 'C:\CSV Data\Customers.xml'
) AS T1;
GO

برای درج این داده‌ها در جدول Customers، می‌توانید از دستور INSERT INTO…SELECT FROM OPENROWSET استفاده کنید:


INSERT INTO Customers (CustomerID, CustomerName, Email, Phone)
SELECT CustomerID, CustomerName, Email, Phone
FROM OPENROWSET(
    BULK 'C:\CSV Data\Customers.txt',
    FORMATFILE = 'C:\CSV Data\Customers.xml'
) AS T1;
GO

این روش انعطاف‌پذیری بالایی را برای تبدیل و فیلتر کردن داده‌ها قبل از درج در پایگاه داده فراهم می‌کند.

وارد کردن داده با SQL Server Integration Services (SSIS)

SQL Server Integration Services یا SSIS یک ابزار قدرتمند ETL (Extract, Transform, Load) است که بخشی از Microsoft SQL Server محسوب می‌شود. SSIS برای وارد کردن، تبدیل و بارگذاری داده‌ها از منابع مختلف به SQL Server، و همچنین انجام وظایف پیچیده‌تر مانند تمیز کردن داده‌ها، تجمیع آنها و اجرای گردش کار (workflow) کاربرد دارد. این روش برای سناریوهای سازمانی با نیازهای پیچیده انتقال داده، بهترین انتخاب است.

مزایای SSIS برای وارد کردن داده

  • انعطاف‌پذیری بالا: امکان اتصال به انواع منابع داده (فایل‌های مسطح، پایگاه‌های داده، وب سرویس‌ها و غیره).
  • قابلیت تبدیل داده: ابزارهای داخلی برای تبدیل، فیلتر و اعتبارسنجی داده‌ها قبل از بارگذاری.
  • مدیریت خطا: قابلیت‌های پیشرفته برای مدیریت و گزارش‌دهی خطاها در طول فرآیند ETL.
  • اتوماسیون: امکان زمان‌بندی و اتوماسیون پکیج‌های SSIS برای اجرای منظم.

ایجاد یک پکیج SSIS شامل استفاده از ابزار SQL Server Data Tools (SSDT) است که یک محیط گرافیکی برای طراحی جریان داده (Data Flow) و کنترل جریان (Control Flow) فراهم می‌کند. این ابزار به کاربران اجازه می‌دهد تا بدون نوشتن کد پیچیده، پکیج‌های ETL را بسازند و سفارشی‌سازی کنند.

وارد کردن داده با BCP (Bulk Copy Program)

برنامه BCP (Bulk Copy Program) یک ابزار خط فرمان است که امکان صادرات و وارد کردن حجم زیادی از داده‌ها بین یک نمونه از SQL Server و یک فایل داده‌ای را فراهم می‌کند. BCP ابزاری قدرتمند و سریع برای انتقال داده است که اغلب توسط مدیران پایگاه داده (DBA) برای کارهای اسکریپتی و اتوماسیون استفاده می‌شود.

مثال عملی BCP

برای وارد کردن داده از فایل Customers.txt به جدول Customers با استفاده از BCP، از دستور زیر در Command Prompt یا PowerShell استفاده می‌کنیم. فرض کنید فایل Customers.txt حاوی داده‌هایی با جداکننده کاما است:


bcp TestData.dbo.Customers in "C:\CSV Data\Customers.txt" -c -t, -S localhost -T

در این دستور:

  • TestData.dbo.Customers: نام کامل جدول (پایگاه داده.شمای.نام جدول).
  • in: مشخص می‌کند که داده‌ها وارد شوند (out برای خروجی گرفتن).
  • "C:\CSV Data\Customers.txt": مسیر فایل ورودی.
  • -c: مشخص می‌کند که نوع داده‌ای کاراکتری استفاده شود.
  • -t,: مشخص می‌کند که جداکننده فیلدها کاما (,) است.
  • -S localhost: نام سرور SQL Server (در اینجا localhost).
  • -T: مشخص می‌کند که از احراز هویت ویندوز (Trusted Connection) استفاده شود.

اگر نیاز به فرمت‌فایل دارید (مانند مثال OPENROWSET)، می‌توانید از گزینه -f به همراه مسیر فایل فرمت استفاده کنید.


bcp TestData.dbo.Customers in "C:\CSV Data\Customers.txt" -f "C:\CSV Data\Customers.xml" -S localhost -T

این روش برای اتوماسیون از طریق اسکریپت‌نویسی بسیار کارآمد است و در مواردی که نیاز به رابط کاربری گرافیکی نیست، سرعت بالایی دارد.

وارد کردن داده با Import/Export Wizard

SQL Server Import and Export Wizard یک ابزار گرافیکی و کاربرپسند است که به کاربران اجازه می‌دهد تا داده‌ها را به راحتی از منابع مختلف به SQL Server یا از SQL Server به مقصد دیگری منتقل کنند. این ابزار برای کاربرانی که با SSIS آشنایی ندارند یا نیاز به یک راه‌حل سریع و بدون کدنویسی دارند، ایده‌آل است. این Wizard به شما گام به گام در انتخاب منبع، مقصد و تنظیمات انتقال داده کمک می‌کند.

مزایای Import/Export Wizard

  • رابط کاربری گرافیکی: استفاده آسان بدون نیاز به کدنویسی.
  • پشتیبانی از انواع منابع: قابلیت اتصال به پایگاه‌های داده مختلف (SQL Server, Oracle, Excel, Flat Files).
  • امکان ذخیره پکیج SSIS: پس از اتمام کار، Wizard امکان ذخیره تنظیمات به عنوان یک پکیج SSIS را می‌دهد که می‌توان آن را مجدداً اجرا یا زمان‌بندی کرد.

مراحل کلی استفاده از Wizard

  1. انتخاب منبع داده: مشخص کردن نوع فایل یا پایگاه داده‌ای که داده‌ها از آنجا استخراج می‌شوند.
  2. انتخاب مقصد داده: انتخاب جدول یا پایگاه داده در SQL Server که داده‌ها به آنجا منتقل می‌شوند.
  3. نقشه‌برداری ستون‌ها: امکان تطبیق ستون‌های منبع با ستون‌های مقصد، و همچنین تعریف تبدیل‌های ساده.
  4. اجرا و ذخیره: اجرای فرآیند انتقال و در صورت نیاز، ذخیره آن به عنوان یک پکیج SSIS.

این Wizard ابزاری عالی برای بارگذاری داده‌های یک‌باره یا برای کاربرانی است که ترجیح می‌دهند با محیط گرافیکی کار کنند.

نکات مهم سئو برای وارد کردن داده به SQL Server

برای اینکه مقاله شما در موتورهای جستجو بهتر دیده شود، لازم است بهینه‌سازی‌های سئو را رعایت کنید. در اینجا به چند نکته مهم در این زمینه اشاره می‌شود:

  • کلمات کلیدی اصلی: کلماتی مانند “وارد کردن داده SQL Server”، “انتقال داده SQL Server”، “مهاجرت داده SQL Server” را به صورت طبیعی در عنوان، زیرعنوان‌ها و متن استفاده کنید.
  • کلمات کلیدی ثانویه: از عباراتی مانند “BULK INSERT”، “OPENROWSET”، “SSIS”، “BCP”، “Import/Export Wizard” به عنوان زیرعنوان‌ها و در متن استفاده کنید.
  • ساختار محتوا: مقاله را با استفاده از تگ‌های <h2> و <h3> به بخش‌های منطقی تقسیم کنید تا خوانایی و قابلیت اسکن برای موتورهای جستجو بهبود یابد.
  • مثال‌های کد و فرمول: ارائه مثال‌های عملی با فرمت‌بندی مناسب (همانند آنچه در این مقاله دیدید) نه تنها به خواننده کمک می‌کند بلکه سیگنال محتوای با کیفیت را به موتورهای جستجو ارسال می‌کند.
  • خوانایی: جملات و پاراگراف‌های کوتاه، استفاده از لیست‌ها و بولد کردن نکات مهم، تجربه کاربری را بهبود بخشیده و موتورهای جستجو نیز به محتوای خوانا امتیاز بالاتری می‌دهند.

نتیجه‌گیری

انتخاب بهترین روش برای وارد کردن داده به SQL Server بستگی به حجم داده، پیچیدگی فرآیند تبدیل، نیاز به اتوماسیون و سطح راحتی کاربر با ابزارهای مختلف دارد. BULK INSERT و BCP برای بارگذاری سریع و حجیم داده‌ها ایده‌آل هستند، در حالی که OPENROWSET(BULK…) انعطاف‌پذیری بیشتری در کوئری گرفتن مستقیم از فایل‌ها ارائه می‌دهد. برای سناریوهای پیچیده‌تر و سازمانی با نیازهای ETL گسترده، SSIS بهترین راه‌حل است. در نهایت، Import/Export Wizard گزینه‌ای عالی برای کاربرانی است که به دنبال سادگی و سرعت در انتقال داده‌های کمتر حجیم هستند. با درک دقیق هر یک از این روش‌ها، متخصصان پایگاه داده می‌توانند به طور موثر و کارآمد داده‌ها را به SQL Server وارد کنند.

 

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

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

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

فوتر سایت

ورود به سایت

sqlyar

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

ورود به سایت

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