Skip to main content

Using JTable

JTable is the component which helps us to display the multi columned data. This post is about fetching database data and displaying it using JTable.
First we will design our Frame
public class MyFrame extends JFrame
{
 private JTable table;
 private JScrollPane jsp;
 public MyFrame()
 {
  super("MyFrame");
  setSize(400,400);
  setDefaultCloseOperation(EXIT_ON_CLOSE);
  setLocationRelativeTo(null);
  initMyFrame();
  setVisible(true);
 }
 private void initMyFrame()
 {
  setLayout(new BorderLayout());
  table=new JTable();
  jsp=new JScrollPane(table);
  add(jsp,BorderLayout.CENTER);


  // database connection and remaining code will go here
 }
 public static void main(String args[])
 {
  new MyFrame();
 }
}



Now we are ready with our frame which contains JTable, but our table does not contains any data.
So we need to establish the database connection, for this I am using PostgreSQL as backend.
Following code is for connecting to database
try
{
 Class.forName("org.postgresql.Driver");
 Connection con=DriverManager.getConnection("jdbc:postgresql://localhost:5432/mydatabase","postgres","postgres");
}catch(Exception e)
{
 System.out.println("Failed to connect to database");
 e.printStackTrace();
}
Now we have established the database connection and its time to fetch data from database and add it to our JTable
try
{
 Statement statement=con.createStatement();
 ResultSet rs=statement.executeQuery("select * from mytable");


 Vector cols=new Vector();
 cols.add("Id");
 cols.add("Name");


 Vector data=new Vector();
  while(rs.next())
  {
   Vector v=new Vector();
   v.add(rs.getInt(1));
   v.add(rs.getString(2));
   data.add(v);
  }


 table.setModel(new DefaultTableModel(data,cols));
 table.addNotify();
}catch(Exception e)
{
 e.printStackTrace();
}
In above code as we are using dynamic data for JTable so we are using Vectors, while using Vector first vector
Vector cols=new Vector();
This vector is for the headers which will be displayed in JTable, it can contain only Strings and the second vector
Vector data=new Vector();
Its for data in JTable which can contains collection only not just Strings, and that is the reason why we are adding Vector v to this data vector.
DefaultTableModel is the default table model provided by Java for setting new table model to JTable.
Method addNotify is important while adding or removing data from TableModel, it tells JTable that data has been modified and its time to refresh.

Comments

Popular posts from this blog

Encrypt Decrypt data using AES in Java

AES stands for Advanced Encryption Standard. AES is an Symmetric Key Algorithm, that means key used for encrypting the data, same key will be used for  decryption of  the encrypted data. This algorithm supplants DES algorithm. This post shows how to use AES algorithm in Java to encrypt and decrypt data. Encrypting Data- import java.security.GeneralSecurityException; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; public class AESTest1 { public static void main(String[] args) throws GeneralSecurityException { KeyGenerator keyGenerator = KeyGenerator.getInstance("AES"); keyGenerator.init(128); SecretKey key = keyGenerator.generateKey(); Cipher cipher = Cipher.getInstance("AES"); cipher.init(Cipher.ENCRYPT_MODE, key); byte encryptedData[] = cipher.doFinal(args[0].getBytes()); } } In above example we have used KeyGenerator class, which generates key for encrypting data, as we are using...

Java Tools Plugin for Notepad++ Update

This post and the plugin is outdated. Please use plugin from  this link  which is updated and allows customization of shortcut key mappings and much more . This post is regarding the update for Notepad++ plugin which I wrote to use compile and execute Java programs from the Notepad++ editor itself. I have updated the plugin so that user can customize the shortcut keys assigned for compiling and executing the programs. Following image shows simple Settings dialog where you can customize the shortcut keys mapping. Although user can customize the keys but to apply them Notepad++ must be restarted. Well, I tried but in Notepad++, there is no way to change mapping after initialization process of plugin.. Click here to download the plugin.

Java Tools Plugin for Notepad++

This post and the plugin is outdated. Please use plugin from this link which is updated and allows customization of shortcut key mappings and much more . Notepad++ is a great free editor. I like notepad++ because its a light weight editor and loads instantly. I use notepad++ for editing many files everyday. One plugin I always wanted was a plugin which lets me compile my java files and execute them from editor itself, but I couldn't find it so I wrote a myself. This plugin can be downloaded from  this link . I am working on this plugin to make it more effective, so that if user have more than one installations of JDK or JRE then user should be able to choose which one to use etc. This is a simple plugin which has two commands- Compile - compiles a java file. Run - executes a java file. For using this plugin Java must be installed on the system.