xhs1990 2016-07-12 01:17 采纳率: 0%
浏览 1243
已结题

JDBC executeQuery 无法获取到Mysql最新的数据???

情况是这样的:创建了多个Connection,connectionA对数据库的修改,connectionB无法看到。创建的connection没有开启事务的自动提价。

步骤是:connectionA对数据库进行了修改(可以在数据库中,明确看到,数据确实修改了),然后connectionB执行了一个executeQuery动作,但是得到的结果集居然没有反映刚才connetionA修改的结果。
prePareStatment或者createStatement时都是采用的默认方式。

这个现象的解决可以通过以下两种方式:
(1)connectionB每次查询之前,强制提交一次事务,然后在查询
(2):connectionB创建Statement时,指定ResultSet.Type_Scroll_sensitive;
上面两种方式试过都可以解决。
现在想知道为什么会出现这种原因,connectionB为什么看不到数据库中的更改(此时还没有通过查询产生ResultSet呢)?

这种现象在Mysql和sqlite数据中,都出现了,其他数据库暂时还没试过,我用的jdk是1.8版本,Mysql是5.6版本的。修改

  • 写回答

1条回答 默认 最新

  • xhs1990 2016-07-12 01:18
    关注

    原谅,不怎么用,所以没有什么金币~~~~~

    评论

报告相同问题?

悬赏问题

  • ¥20 指导如何跑通以下两个Github代码
  • ¥15 大家知道这个后备文件怎么删吗,为啥这些文件我只看到一份,没有后备呀
  • ¥15 C++为什么这个代码没报错运行不出来啊
  • ¥15 一道ban了很多东西的pyjail题
  • ¥15 关于#r语言#的问题:如何将生成的四幅图排在一起,且对变量的赋值进行更改,让组合的图漂亮、美观@(相关搜索:森林图)
  • ¥15 C++识别堆叠物体异常
  • ¥15 微软硬件驱动认证账号申请
  • ¥15 GPT写作提示指令词
  • ¥20 根据动态演化博弈支付矩阵完成复制动态方程求解和演化相图分析等
  • ¥15 华为超融合部署环境下RedHat虚拟机分区扩容问题