How to import the Excel file into Oracle Table Using Java
Please find the below code to import the Excel File into the Oracle Table
/*
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package test;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
/**
*
* @author Aravind
*/
public class App {
public static void main(String args[]){
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection con=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","system","system");
System.out.println("");
con.setAutoCommit(false);
PreparedStatement pstm = null;
String destDir="C:\\Users\\Desktop\\test.xlsx";
System.out.println("destDir==> "+destDir);
XSSFWorkbook workBook = new XSSFWorkbook(destDir);
XSSFSheet sheet = workBook.getSheetAt(0);
int totalRows = sheet.getPhysicalNumberOfRows();
System.out.println("total no of rows >>>>"+totalRows);
Row row;
for (int i = 1; i <= sheet.getLastRowNum(); i++) {
row = (Row) sheet.getRow(i);
String name = row.getCell(0).getStringCellValue();
String add = row.getCell(1).getStringCellValue();
int contact = (int) row.getCell(2).getNumericCellValue();
String email = row.getCell(3).getStringCellValue();
System.out.println(name+":My EMAIL address is "+email);
String sql = "INSERT INTO TEST_EMPLOYEE (NAME, ADDRESS, CONTACT, EMAIL) VALUES('" + name + "','" + add + "'," + contact + ",'" + email + "')";
pstm = (PreparedStatement) con.prepareStatement(sql);
pstm.execute();
System.out.println("Import rows " + i);
}
con.commit();
pstm.close();
con.close();
System.out.println("Success import excel to my table");
}
catch(Exception e){
}
}
}
* To change this license header, choose License Headers in Project Properties.
* To change this template file, choose Tools | Templates
* and open the template in the editor.
*/
package test;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
/**
*
* @author Aravind
*/
public class App {
public static void main(String args[]){
try {
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection con=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","system","system");
System.out.println("");
con.setAutoCommit(false);
PreparedStatement pstm = null;
String destDir="C:\\Users\\Desktop\\test.xlsx";
System.out.println("destDir==> "+destDir);
XSSFWorkbook workBook = new XSSFWorkbook(destDir);
XSSFSheet sheet = workBook.getSheetAt(0);
int totalRows = sheet.getPhysicalNumberOfRows();
System.out.println("total no of rows >>>>"+totalRows);
Row row;
for (int i = 1; i <= sheet.getLastRowNum(); i++) {
row = (Row) sheet.getRow(i);
String name = row.getCell(0).getStringCellValue();
String add = row.getCell(1).getStringCellValue();
int contact = (int) row.getCell(2).getNumericCellValue();
String email = row.getCell(3).getStringCellValue();
System.out.println(name+":My EMAIL address is "+email);
String sql = "INSERT INTO TEST_EMPLOYEE (NAME, ADDRESS, CONTACT, EMAIL) VALUES('" + name + "','" + add + "'," + contact + ",'" + email + "')";
pstm = (PreparedStatement) con.prepareStatement(sql);
pstm.execute();
System.out.println("Import rows " + i);
}
con.commit();
pstm.close();
con.close();
System.out.println("Success import excel to my table");
}
catch(Exception e){
}
}
}
Hi Aravind ,While i am running this code i am getting following error can you please tell me what are the poi files required for this please send me if any changes required k.eswar456@gmail.com
ReplyDeletedestDir==> H:\data.xlsx
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/xmlbeans/XmlException
at upload.App.main(App.java:24)
Caused by: java.lang.ClassNotFoundException: org.apache.xmlbeans.XmlException
at java.net.URLClassLoader.findClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
at java.lang.ClassLoader.loadClass(Unknown Source)
... 1 more
Hi Eswar,
DeleteYou have not added the sufficient jars that are required that's what you are getting this exception.For the error that you have mentioned you have to add the xmlbeans-2.6.0.jar
Thank you soo much Aravind.I want to do same task in JSP or Servlet,can you suggest me how to change change this code for servlet or Jsp.
DeleteHi Aravind ,While i am running this code i am getting following error can you please tell me what are the poi files required for this please send me if any changes required anitha.payyavula1997@gmail.com
ReplyDeleteHi Could you please update what is the error that you are facing.So that I can help you accordingly
DeleteI want to say thanks to you. Most importantly I have bookmarked your site for future updates.
ReplyDeleteClass 2 Digital Signature in Delhi
Pretty great post. I simply stumbled upon your weblog and wanted to say that I have really loved browsing your blog posts.
ReplyDeleteBest Digital Signature Provider in Delhi
The blog is absolutely fantastic. Lots of great information and inspiration, both of which we all need. Thanks for such a continuous great postings.
ReplyDeleteClass 2 Digital Signature in Delhi