用PreparedStatement 插入数据,小数丢失

z_j 2009-03-12 03:30:05
数据库是:Sybase12.5.3
jdbc驱动是:jconn3.jar
程序片段如下:

// create table t2 ( id int not null, d numeric(10,6) null, primary key(id))
PreparedStatement ps =con.prepareStatement("insert into t2( id, d) values (?,?)");
ps.setObject( 1, new Integer(3), Types.INTEGER);
ps.setObject( 2, new Double(0.56), Types.NUMERIC);
ps.execute();
ps.close();



执行后查询,得到d是0.000000
无法理解


...全文
247 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
z_j 2009-03-12
  • 打赏
  • 举报
回复
问题解决了,改成 ps.setObject( 2, new Double(0.56), Types.NUMERIC,6);即对于Numeric和decimal 必须指定精度

原来程序是在用jtds做驱动连SQL Server 的, 没有问题,换成Sybase就有这个问题。不知该说是Sybase的驱动严谨,还是该说jtds强。

一直对Sybase没有太多好感,这下更没好感了。


感谢楼上的热心,送分了

WWWWA 2009-03-12
  • 打赏
  • 举报
回复
修改Types.NUMERIC试试

2,596

社区成员

发帖
与我相关
我的任务
社区描述
Sybase相关技术讨论区
社区管理员
  • Sybase社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧