PandaLib/pandalib-db/src/main/java/fr/pandacube/lib/db/DBConnection.java

62 lines
1.8 KiB
Java
Raw Normal View History

package fr.pandacube.lib.db;
2016-07-08 11:33:22 +02:00
import java.sql.Connection;
import java.sql.SQLException;
2022-08-01 22:21:04 +02:00
import org.apache.commons.dbcp2.BasicDataSource;
2020-02-02 16:36:43 +01:00
2022-08-01 22:21:04 +02:00
/**
* A class holding the connection to the database.
*/
2016-07-08 11:33:22 +02:00
public class DBConnection {
2022-08-01 22:21:04 +02:00
private final BasicDataSource connSource;
/**
* Create a new connection with the provided settings.
* @param host the MySQL DB host.
* @param port the MySQL DB port.
* @param dbname the MySQL DB name.
* @param login the login/username.
* @param password the password.
*/
public DBConnection(String host, int port, String dbname, String login, String password) {
this("jdbc:mysql://" + host + ":" + port + "/" + dbname
+ "?useUnicode=true"
+ "&sslMode=DISABLED"
+ "&allowPublicKeyRetrieval=true"
2022-08-01 22:21:04 +02:00
+ "&characterEncoding=utf8"
+ "&characterSetResults=utf8"
+ "&character_set_server=utf8mb4"
+ "&character_set_connection=utf8mb4",
login, password);
}
2022-08-01 22:21:04 +02:00
/**
* Create a new connection with the provided settings.
* @param url the JDBC URL.
* @param login the login/username.
* @param password the password.
*/
public DBConnection(String url, String login, String password) {
connSource = new BasicDataSource();
connSource.setUrl(url);
connSource.setUsername(login);
connSource.setPassword(password);
}
2022-08-01 22:21:04 +02:00
/* package */ Connection getConnection() throws SQLException {
return connSource.getConnection();
}
2022-08-01 22:21:04 +02:00
/**
* Closes the connection.
*/
public void close() {
try {
connSource.close();
} catch (SQLException ignored) {}
}
2016-07-08 11:33:22 +02:00
}