Hướng dẫn how read data from excel and insert into sql using c#? - cách đọc dữ liệu từ excel và chèn vào sql bằng c#?
Bỏ qua nội dung chính Trình duyệt này không còn được hỗ trợ. Show
Nâng cấp lên Microsoft Edge để tận dụng các tính năng mới nhất, cập nhật bảo mật và hỗ trợ kỹ thuật.
Nhập dữ liệu từ Excel vào SQL Server hoặc Azure SQL cơ sở dữ liệu
Trong bài viết nàyÁp dụng cho: SQL Server (tất cả các phiên bản được hỗ trợ) Cơ sở dữ liệu Azure SQL SQL Server (all supported versions) Azure SQL DatabaseCó một số cách để nhập dữ liệu từ các tệp Excel vào SQL Server hoặc vào cơ sở dữ liệu Azure SQL. Một số phương thức cho phép bạn nhập dữ liệu trong một bước trực tiếp từ các tệp Excel; Các phương thức khác yêu cầu bạn xuất dữ liệu Excel của mình dưới dạng văn bản (tệp CSV) trước khi bạn có thể nhập nó. Bài viết này tóm tắt các phương thức được sử dụng thường xuyên và cung cấp các liên kết để biết thêm thông tin chi tiết. Một mô tả đầy đủ về các công cụ và dịch vụ phức tạp như SSIS hoặc Azure Data Factory nằm ngoài phạm vi của bài viết này. Để tìm hiểu thêm về giải pháp mà bạn quan tâm, hãy làm theo các liên kết được cung cấp. Danh sách các phương phápCó một số phương pháp để nhập dữ liệu từ Excel. Bạn có thể cần cài đặt SQL Server Management Studio (SSMS) để sử dụng một số công cụ này. Bạn có thể sử dụng các công cụ sau để nhập dữ liệu từ Excel:
Nếu bạn muốn nhập nhiều bảng tính từ một sổ làm việc Excel, bạn thường phải chạy bất kỳ công cụ nào trong số này một lần cho mỗi tờ. Trình hướng dẫn nhập và xuất khẩuNhập dữ liệu trực tiếp từ các tệp Excel bằng cách sử dụng trình hướng dẫn nhập và xuất nhập SQL Server. Bạn cũng có tùy chọn để lưu cài đặt dưới dạng gói Dịch vụ tích hợp SQL Server (SSIS) mà bạn có thể tùy chỉnh và sử dụng lại sau.
Điều này ra mắt trình hướng dẫn:
Để tìm hiểu thêm, hãy xem lại:
Nhập dữ liệu từ Excel hoặc Xuất dữ liệu sang Excel với Dịch vụ tích hợp SQL Server (SSIS)Tiện ích BCP Để tìm hiểu thêm, hãy xem lại:
Để bắt đầu học cách xây dựng các gói SSIS, hãy xem hướng dẫn cách tạo gói ETL.
OpenRowset và máy chủ được liên kếtGhi chú Nhà cung cấp ACE (trước đây là nhà cung cấp máy bay phản lực) kết nối với các nguồn dữ liệu Excel được dành cho việc sử dụng phía máy khách tương tác. Nếu bạn sử dụng nhà cung cấp ACE trên SQL Server, đặc biệt là trong các quy trình hoặc quy trình tự động chạy song song, bạn có thể thấy kết quả không mong muốn. Truy vấn phân phốiNhập dữ liệu trực tiếp vào SQL Server từ các tệp Excel bằng cách sử dụng hàm Transact-SQL 3 hoặc 4. Việc sử dụng này được gọi là một truy vấn phân tán.Trước khi bạn có thể chạy truy vấn phân tán, bạn phải bật tùy chọn cấu hình máy chủ 5, như được hiển thị trong ví dụ sau. Để biết thêm thông tin, hãy xem tùy chọn cấu hình máy chủ truy vấn phân tán ad hoc.
Mẫu mã sau sử dụng 3 để nhập dữ liệu từ bảng tính Excel 7 vào bảng cơ sở dữ liệu mới.
Đây là ví dụ tương tự với 4.
Để nối dữ liệu đã nhập vào bảng hiện có thay vì tạo một bảng mới, hãy sử dụng cú pháp 9 thay vì cú pháp 0 được sử dụng trong các ví dụ trước.Để truy vấn dữ liệu Excel mà không cần nhập nó, chỉ cần sử dụng cú pháp 1 tiêu chuẩn.Để biết thêm thông tin về các truy vấn phân tán, hãy xem các chủ đề sau:
Máy chủ liên kếtBạn cũng có thể định cấu hình kết nối liên tục từ SQL Server đến tệp Excel dưới dạng máy chủ được liên kết. Ví dụ sau đây nhập dữ liệu từ bảng tính 2 trên máy chủ liên kết Excel hiện tại 3 vào bảng cơ sở dữ liệu SQL Server mới có tên 4.
Bạn có thể tạo một máy chủ được liên kết từ SQL Server Management Studio hoặc bằng cách chạy quy trình được lưu trữ hệ thống 5, như được hiển thị trong ví dụ sau.
Để biết thêm thông tin về các máy chủ được liên kết, hãy xem các chủ đề sau:
Để biết thêm các ví dụ và thông tin về cả máy chủ được liên kết và truy vấn phân tán, hãy xem các chủ đề sau:
Điều kiện tiên quyết - Lưu dữ liệu Excel dưới dạng văn bảnĐể sử dụng phần còn lại của các phương thức được mô tả trên trang này - câu lệnh chèn số lượng lớn, công cụ BCP hoặc nhà máy dữ liệu Azure - trước tiên bạn phải xuất dữ liệu Excel của mình sang tệp văn bản. Trong Excel, chọn Tệp | Lưu dưới dạng và sau đó chọn Text (Tab-Delimited) (*.txt) hoặc CSV (dấu phẩy-Delimited) (*.csv) làm loại tệp đích.File | Save As and then select Text (Tab-delimited) (*.txt) or CSV (Comma-delimited) (*.csv) as the destination file type. Nếu bạn muốn xuất nhiều bảng tính từ sổ làm việc, hãy chọn từng tờ và sau đó lặp lại quy trình này. Lệnh lưu chỉ xuất xuất bảng hoạt động.Save as command exports only the active sheet. Mẹo Để có kết quả tốt nhất với các công cụ nhập dữ liệu, hãy lưu các bảng chỉ chứa các tiêu đề cột và các hàng dữ liệu. Nếu dữ liệu đã lưu chứa các tiêu đề trang, các dòng trống, ghi chú, v.v., bạn có thể thấy kết quả bất ngờ sau khi bạn nhập dữ liệu. Nhập trình hướng dẫn tệp phẳngNhập dữ liệu được lưu dưới dạng tệp văn bản bằng cách bước qua các trang của Trình hướng dẫn tệp phẳng nhập. Như được mô tả trước đây trong phần Điều kiện tiên quyết, bạn phải xuất dữ liệu Excel của mình dưới dạng văn bản trước khi bạn có thể sử dụng Trình hướng dẫn tệp Flat Interpress để nhập nó. Để biết thêm thông tin về Trình hướng dẫn tệp phẳng nhập, hãy xem Nhập tệp phẳng vào SQL Wizard. Lệnh chèn số lượng lớn 6 là một lệnh Transact-SQL mà bạn có thể chạy từ SQL Server Management Studio. Ví dụ sau tải dữ liệu từ tệp được phân phối bằng dấu phẩy 7 vào bảng cơ sở dữ liệu hiện có.Như được mô tả trước đây trong phần Điều kiện tiên quyết, bạn phải xuất dữ liệu Excel của mình dưới dạng văn bản trước khi bạn có thể sử dụng Chèn số lượng lớn để nhập nó. Chèn số lượng lớn không thể đọc trực tiếp các tệp excel. Với lệnh chèn số lượng lớn, bạn có thể nhập một tệp CSV được lưu trữ cục bộ hoặc trong bộ nhớ Azure Blob.
Để biết thêm thông tin và ví dụ cho cơ sở dữ liệu SQL Server và SQL, hãy xem các chủ đề sau:
Công cụ BCPBCP là một chương trình mà bạn chạy từ dấu nhắc lệnh. Ví dụ sau tải dữ liệu từ tệp được phân phối bằng dấu phẩy vào bảng cơ sở dữ liệu 9 hiện có.Như được mô tả trước đây trong phần Điều kiện tiên quyết, bạn phải xuất dữ liệu Excel của mình dưới dạng văn bản trước khi bạn có thể sử dụng BCP để nhập nó. BCP không thể đọc trực tiếp các tệp excel. Sử dụng để nhập vào cơ sở dữ liệu SQL Server hoặc SQL từ tệp thử nghiệm (CSV) được lưu vào bộ lưu trữ cục bộ. Quan trọng Đối với tệp văn bản (CSV) được lưu trữ trong bộ lưu trữ Azure Blob, sử dụng Chèn số lượng lớn hoặc OpenRowset. Để biết ví dụ, xem ví dụ.
Để biết thêm thông tin về BCP, hãy xem các chủ đề sau:
Sao chép Wizard (ADF)Nhập dữ liệu được lưu dưới dạng tệp văn bản bằng cách bước qua các trang của trình hướng dẫn sao chép Azure Data Factory (ADF). Như được mô tả trước đây trong phần Điều kiện tiên quyết, bạn phải xuất dữ liệu Excel của mình dưới dạng văn bản trước khi bạn có thể sử dụng Nhà máy dữ liệu Azure để nhập nó. Nhà máy dữ liệu không thể đọc trực tiếp các tệp excel. Để biết thêm thông tin về trình hướng dẫn bản sao, hãy xem các chủ đề sau:
Nhà máy dữ liệu AzureNếu bạn quen thuộc với Azure Data Factory và không muốn chạy trình hướng dẫn sao chép, hãy tạo một đường ống với hoạt động sao chép sao chép từ tệp văn bản sang SQL Server hoặc đến cơ sở dữ liệu Azure SQL. Như được mô tả trước đây trong phần Điều kiện tiên quyết, bạn phải xuất dữ liệu Excel của mình dưới dạng văn bản trước khi bạn có thể sử dụng Nhà máy dữ liệu Azure để nhập nó. Nhà máy dữ liệu không thể đọc trực tiếp các tệp excel. Để biết thêm thông tin về trình hướng dẫn bản sao, hãy xem các chủ đề sau:
Nếu bạn quen thuộc với Azure Data Factory và không muốn chạy trình hướng dẫn sao chép, hãy tạo một đường ống với hoạt động sao chép sao chép từ tệp văn bản sang SQL Server hoặc đến cơ sở dữ liệu Azure SQL.
Máy chủ SQLCơ sở dữ liệu Azure SQLĐể bắt đầu học cách sao chép dữ liệu với nhà máy dữ liệu Azure, hãy xem các chủ đề sau: Di chuyển dữ liệu bằng cách sử dụng hoạt động sao chép
Hướng dẫn: Tạo một đường ống với hoạt động sao chép bằng cổng thông tin AzureLỗi thông thường
Di chuyển dữ liệu bằng cách sử dụng hoạt động sao chép
Hướng dẫn: Tạo một đường ống với hoạt động sao chép bằng cổng thông tin AzureLỗi thông thường Di chuyển dữ liệu bằng cách sử dụng hoạt động sao chép 0Hướng dẫn: Tạo một đường ống với hoạt động sao chép bằng cổng thông tin AzureLỗi thông thườngMicrosoft.ace.oledb.12.0 "chưa được đăng ký Lỗi này xảy ra vì nhà cung cấp OLEDB không được cài đặt. Cài đặt nó từ Microsoft Access DataBase Engine 2010 Phân phối lại. Hãy chắc chắn cài đặt phiên bản 64 bit nếu Windows và SQL Server đều là 64 bit. 1 2Lỗi đầy đủ là:
Hệ thống tập tinMáy chủ SQL Làm thế nào để bạn đọc dữ liệu từ Excel và chèn vào SQL?Đầu tiên, sao chép dữ liệu từ Excel, sau đó dán nó vào bảng SQL Server bằng cơ sở dữ liệu> Bảng> Chỉnh sửa tùy chọn menu 200 hàng Top. Luôn bắt đầu bằng cách sao chép và dán một hàng dữ liệu duy nhất để xác thực các loại dữ liệu.copy the data from Excel, and then paste it into the SQL Server table using the Database > Table > Edit top 200 rows menu option. Always start by copying and pasting a single row of data to validate the data types.
Làm thế nào đọc dữ liệu từ Excel và chèn vào SQL bằng C#?Tạo một hàm để đọc và chèn một tệp excel vào cơ sở dữ liệu là:.. riêng tư void insertexcelrecords (String filePath). ExcelConn(FilePath);. Truy vấn = chuỗi. .... OLEDBCOMMAND ECOM = OLEDBCOMMAND mới (Truy vấn, ECON) ;. Kinh tế. .... Tập dữ liệu ds = new DataSet () ;. OLEDBDATAAD CHƯƠNG ODA = OLEDBDATAAD CHƯƠNG (Truy vấn, ECON) ;. Làm thế nào để bạn đọc từ một tệp excel trong c?Cách đọc tệp Excel trong C#.. Tải xuống thư viện C# để đọc các tệp Excel .. Tải và đọc một tệp Excel (sổ làm việc). Tạo một sổ làm việc Excel trong CSV hoặc XLSX .. Chỉnh sửa các giá trị tế bào trong một phạm vi của các ô .. Xác thực dữ liệu bảng tính .. Xuất dữ liệu bằng khung thực thể .. Làm thế nào sao chép dữ liệu từ bảng excel sang sql?Bạn có thể sao chép dữ liệu-dán từ ex excel-sheet vào bảng SQL bằng cách làm như vậy:.. Chọn dữ liệu trong Excel và nhấn Ctrl + C .. Trong SQL Server Management Studio, nhấp chuột phải và chọn Chỉnh sửa 200 hàng Top .. Cuộn xuống phía dưới và chọn toàn bộ hàng trống bằng cách nhấp vào tiêu đề hàng .. Dán dữ liệu bằng cách nhấn Ctrl + V .. |