The better way is to get a DataSource
object. Either by using JNDI to look one up that your app server container already configured for you:
Context context = new InitialContext();
DataSource dataSource = (DataSource) context.lookup("java:comp/env/jdbc/myDB");
… or by instantiating and configuring one from your database driver directly, such as com.mysql.cj.jdbc.MysqlDataSource
(see documentation):
MysqlDataSource dataSource = new MysqlDataSource();
dataSource.setUser("scott");
dataSource.setPassword("tiger");
dataSource.setServerName("myDBHost.example.org");
… and then obtain connections from it, same as above:
Connection conn = dataSource.getConnection();
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT ID FROM USERS");
…
rs.close();
stmt.close();
conn.close();
In modern Java, use try-with-resources syntax to automatically close JDBC resources (now AutoCloseable
).
try (
Connection conn = dataSource.getConnection();
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT ID FROM USERS");
) {
…
}
Center one and right/left align other flexbox element
How to store objects in HTML5 localStorage/sessionStorage
How do I modify the URL without reloading the page?
Why doesnt percentage height work in HTML/CSS?
How can I validate an email address in JavaScript?
How can I vertically center a div element for all browsers using CSS?
How can I horizontally center an element?
Get top n records for each group of grouped results
Syntax error due to using a reserved word as a table or column name in MySQL
When to use single quotes, double quotes, and backticks in MySQL