Solved

load a db table from excel

Posted on 2006-10-23
7
211 Views
Last Modified: 2010-04-16
I am new to .net and i wanted to know how to implemnet thisi project that i have  been given and wanted an experts advice on the best way to implement the project.Plz advice.

Requiremnets:

Read from multiple sheets of an excel file  and load the single sql db table with this data from the excel file and also run a stored procedure in the background
to manupilate other db tables using this table.
This is an windows application.
Thank you.
0
Comment
Question by:pgupta81
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
  • 2
  • +1
7 Comments
 
LVL 29

Expert Comment

by:Gautham Janardhan
ID: 17793627
If its a one time requirement u can directly import data from excel into sql table using DTS.
In EM , rt click DATABSE, all tasks - Import and there u give source and destination, Ur source will be excel file
0
 
LVL 5

Expert Comment

by:rameedev
ID: 17793709
IF it is not a One time requirement then

On some Button Click Event (Or whatever is the UI event)...You could probably do something like this


Function LoadDataFrom ExcelAndUpdateDB()
{
    // Write your Code for filling some dataset from the Excel file
    // This Could return a DataSet
   
    foreach(DataRow dr in DataSet.Tables[0].Rows)
    {
        //Write your Code to take all the rows from the datatable and call your SP
    }
}


0
 

Author Comment

by:pgupta81
ID: 17794078
I have to develop a windows application on this thats why i cannot use EM DTS to do this..

How to iterate through multiple sheets of excel to load sql table?
Do i need to follow certain naming convention ?
0
Salesforce Made Easy to Use

On-screen guidance at the moment of need enables you & your employees to focus on the core, you can now boost your adoption rates swiftly and simply with one easy tool.

 
LVL 8

Accepted Solution

by:
redpipe earned 125 total points
ID: 17794194
The following function takes a complete filepath to an Excel file and returns all sheetnames in the file as an string array.

public string[] GetSheetNames(string FilePath)
    {
      string connString = "Provider=Microsoft.Jet.OLEDB.4.0;" +
                          "Data Source=" + FilePath + ";" +
                          "Extended Properties=\"Excel 8.0;HDR=YES\"";
      OleDbConnection conn = null;
      string[] xlsSheets = null;
      DataTable dt = null;
      try {
        using (conn = new OleDbConnection(connString)) {
          if (conn.State != ConnectionState.Open) { conn.Open(); }
          dt = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
          if ((dt != null) || (dt.Rows.Count > 0)) {
            xlsSheets = new String[dt.Rows.Count];
            int i = 0;
            string sheetName;
            foreach (DataRow row in dt.Rows) {
              sheetName = row["TABLE_NAME"].ToString();
              if (sheetName.StartsWith("'")) { sheetName = sheetName.Remove(0, 1); }
              if (sheetName.EndsWith("'")) { sheetName = sheetName.Remove(sheetName.Length - 1, 1); }
              if (sheetName.EndsWith("$")) { sheetName = sheetName.Remove(sheetName.Length - 1, 1); }
              xlsSheets[i] = sheetName;
              i++;
            }
          }
        }
      } finally {
        if (conn != null) {
          try {
            conn.Close();
            conn.Dispose();
            conn = null;
          } catch (OleDbException exOleDb) {
            Logger.LogException(exOleDb);
          }
        }

        if (dt != null) {
          dt.Dispose();
        }
      }
      return xlsSheets;
    }
0
 
LVL 29

Expert Comment

by:Gautham Janardhan
ID: 17794198
Dim DS As System.Data.DataSet
Dim MyCommand As System.Data.OleDb.OleDbDataAdapter
Dim MyConnection As System.Data.OleDb.OleDbConnection

MyConnection = New System.Data.OleDb.OleDbConnection( _
      "provider=Microsoft.Jet.OLEDB.4.0; " & _
      "data source=C:\myData.XLS; " & _
      "Extended Properties=Excel 8.0;")
' Select the data from Sheet1 of the workbook.
MyCommand = New System.Data.OleDb.OleDbDataAdapter( _
      "select * from [Sheet1$]", MyConnection)

DS = New System.Data.DataSet()
MyCommand.Fill(DS)
MyConnection.Close()
0
 
LVL 8

Expert Comment

by:redpipe
ID: 17794202
Forgot to submit the function for retrieving data from a given sheet.

public DataTable GetData(string FilePath, string SheetName, bool FirstRowIsHeader)
{
      string connString = null;
      if (FirstRowIsHeader) {
        connString = "Provider=Microsoft.Jet.OLEDB.4.0;" +
                     "Data Source=" + FilePath + ";" +
                     "Extended Properties=\"Excel 8.0;HDR=YES\"";
      } else {
        connString = "Provider=Microsoft.Jet.OLEDB.4.0;" +
                    "Data Source=" + FilePath + ";" +
                    "Extended Properties=\"Excel 8.0;HDR=NO\"";
      }
      OleDbConnection conn = null;
      OleDbCommand cmd = new OleDbCommand();
      DataTable dt = null;
      IDataReader dr = null;
      try {
        using (conn = new OleDbConnection(connString)) {
          if (conn.State != ConnectionState.Open) { conn.Open(); }
          cmd.Connection = conn;
          cmd.CommandText = "SELECT * FROM [" + SheetName + "$]";
          OleDbDataAdapter adapter = new OleDbDataAdapter();
          adapter.SelectCommand = cmd;
          dt = new DataTable(SheetName);
          adapter.FillSchema(dt, SchemaType.Source);
          adapter.Fill(dt);
        }
      } finally {
        if (cmd != null) {
        cmd.Dispose();
        cmd = null;
      }

      if (dr != null) {
        dr.Close();
        dr.Dispose();
        dr = null;
      }

      if (conn != null) {
        try {
          conn.Close();
          conn.Dispose();
          conn = null;
        } catch (OleDbException exOleDb) {
          Logger.LogException(exOleDb);
        }
      }
      }
      return dt;
    }
0
 

Author Comment

by:pgupta81
ID: 17891855
code Helped!! Thanks
0

Featured Post

PeopleSoft Has Never Been Easier

PeopleSoft Adoption Made Smooth & Simple!

On-The-Job Training Is made Intuitive & Easy With WalkMe's On-Screen Guidance Tool.  Claim Your Free WalkMe Account Now

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

In order to hide the "ugly" records selectors (triangles) in the rowheaders, here are some suggestions. Microsoft doesn't have a direct method/property to do it. You can only hide the rowheader column. First solution, the easy way The first sol…
This article aims to explain the working of CircularLogArchiver. This tool was designed to solve the buildup of log file in cases where systems do not support circular logging or where circular logging is not enabled
NetCrunch network monitor is a highly extensive platform for network monitoring and alert generation. In this video you'll see a live demo of NetCrunch with most notable features explained in a walk-through manner. You'll also get to know the philos…
If you’ve ever visited a web page and noticed a cool font that you really liked the look of, but couldn’t figure out which font it was so that you could use it for your own work, then this video is for you! In this Micro Tutorial, you'll learn yo…

696 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question