Skip to main content

how to import .csv file into sql server using c#

I am using the ASP.NET MVC. here is the code that might help you that how to you convert the CSV file in List and after that you will able to save the List data in to SQL.


     [HttpPost]  
     public ActionResult Create(t_NextDevAttendence t_nextdevattendence, IEnumerable<HttpPostedFileBase> files)  
     {  
       // Read the CSV file name & file path  
                // I am usisg here Kendo UI Uploader  
                string path = "";  
       string filenamee = "";  
       if (files != null)  
       {  
         foreach (var file in files)  
         {  
           var fileName = Path.GetFileName(file.FileName);  
           path = Path.GetFullPath(file.FileName);  
           filenamee = fileName;  
         }  
                     // Read the CSV file data  
         StreamReader sr = new StreamReader(path);  
         string line = sr.ReadLine();  
         string[] value = line.Split(',');  
         DataTable dt = new DataTable();  
         DataRow row;  
         foreach (string dc in value)  
         {  
           dt.Columns.Add(new DataColumn(dc));  
         }  
         while (!sr.EndOfStream)  
         {  
           value = sr.ReadLine().Split(',');  
           if (value.Length == dt.Columns.Count)  
           {  
             row = dt.NewRow();  
             row.ItemArray = value;  
             dt.Rows.Add(row);  
           }  
         }  
         // Insert CSV data in List  
         List<EmpAttendence> employeeList = new List<EmpAttendence>();  
         var myEnumerable = dt.AsEnumerable();  
         foreach (var item in myEnumerable)  
         {  
                     // set the CSV file column with my class  
                     // here it is Important that all field should be string when your inset in DB  
           EmpAttendence emp = new EmpAttendence();  
           emp.EmployeeId = item.Field<String>("User ID");  
           emp.EntryDate = item.Field<String>("Date");  
           emp.EntryTime = item.Field<String>("Time");  
           emp.fileName = filenamee;  
           employeeList.Add(emp);  
         }  
         // Insert in database from List  
         foreach (var item in employeeList)  
         {  
                     // table name  
           t_NextDevAttendence t_next = new t_NextDevAttendence();  
           t_next.EmployeeCode = item.EmployeeId;  
           t_next.EntryDate = item.EntryDate;  
           t_next.EntryTime = item.EntryTime;  
           t_next.CSVFileName = item.fileName;  
           db.t_NextDevAttendence.AddObject(t_next);  
         }  
         db.SaveChanges();  
         return RedirectToAction("Index");  
       }  
       return View(t_nextdevattendence);  
     }  

Comments

Popular posts from this blog

WPF datagrid cell textbox change event

Entity/Class: public class FeesDetails : INotifyPropertyChanged { public int Id { get; set; } public string FeesName { get; set;} public string FeesDetailsName { get; set; } public int? PaidAmount { get; set; } public event PropertyChangedEventHandler PropertyChanged; private void NotifyPropertyChanged(System.String info) { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(info)); } } public int feesAmount { get; set; } public int FeesAmount { get { return this.feesAmount; } set { if (value != this.feesAmount) { this.feesAmount = value; NotifyPropertyChanged("FeesAmount"); } } } } XAML: <DataGrid AutoGenerateColumns="False" Height="21...

mvc razor textboxfor change event change another textboxfor value

Based on value of Weight, Rate , CNF & AWB it will change the value of Freight , TTLCNF anfd TTLFright . Freight= Weight*Rate; TTLCNF  = Weight*CNF; TTLFright=  Freight+ TTLCNF  + AWB; @Html.TextBoxFor(model => model.Weight, new { onChange="return GetWight(this);"}) @Html.TextBoxFor(model => model.Rate, new { onChange="return GetWight(this);"})/Kg @Html.TextBoxFor(model => model.Freight, new {disabled = "disabled" , @readonly = "readonly" ,onChange="return GetTTLFright(this);"}) @Html.TextBoxFor(model => model.CNFPK, new { onChange="return GetCNFPK(this);"}) @Html.TextBoxFor(model => model.TTLCNF, new {disabled = "disabled" , @readonly = "readonly",onChange="return GetTTLFright(this);" }) @Html.TextBoxFor(model => model.AWB, new { onChange="return GetTTLFright(this);"}) and script <script> function GetW...

mvvm double click event in listview

If you want to get the double click event on a listview item you can try with this code; <ListView Grid.Row="0" Grid.RowSpan="3" Grid.Column="0" Width="250" Height="200" HorizontalAlignment="Stretch" VerticalAlignment="Top" AlternationCount="2" BorderBrush="#FFA8CC7B" ItemContainerStyle="{StaticResource alternatingStyle}" ItemsSource="{Binding FromPayerNameList}" SelectedItem="{Binding SelectedFromPayer, Mode=TwoWay}"> <ListView.ItemTemplate> <DataTemplate> <TextBlock Width="{Binding Path=ActualWidth, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type ListView}}}" Text=...