Пользовательский интерфейс C # при загрузке электронной таблицы Excel в базу данных SQL через VS 2005 - PullRequest
2 голосов
/ 02 ноября 2011

В настоящее время у меня есть веб, который загружает данные таблицы Excel в базу данных SQL. Когда страница загружается, все параметры жестко запрограммированы в коде, поэтому у меня нет кнопки «поиск файла» и «загрузка». Я хотел бы реализовать эти 2 кнопки, но я не уверен, как мне это сделать.

Я использую язык C #, Visual Studio 2005 и SQL Server 2005.

Ниже приведен код, который выполняет импорт данных Excel в базу данных:

importexcel.aspx.cs

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Data.OleDb;
using System.Data.Common;
using System.Data.SqlClient;

public partial class ImportExcel : System.Web.UI.Page
{
    public static string path = @"c:\Documents and Settings\rhlim\My Documents\Visual Studio 2005\WebSites\insqlserver\studentsheet1.xls";
    public static string connStr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + path + ";Extended Properties=Excel 8.0;";

    protected void Page_Load(object sender, EventArgs e)
    {
        // Create Connection to Excel Workbook
        using (OleDbConnection connection =
                     new OleDbConnection(connStr))
        {
            OleDbCommand command = new OleDbCommand
                    ("Select StudentName,RollNo,Course FROM [Sheet1$]", connection);

            connection.Open();
            // Create DbDataReader to Data Worksheet
            using (DbDataReader dr = command.ExecuteReader())
            {
                // SQL Server Connection String
                string sqlConnectionString = "Data Source=<IP>;Initial Catalog=<database>;User ID=<userid>;Password=<password>";

                // Bulk Copy to SQL Server
                using (SqlBulkCopy bulkCopy =
                           new SqlBulkCopy(sqlConnectionString))
                {
                    bulkCopy.DestinationTableName = "tStudent";
                    bulkCopy.WriteToServer(dr);
                }
            }
        }
    }
}

Ниже приведен мой код для моего текущего HTML:

importexcel.aspx

    <%@ Page Language="C#" AutoEventWireup="true"  CodeFile="ImportExcel.aspx.cs" Inherits="ImportExcel" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head id="Head1" runat="server">
    <title></title>
<script language="javascript" type="text/javascript">
</script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    </div>
    Please select a Excel spreadsheet to import:<br />     
        <asp:FileUpload ID="fupExcel" runat="server" /> 
        <br /> 
        <br /> 
<asp:Button ID="btnImport" runat="server"  
            Text="Import" onclick="btnImport_Click" />  
        <br />
        <br />
        <a href=http://localhost:1701/SoD>Click to go to main page</a>
        </form>

</body>
</html>

Я не уверен, как мне прикрепить 2 кнопки к фоновому коду, кто-то меня научит? Лучше всего, если с примером кода, большое спасибо!

1 Ответ

0 голосов
/ 02 ноября 2011

Во-первых, код в загрузке вашей страницы должен выполняться только if(IsPostBack) или по нажатию кнопки.

Во-вторых, (по крайней мере, современные) браузеры не позволят вам изменить значение поля входного файла или щелкнуть по нему.

Вы можете попробовать кое-что из флэш-загрузки, но я не ожидаю многого.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...