在java程序与数据库连接的编程中,mysql jdbc url格式如下:
jdbc:mysql://[host:port],[host:port].../[database][?参数名1][=参数值1][&参数名2][=参数值2]...
如:jdbc:mysql://localhost:3306/test?user=test&password=123456
刚好最近遇到一个数据库连接参数带来的问题,所以罗列一下几个较为重要的参数:
示例代码:jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8
JDBC使用socket与数据库连接,数据库并不对应用与数据库间的连接超时进行处理,JDBC的socket timeout在数据库被突然停掉或是发生网络错误(由于设备故障等原因)时十分重要。由于TCP/IP的结构原因,socket没有办法探测到网络错误,因此应用也无法主动发现数据库连接断开。如果没有设置socket timeout的话,应用在数据库返回结果前会无期限地等下去,这种连接被称为dead connection。为了避免dead connections,socket必须要有超时配置。socket timeout可以通过JDBC设置,socket timeout能够避免应用在发生网络错误时产生无休止等待的情况,缩短服务失效的时间。
此参数为jdbc的过期时间设置,与mysql-server的过期时间不是同一参数。
示例代码:jdbc:mysql://localhost:3306/test?connectTimeout=60000&socketTimeout=60000
以上为整理的较为常用的参数,如果感兴趣可以去官网查阅一下其他参数。