国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

java - Spring-data-jpa 剛保存的信息查找不到

瀏覽:82日期:2023-11-07 09:04:21

問(wèn)題描述

1 后臺(tái)結(jié)構(gòu)

后臺(tái)的結(jié)構(gòu)是 SpringMVC, Spring, jpa(HibernateJpaDialect),DataSource(c3p0), Mysql(InnoBDB), transactionManager(JpaTransactionManager)。

2 問(wèn)題環(huán)境

@Transactional(value = 'transactionManager', isolation = Isolation.READ_UNCOMMITTED) public Object addScenicSpot(int tourGuideID, String jsonStr) {Djd_js entity = new Djd_js();try{ _setEntity(entity, jsonStr); entity.setDaoyouID(tourGuideID); jdjsDao.save(entity); int spotId = entity.getId(); //添加信息到消息隊(duì)列中try { Sender sender = new SenderImpl(); sender.getGPSFromBaiduAPI('jdjs', spotId, entity.getDizhi());} catch (InterruptedException e) { return false;} return spotId;}catch (Exception e){ return false;} }

以上是保存的部分,并把得到的 ID 發(fā)送到消息隊(duì)列中,下邊是消息隊(duì)列的處理部分

public boolean updateLngAndLat(MessageVo messageVo) {System.out.println('CreateTime--------'+messageVo.getCreateDate());System.out.println('Address--------'+messageVo.getContent());System.out.println('Id--------'+messageVo.getId());Djd_js entity = jdjsDao.findOne(messageVo.getId());System.out.println('entity-Address--------'+entity.getDizhi());、、運(yùn)行到這里就直接卡住了,如果注釋掉查詢,其他的調(diào)用皆正常。Map<String, Object> result = LngAndLatUtil.getLngAndLat(((MessageVo) messageVo).getContent());System.out.println('result--------'+(int)result.get('result'));if (1 == (int)result.get('result')){ entity.setJingdu(Double.valueOf(result.get('lng').toString())); entity.setWeidu(Double.valueOf(result.get('lat').toString())); System.out.println('message-------------------------------'+'lng:'+Double.valueOf(result.get('lng').toString())+', lat:'+Double.valueOf(result.get('lat').toString())); jdjsDao.updateLngAndLatBySenciSpotID(messageVo.getId(), (Double) result.get('lng'), (Double) result.get('lat'));}else { System.out.println('message-------------------------------False');}return false; }3 問(wèn)題描述

前端調(diào)用 addScenicSpot() 方法,會(huì)將信息保存到數(shù)據(jù)庫(kù)中,然后將保存之后的數(shù)據(jù)控中的ID發(fā)送到消息隊(duì)列中,然后訂閱者處理隊(duì)列中的信息,根據(jù) ID 查詢到剛保存的信息,然后調(diào)用外部接口查詢到經(jīng)緯度,并將得到的經(jīng)緯度存儲(chǔ)到數(shù)據(jù)庫(kù)中。現(xiàn)在的問(wèn)題是,保存信息正常,但是到了訂閱者處理這邊,根據(jù)得到的 ID 查找不到保存的信息。

4 猜測(cè)問(wèn)題所在

產(chǎn)生bug的原因是spring事務(wù)提交晚于消息隊(duì)列的生產(chǎn)消息,導(dǎo)致消息隊(duì)列消費(fèi)消息時(shí)獲取到的數(shù)據(jù)不正確,靈感來(lái)自于這里:http://www.cnblogs.com/taocon...

問(wèn)題解答

回答1:

同步調(diào)用,改為異步調(diào)用?

@AsyncgetGPSFromBaiduAPI

回答2:

已經(jīng)解決了問(wèn)題了,應(yīng)用的這里的方法:http://www.cnblogs.com/taocon...

標(biāo)簽: java
相關(guān)文章:
主站蜘蛛池模板: 崇明县| 永和县| 宣武区| 鄂托克前旗| 五指山市| 阿合奇县| 子洲县| 彩票| 四会市| 沁阳市| 丹巴县| 全南县| 绥宁县| 定襄县| 台北市| 梅河口市| 哈尔滨市| 余庆县| 永安市| 阿鲁科尔沁旗| 开远市| 桂东县| 仙桃市| 苏尼特右旗| 高安市| 邯郸市| 乌拉特中旗| 永胜县| 那曲县| 台湾省| 从化市| 顺义区| 汝阳县| 黑水县| 白城市| 泽普县| 芮城县| 高邑县| 北海市| 河池市| 深水埗区|