Java - einfügen von Zeilen in eine db-Tabelle nach excel-Datei Lesen

Ich in der Lage bin zu Lesen Sie die excel-Datei Daten aus dem code unten, aber ich bin nicht in der Lage, um die Logik hinter, wie man excel-Daten in der Reihenfolge speichern, in der POJO-Klasse nach dem Lesen der excel-Datei.
Kurz gesagt: ich habe Verwirrung, wie Sie schicken diese Lesen von excel-Daten an meine model-Klassen gespeichert werden, die in meine Datenbank-Tabelle?

Den folgenden code korrekt gedruckt, die excel-Zeilen in meiner Eclipse-Konsole:

                     ..............
                          ..............
        public String execute()
        {
            try
            { 
                 String filePath=servletRequest.getSession().getServletContext().getRealPath("/"); 
                 File fileToCreate= new File(filePath,this.excelDataFileName);
                 FileUtils.copyFile(this.excelData, fileToCreate); 
                 UploadExcel obj=new UploadExcel();
                 obj.readExcel(excelData.getAbsolutePath()); 

            }
            catch(Exception e){
                e.printStackTrace();
                addActionError(e.getMessage());
                return INPUT;
            }
            return SUCCESS;
        }


        /*
         *Method to read the each sheet ,row & column of the excel sheet of the uploaded xls file  
        */
        public void readExcel(String filePath)
        { 
            try
             {
                FileInputStream file=new FileInputStream(new File(filePath));

                //Getting the instance for XLS file 
                 HSSFWorkbook workbook=new HSSFWorkbook(file);

                 //Get First sheet from the workbook
                HSSFSheet sheet=workbook.getSheetAt(0);

                 ArrayList myList = new ArrayList();
                //Iterate start from the first sheet of the uploaded excel file
                  Iterator<Row> rowIterator = sheet.iterator();
                  while(rowIterator.hasNext())
                  {
                      Row  row=rowIterator.next();

                      if(row.getRowNum()==0)
                      {
                          continue;//skip to read the first row of file
                      }

                      //For each row, iterate through each coulumns
                      Iterator<Cell> cellIterator=row.cellIterator();

                      while(cellIterator.hasNext())
                      {
                          Cell cell=cellIterator.next();
                          if(cell.getColumnIndex()==0)
                          {
                              continue;
                          }
                          switch(cell.getCellType())
                          {
                             case Cell.CELL_TYPE_BOOLEAN:
                                  System.out.print(cell.getBooleanCellValue() + "\t\t");
                                 //myList.add(cell.getBooleanCellValue());
                                  break;
                             case Cell.CELL_TYPE_NUMERIC:
                                 System.out.print(cell.getNumericCellValue()+ "\t\t");
                                // myList.add(cell.getNumericCellValue());
                                 break;
                             case Cell.CELL_TYPE_STRING:
                                 System.out.print(cell.getStringCellValue()+ "\t\t");
                                //myList.add(cell.getStringCellValue());
                                 break;
                          }

                      }     
                      System.out.println(""); 


                  }
                  file.close();
                FileOutputStream out=
                        new FileOutputStream(new File(filePath));

                  workbook.write(out);
                  out.close();



            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }

        }




    }

In der Ausgabe der Konsole:

TEXTit      6695 PROSPECT RD        Nova Scotia     B3z 3t1 

row2sdfsda      61695 P         sfsdfdsf        23B3z 3t1   

Was ich dachte ist,
Ich habe, um die Zeile eins nach dem anderen, und ich werde fügen Sie dieser Zeile die Daten zu meinem POJO-Klasse-Objekt und senden Sie es an dao , und schließlich verwenden saveOrupdate(tableobj) von hibernate-Methode zum speichern der Daten in meine db-Tabelle.
Aber ich konnte nicht denken können, wie kann ich diese Daten auf meinem Pojo-Klasse?

Hoffe, jemand kann mir hier helfen.

  • Senden Sie nicht jede Zeile auf die DAO-one pro. Es wird schrecklich langsam..Man kann nur passieren in einer Liste der Objekt-Typ und Tue es in 1 reinigen Sie die Transaktion mit einer Batchdatei einfügen
  • können Sie bitte post eine Antwort, wie Sie vorgeschlagen. Ich Lerne struts2 hibernate, ich konnte nicht die Dinge, die Sie sagte, in diesem Kommentar.
  • ich code geschrieben hier hier klicken als Sie schlug in Ihrem Kommentar, aber es ist nicht das einfügen in meine db, weder ist es zeigt keine Fehler
InformationsquelleAutor beginner | 2013-09-11
Schreibe einen Kommentar