postgresql JDBC建立连接URL的格式以及getConnection可接受的参数

URL用于标识数据库的位置,通过URL地址告诉JDBC程序连接哪个数据库,postgre jdbc支持的URL的写法为:
  • jdbc:postgresql:database
  • jdbc:postgresql:/
  • jdbc:postgresql://host/database
  • jdbc:postgresql://host/
  • jdbc:postgresql://host:port/database
  • jdbc:postgresql://host:port/
  • jdbc:postgresql://host1:port1,host2:port2/database
  • ipv6地址:jdbc:postgresql://[::1]:5740/accounting
也可以在url中加入其他参数如:?uer=root&password=root&useUnicode=true&characterEncoding=utf8

1、 接受url、与一个持久化属性集对象,相应参入可放入properties中
String url="jdbc:postgresql://localhost:5432/test"
Properties info = new Properties();    //定义Properties对象
info.setProperty("user","root");    //设置Properties对象属性
info.setProperty("password","root");
Connection con = DriverManager.getConnection(url,info);
源码如下:
@CallerSensitive
public static Connection getConnection(String url,
java.util.Properties info) throws SQLExce ption {
return (getConnection(url, info, Reflection.getCallerClass()));
}
2、只接受一个url,用户名密码及其他相关设置都以url参数的形式放入
String url = " jdbc:postgresql ://localhost:5432/test?user=root&password=root ";
Connection con = DriverManager.getConnection(url);
源码如下:
@CallerSensitive
public static Connection getConnection(String url)
throws SQLException {
java.util.Properties info = new java.util.Properties();
return (getConnection(url, info, Reflection.getCallerClass()));
}
3、接受一个url和String类型的user与password,其他参数以url参数形式放入
String url = "jdbc:postgresql://localhost:5432/test";
Connection con = DriverManager.getConnection(url,"root","root");
源码如下:
@CallerSensitive
public static Connection getConnection(String url,
String user, String password) throws SQLException {
java.util.Properties info = new java.util.Properties();
if (user != null) {
info.put("user", user);
}
if (password != null) {
info.put("password", password);
}
return (getConnection(url, info, Reflection.getCallerClass()));
}
  • 8
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PostgreSQLJDBC URL 中设置编码可以通过以下方式实现: 1. 在 JDBC URL 中添加参数:可以在 JDBC URL 中添加 `charset` 参数来指定编码。例如,如果要将编码设置为 UTF-8,可以将 JDBC URL 设置为 `jdbc:postgresql://localhost:5432/mydatabase?charset=utf8`。 2. 使用连接属性:除了在 JDBC URL 中设置编码外,还可以使用连接属性来指定编码。可以使用 `user` 和 `password` 连接属性以及其他自定义连接属性。例如,可以使用以下代码在 Java 中设置编码: ```java Properties props = new Properties(); props.setProperty("user", "myuser"); props.setProperty("password", "mypassword"); props.setProperty("charset", "UTF8"); Connection conn = DriverManager.getConnection("jdbc:postgresql://localhost:5432/mydatabase", props); ``` 3. 使用连接参数:如果不希望将编码硬编码到代码中,还可以在获取连接时使用连接参数来指定编码。例如,可以使用以下代码在 Java 中设置编码: ```java String url = "jdbc:postgresql://localhost:5432/mydatabase"; String user = "myuser"; String password = "mypassword"; Properties props = new Properties(); props.setProperty("user", user); props.setProperty("password", password); Connection conn = DriverManager.getConnection(url, props); // 设置编码 conn.setClientInfo("charset", "UTF8"); ``` 无论使用哪种方式,确保将编码与 PostgreSQL 数据库的实际配置相匹配。在设置编码时,应注意遵循 PostgreSQL 支持的编码列表,并根据实际情况选择适合的编码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值