mysql配置jdbc


 

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/database?useUnicode=true&characterEncoding=utf8&autoReconnect=true&rewriteBatchedStatements=TRUE
jdbc.username=root
jdbc.password=password

 

特別說明其中的jdbc.url配置:如果你已經升級好了mysql-connector,其中的characterEncoding=utf8可以被自動被識別為utf8mb4(當然也兼容原來的utf8),而autoReconnect配置我強烈建議配上,我之前就是忽略了這個屬性,導致因為緩存緣故,沒有讀取到DB最新配置,導致一直無法使用utf8mb4字符集,多么痛的領悟!!

沒有讓mysql驅動開啟批量執行sql的開關。

怎么開啟呢?在拼裝mysql鏈接的url時,為其加上allowMultiQueries參數,設置為true,如下:

jdbc.jdbcUrl=jdbc:mysql://127.0.0.1:3306/database?useUnicode=true&characterEncoding=utf8&allowMultiQueries=true

 

mysql JDBC URL格式如下: 

jdbc:mysql://[host:port],[host:port].../[database][?參數名1][=參數值1][&參數名2][=參數值2]... 

常用的幾個較為重要的參數: 

參數名稱 參數說明 缺省值 最低版本要求 
user 數據庫用戶名(用於連接數據庫) 所有版本 
passWord 用戶密碼(用於連接數據庫) 所有版本 
useUnicode 是否使用Unicode字符集,如果參數characterEncoding設置為gb2312或gbk,本參數值必須設置為true false 1.1g 
characterEncoding 當useUnicode設置為true時,指定字符編碼。比如可設置為gb2312或gbk false 1.1g 
autoReconnect 當數據庫連接異常中斷時,是否自動重新連接? false 1.1 
autoReconnectForPools 是否使用針對數據庫連接池的重連策略 false 3.1.3 
failOverReadOnly 自動重連成功后,連接是否設置為只讀? true 3.0.12 
maxReconnects autoReconnect設置為true時,重試連接的次數 3 1.1 
initialTimeout autoReconnect設置為true時,兩次重連之間的時間間隔,單位:秒 2 1.1 
connectTimeout 和數據庫服務器建立socket連接時的超時,單位:毫秒。 0表示永不超時,適用於JDK 1.4及更高版本 0 3.0.1 
socketTimeout socket操作(讀寫)超時,單位:毫秒。 0表示永不超時 0 3.0.1 

對應中文環境,通常mysql連接URL可以設置為: 

復制代碼代碼如下:

jdbc:mysql://localhost:3306/test?user=root&password=&useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadOnly=false 


在使用數據庫連接池的情況下,最好設置如下兩個參數: 

復制代碼代碼如下:

autoReconnect=true&failOverReadOnly=false 


需要注意的是,在xml配置文件中,url中的&符號需要轉義成&。比如在tomcat的server.xml中配置數據庫連接池時,mysql jdbc url樣例如下: 

復制代碼代碼如下:

jdbc:mysql://localhost:3306/test?user=root&password=&useUnicode=true&characterEncoding=utf8&autoReconnect=true&failOverReadOnly=false


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM