Skip to content

Instantly share code, notes, and snippets.

@jasoet
Created October 6, 2012 04:16
Show Gist options
  • Save jasoet/3843797 to your computer and use it in GitHub Desktop.
Save jasoet/3843797 to your computer and use it in GitHub Desktop.
Database Connection Singleton
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package org.secondstack.db;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
/**
*
* @author Deny Prasetyo
*/
public class DatabaseConnection {
private static DatabaseConnection instance;
private Connection connection;
private String url = "jdbc:postgresql://localhost:5432/jdbc";
private String username = "root";
private String password = "localhost";
private DatabaseConnection() throws SQLException {
try {
Class.forName("org.postgresql.Driver");
this.connection = DriverManager.getConnection(url, username, password);
} catch (ClassNotFoundException ex) {
System.out.println("Database Connection Creation Failed : " + ex.getMessage());
}
}
public Connection getConnection() {
return connection;
}
public static DatabaseConnection getInstance() throws SQLException {
if (instance == null) {
instance = new DatabaseConnection();
} else if (instance.getConnection().isClosed()) {
instance = new DatabaseConnection();
}
return instance;
}
}
@technical-mindset
Copy link

you can create an other method public DatabaseConnection createCon(String url, uName, pswrd){}

@technical-mindset
Copy link

is there any way not to hardcode URL, username, and password?

So now which method should I call to get the data base connection ?

DBConnection db = DBConnection.getInstance();
Connection conn = db.getConnection();

@donyor-02
Copy link

Thanks, it helped me.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment