6

我正在寻找有关如何从 .NET Web 应用程序创建与数据库的接口以从 Excel 文件上传数据的任何最佳实践或想法我应该使用一种允许加载所有记录并标记错误的机制还是应该我使用一种在发生错误时停止加载的机制。

我以前从来没有处理过这种类型的要求,所以任何帮助都会非常棒!

谢谢

4

4 回答 4

5

我会尝试以下过去运作良好的方法。

  1. 允许用户上传文件,将其放在磁盘的某个位置。
  2. 将文件的结果绑定到某个网格(您可以使用传统的 Connection/Command 对象使用 ODBC/OLE DB 连接到 Excel 文件)。
  3. 根据一组业务规则对网格中的行应用验证(excel 数据通常很脏)。
  4. 允许用户更新网格中的值并纠正验证问题。
  5. 当所有数据都符合要求并且用户对它感到满意时,在事务中执行批量插入。
  6. 如果有任何“坏”发生回滚并呈现一些用户反馈。
于 2008-11-13T18:38:39.770 回答
2

您应该上传数据,然后在验证检查失败时对其进行标记。对于实际加载数据,您有几个选项:

  • ADO.Net 批量加载 API - 使用批量加载 API 将其放入临时表中。下面的代码片段显示了打开 .CSV 文件并以编程方式将其加载到临时表中的过程。

.

  public void Load() {
        bool OK = File.Exists(_filename);
        if (OK) {
            string sql = String.Format("Select * from {0}", FileName);
            OleDbConnection csv = new OleDbConnection();
            OleDbCommand cmd = new OleDbCommand(sql, csv);
            OleDbDataReader rs = null;
            SqlConnection db = null;
            SqlCommand clear = null;

            SqlBulkCopy bulk_load = null;
            try {
                    // Note two connections: one from the csv file
                    // and one to the database;
                    csv = new OleDbConnection();
                    csv.ConnectionString = ConnectionString;
                    csv.Open();
                    cmd = new OleDbCommand(sql, csv);
                    rs = cmd.ExecuteReader();

                    // Dung out the staging table
                    db = // [Create A DB conneciton Here]
                    clear = new SqlCommand("Truncate table Staging", db); // Left to the reader
                    clear.ExecuteNonQuery();

                   // Import into the staging table
                    bulk_load = new SqlBulkCopy(db);
                    bulk_load.DestinationTableName = Destination; // Actually an instance var
                    bulk_load.WriteToServer(rs);
                } catch (Exception ee) {
                    string summary = ee.Message;
                    string detail = ee.StackTrace;
                    //Notify(DisplayType.error, summary, detail);
                } finally {
                    if (rs != null) rs.Close();
                    if (csv != null) csv.Close();
                    if (bulk_load != null) bulk_load.Close();
                }
            }
        }
  • 使用 BCP 或 SSIS 直接从电子表格或 .CSV 文件导入它。
于 2008-11-13T18:17:27.550 回答
1

如果您的数据库中的数据完整性很重要,则不允许导入有错误或不符合您的数据库验证要求的数据。

由于这些是 Excel 文件,用户应该很容易更正 Excel 文件中的数据,而不是尝试使用其他界面来修复数据。只需确保错误消息将用户引导至问题所在的字段并清楚地解释问题所在。

于 2008-11-13T18:15:25.497 回答
0

你想把 excel 文件作为 blob 放在数据库中吗?还是您想解析文件并将文件中的记录放入数据库中?

我假设是后者。

作为用户,我希望可以选择知道错误是什么,以便我可以修复它们并重试。我认为我如何重试取决于我上传了多少数据。

我会尝试做一个混合解决方案..如果只有几个错误显示一个屏幕来纠正这些错误,以便用户可以快速继续。如果有大量错误,您应该可以做到并让用户重新尝试。

至于数据库。要么有一个单独的表格供上传,直到它们被检查并获取您的“真实”数据,或者有一个 UploadUniqueId 列,这样您就可以回滚任何上传而不会大惊小怪。

删除表名,其中 UploadUniqueId = 'GUID'

于 2008-11-13T18:07:05.543 回答