PreparedStatement/Statement处理insert update等操作时乱码,以及URL

本文介绍了一种解决PreparedStatement在存入数据库时出现乱码的方法。问题出现在未正确指定字符编码的情况下,通过调整JDBC URL参数 characterEncoding=utf8 解决了问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文:

在顶目中无意中碰到PreparedStatement 在存DB时出现乱码,困扰了好久终于解决问题
  

  问题代码如下

 1     ps = con.prepareStatement(INSERT_SQL);
 2 
 3    ps.setString(1, username);
 4 
 5    ps.setLong(2, messageID);
 6 
 7    ps.setString(3, new java.util.Date());
 8 
 9    ps.setInt(4, msgXML.Length());
10 
11    ps.setString(5, “中文内容”);
12 
13    ps.executeUpdate();    

  debug时可以看到在 ps.executeUpdate(); 行 ps 中的 “中文内容” 变成 ????

  原因是设置Datasource 的Driver 时Jdbc.Url=Jdbc:mysql://192.168.12.22:3306/Ts 没有指定编码

  可以按如下修改

  Jdbc.Url=Jdbc:mysql://192.168.12.22:3306/Ts?characterEncoding=utf8

  问题解决

原文完。

  当然,jdbc中也可以:

jdbc提供如下方法:  

1 conn = DriverManager.getConnection(url, username, password);

显然url其实是一个就是资源定位符,所以也可以像HTTP协议那样传递参数。

所以jdbc提供了如下方法:

1 String url = "jdbc:mysql://host/dbname?username=ding&password=ding&characterEncoding=utf8";
2 conn = DriverManager.getConnection(url);

其实大部分的同学协议都可以向http协议传递参数,这里的叫jdbc协议。jdbc协议主要靠TCP协议实现。

既然URL表示一个资源地址,那么我们就可以使用jdk的URL,URLConnection,URI等类获取资源。

 

转载于:https://www.cnblogs.com/skimoon/p/3659358.html

package DaoUntil; import java.sql.*; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; public class DaoUntil01 { private static final String DRIVER_CLASS = "com.mysql.cj.jdbc.Driver"; private static final String URL = "jdbc:mysql://localhost:3306/jdbctest?characterEncoding=UTF-8&uesSSL=false"; private static final String USERNAME = "root"; private static final String PASSWORD = "root"; //共享驱动 static { try { Class.forName(DRIVER_CLASS); } catch (ClassNotFoundException e) { e.printStackTrace(); } } public static Connection getConnection() throws SQLException { return DriverManager.getConnection(URL,USERNAME,PASSWORD); } public static int DML(String sql,Object... data){ Connection conn = null; PreparedStatement ps = null; try { conn = DaoUntil01.getConnection(); ps = conn.prepareStatement(sql); for (int i = 0; i < data.length; i++) { ps.setObject(i+1,data[i]); } int i = ps.executeUpdate(); return i; } catch (SQLException throwables) { throwables.printStackTrace(); }finally { try { if (conn != null) conn.close(); } catch (SQLException throwables) { throwables.printStackTrace(); }finally { try { if (ps != null) conn.close(); } catch (SQLException throwables) { throwables.printStackTrace(); } } } return 0; } public static List<Map<String, Object>> DQL(String sql , Object... data){ Connection conn = null; PreparedStatement ps = null; try { conn = DaoUntil01.getConnection(); ps = conn.prepareStatement(sql); for (int i = 0; i < data.length;
03-20
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值