Skip to main content

Store file into table by using JDBC with example

To store large data files or text files into database table, we will use CLOB (Charecter Large Object) datatype of SQL. By using CLOB it is possible to save entire text book or a file or resume into a column of data table. If your using MySQL database instead of CLOB use LONGTEXT to save file into datatable.

For saving files into a data table, we need to create one table which will contains a column type as CLOB to store files. Here, is the query to create a data table.

1
2
3
4
create table myfiles(
file_id int(10),
file_name varchar(30),
file_type LONGTEXT);

Once table creation completes, these table contains the 3 columns one is file_id represents the file id, file_name represents the name of the file and finally file_type will get save entire file into the table column.

Now, we will move to write a JDBC program which will saves the file into the newly creating table. Here is the JDBC program,

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
package com.javatbrains.jdbc;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;

public class StoreTextFile {

   static Connection con = null;
   static PreparedStatement pst = null;

   public static void main(String[] args) throws FileNotFoundException {
     try {
       // Load file by using File
       File myFile = new File("D:/myFile.txt");

       // To read data from file object myFile, Connect it to a FileReader.
       FileReader reader = new FileReader(myFile);

       // Register Driver
       DriverManager.registerDriver(new com.mysql.jdbc.Driver());

       // Establish Connection
       con = DriverManager.getConnection( "jdbc:mysql://localhost:3306/test?user=root&password=root");

       // Create a preparestatement
       pst = con.prepareStatement( "Insert into myfiles (file_id, file_name, file_type) values(?,?,?)");

       // Set values to PST
       pst.setInt(1, 1);
       pst.setString(2, "MyFile");
       pst.setCharacterStream(3, reader, (int) myFile.length());

       // Execute the PreapreStatement
       pst.execute();

       System.out.println("Inserted Successfully");
     } catch (SQLException e) {
        e.printStackTrace();
     } finally {
        try {
          con.close();
          pst.close();
        } catch (SQLException e) {
          e.printStackTrace();
        }
     }
   }
 }

In the above will stores an text file content into your MySQL datatable by reading the file. Here are the steps to create the JDBC program which will store the text file into MySQL database table.
  • We need to load text file by using the File class and we will read the file instance by using the FileReader class.
  • Then we need to register the Driver by using the registerDriver() method which will present under the DriverManager class.
  • We need to create connection by using the getConnection() method which will present under the DriverManager class by providing the database information into String format.
  • Create PrepareStatement instance and pass insert query into that.
  • Setup the inserting records to PrepareStatement instance by index wise.
  • For storing the text file into table, we used method as setCharecterStream() method and pass the FileReader instance and length of the file.
  • Finally execute the PrepareStatement by using the execute() method.
Do you know?  

Popular posts from this blog

Multithreading in java with example

Multithreading  is one of the most important concept in core java. In this article we will learn what is multithreading? , what is the use of it? and What is the use of Synchronization and when to use it?  with detailed examples. At a time, two or more threads are accessing the same object is called as Multithreading  in Java .  First, we will create two threads for two objects. It is also possible to run two or more threads on a single class object. In this case, there is a possibility to get unreliable results. If the two threads are perform same task, then they need same object to be executed each time. For your better understanding, take an example of any reservations like, railway, movie ticket booking,etc. Let us think only one berth is available in a train and two passengers are asking for that berth. The first person has sent a request to allocate that ticket/berth to him. At the same time, the second person also sent a request to allocate that ...

Git installation for AngularJS 2 in Windows 10

Download Git latest version from https://git-scm.com/downloads or you click on the below link to download directly for windows https://git-scm.com/download/win . Once download completes, click on executable file to start installation process and choose Yes to allow the software installation in windows 10. Click on Next button to continue further installation. Browse the isntallation directory and click on Next button to continue. Select the list of components which you want to be installed and click on Next button to proced further installation. Type the shortcut name for Start menu and click on Next button. Select how you want to use the Git and click on Next button. For Windows no need to change anything, let it be the default one. Choose the Use the OpenSSL library and click on Next button. Select how should Git treat line ending in text files and click on Next button. Select which terminal emulator to use with Git and click on Next button. Configure extr...

JNDI configuration for Tomcat 9 with Oracle

In this article, I am going to place the required source code to get data from the table by using the JNDI configuration. Below are the environment details that I have configured currently. Windows - 7 Oracle - 10g Tomcat - 9 JDK - 8 Eclipse Oxygen Ojdbc6 jar required First, we need to create the Dynamic Web Project. If you don't know how to do <Click Here>. I have faced a lot of issues before getting the output like 405, No driver class to load, etc. I am using JSP & Servlets in the current explanation. Before started writing the application logic, we need to do the below configuration in the installed tomcat directory. Place OJDBC6.jar in the Tomcat LIB directory. Add this Resource under <GlobalNamingResources> in Server.xml file which is present under the conf directory in Tomcat. < Resource name = "jdbc/myoracle" global= "jdbc/myoracle" auth = "Container" type= "javax.sql.DataSource" driverClass...