我正在使用 java/hibernate/mysql。我正在创建要保存到数据库的对象列表。有些项目是新的,有些已经在数据库中(我不知道是哪些)。出于这个原因,我正在使用 session.SaveOrUpdate 方法,它可以很好地在必要时插入并在必要时更新。
问题是每次我调用 saveOrUpdate(myObject) 时,我都会看到有一个 select 调用来检查该记录是否已经存在,所以如果我遍历 N 个对象,我有 N - select 查询。有什么办法可以将这些选择集中在一起吗?
此行为是否对性能有重大影响?
谢谢
我得到的日志是:
Hibernate: select price0_.product_id as product1_3_0_, price0_.store_id as
store2_3_0_, price0_.date_updated as date3_3_0_, price0_.price as price3_0_,
price0_.quality as quality3_0_, price0_.update_source as update6_3_0_
from realworld.price price0_ where price0_.product_id=? and price0_.store_id=?
Hibernate: select price0_.product_id as product1_3_0_, price0_.store_id as
store2_3_0_, price0_.date_updated as date3_3_0_, price0_.price as price3_0_,
price0_.quality as quality3_0_, price0_.update_source as update6_3_0_
from realworld.price price0_ where price0_.product_id=? and price0_.store_id=?
Hibernate: insert into realworld.price
(date_updated, price, quality, update_source, product_id, store_id)
values (?, ?, ?, ?, ?, ?)
Hibernate: insert into realworld.price
(date_updated, price, quality, update_source, product_id, store_id)
values (?, ?, ?, ?, ?, ?)
生成这个的代码是:
for (Price price : prices){
HibernateCurrentSession.currentSession().merge(price);
i++;
if ( i % batchsize == 0 ) {
//flush a batch of inserts and release memory:
HibernateCurrentSession.currentSession().flush();
HibernateCurrentSession.currentSession().clear();
}
}
最佳答案
好吧,首先,那些选择和非选择都在同一个事务中执行,因此它们应该工作得非常快。您获得它们的原因可能是这样一个事实,即对于现有条目,Hibernate 可能希望首先检查版本字段(通过将其当前值与数据库中已有的值进行比较),这将在更新之前发出选择。可以找到有关 saveOrUpdate 行为的更多详细信息 here
我认为您没有办法在这种情况下控制或批处理这些选择。您可以通过以下方式提高操作效率:
Session.merge(obj) 将所有这些实例重新附加到当前的 Hibernate session 关于java - Hibernate Session.SaveOrUpdate 方法在每个项目之前调用 select - 有没有办法对这些选择进行批处理?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8152235/
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev
我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我有一个奇怪的问题:我在rvm上安装了rubyonrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(
我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request
这是一道面试题,我没有答对,但还是很好奇怎么解。你有N个人的大家庭,分别是1,2,3,...,N岁。你想给你的大家庭拍张照片。所有的家庭成员都排成一排。“我是家里的friend,建议家庭成员安排如下:”1岁的家庭成员坐在这一排的最左边。每两个坐在一起的家庭成员的年龄相差不得超过2岁。输入:整数N,1≤N≤55。输出:摄影师可以拍摄的照片数量。示例->输入:4,输出:4符合条件的数组:[1,2,3,4][1,2,4,3][1,3,2,4][1,3,4,2]另一个例子:输入:5输出:6符合条件的数组:[1,2,3,4,5][1,2,3,5,4][1,2,4,3,5][1,2,4,5,3][
我已经构建了一些serverspec代码来在多个主机上运行一组测试。问题是当任何测试失败时,测试会在当前主机停止。即使测试失败,我也希望它继续在所有主机上运行。Rakefile:namespace:specdotask:all=>hosts.map{|h|'spec:'+h.split('.')[0]}hosts.eachdo|host|begindesc"Runserverspecto#{host}"RSpec::Core::RakeTask.new(host)do|t|ENV['TARGET_HOST']=hostt.pattern="spec/cfengine3/*_spec.r