草庐IT

nested-transactions

全部标签

java - 如何在@Transactional 方法中手动强制提交?

这个问题在这里已经有了答案:Howtoflushdataintodbinsideactivespringtransaction?(4个回答)关闭7年前。我正在使用Spring/Spring-data-JPA,发现自己需要在单元测试中手动强制提交。我的用例是我正在做一个多线程测试,其中我必须使用在线程产生之前持久化的数据。不幸的是,鉴于测试是在@Transactional事务中运行的,即使是flush也无法让生成的线程访问它。@TransactionalpublicvoidtestAddAttachment()throwsException{finalContractc1=contrac

java - 如何将 @Transactional 与 Spring Data 一起使用?

我刚开始从事Spring-data、Hibernate、MySQL、JPA项目。我切换到spring-data这样我就不必担心手动创建查询了。我注意到,当您使用spring-data时,不需要使用@Transactional,因为我也尝试了没有注释的查询。我应该/不应该使用@Transactional注释有什么具体原因吗?作品:@TransactionalpublicListlistStudentsBySchool(longid){returnrepository.findByClasses_School_Id(id);}同样有效:publicListlistStudentsBySch

java - 如何将 @Transactional 与 Spring Data 一起使用?

我刚开始从事Spring-data、Hibernate、MySQL、JPA项目。我切换到spring-data这样我就不必担心手动创建查询了。我注意到,当您使用spring-data时,不需要使用@Transactional,因为我也尝试了没有注释的查询。我应该/不应该使用@Transactional注释有什么具体原因吗?作品:@TransactionalpublicListlistStudentsBySchool(longid){returnrepository.findByClasses_School_Id(id);}同样有效:publicListlistStudentsBySch

php - 在 Laravel 4 DB::transaction() 上传递多个参数?

我正在尝试:$iddocente='1';$idcurso='2';DB::transaction(function(){DB::table('users')->insert(array('docente'=>$iddocente,'curso'=>$idcurso));});但是没有工作。请帮助我。 最佳答案 use关键字就是您想要的。DB::transaction(function()use($iddocente,$idcurso){ 关于php-在Laravel4DB::trans

php - 组合 : avoiding multiple nested foreach

当你需要检查/拥有数组元素的组合时,如何避免嵌套foreach?示例代码:$as=array($optionA1,$optionA2)$bs=array($optionB1,$optionB2)$cs=array($optionC1,$optionC2)foreach($asas$a){foreach($bsas$b){foreach($csas$c){$result=$this->method($a,$b,$c);if($result)etc}}}有人有可以避免嵌套的替代方法吗? 最佳答案 您可以编写自己的Iterator类来实现

PHP 和 NLP : Nested parenthesis (parser output) to array?

想要将带有嵌套括号的文本转换为嵌套数组。以下是NLP解析器的示例输出:(TOP(S(NP(PRPI))(VP(VBPlove)(NP(NP(DTa)(JJbig)(NNbed))(PP(INof)(NP(NNSroses)))))(..)))(原创:我喜欢一大片玫瑰。)想把它变成一个嵌套数组,所以它看起来像这样TOPSNPPRPIVPVBPLove等等找到这个phpcurlybracesintoarray但这不是嵌套数组 最佳答案 代码解释:current=array();$this->stack=array();$this->st

PHP 和正则表达式 : Split a string by commas that are not inside brackets (and also nested brackets)

两天前,我开始研究代码解析器,但遇到了困难。如何用不在括号内的逗号分隔字符串,让我告诉你我的意思:我要解析这个字符串:one,two,three,(four,(five,six),(ten)),seven我想得到这个结果:array("one";"two";"three";"(four,(five,six),(ten))";"seven")但我得到的是:array("one";"two";"three";"(four";"(five";"six)";"(ten))";"seven")我如何在PHPRegEx中执行此操作。提前致谢! 最佳答案

php - Laravel DB::transaction() 返回值

这是我第一次使用DB::transaction()但如果事务失败或成功,它究竟如何工作?在下面的示例中,我是否必须手动分配一个值以返回true,或者如果它失败,该方法将返回false或完全退出事务(因此跳过其余代码)?文档对此帮助不大。useException;useDB;try{$success=DB::transaction(function(){//Runsomequeries});print_r($success);}catch(Exception$e){echo'Uhoh.';}解决方案我为可能想知道的其他人写下了这个解决方案。因为我更关心根据查询的成功返回一个bool值,经

php - 如何修复 laravel 5.2 这个错误 "Maximum function nesting level of ' 10 0' reached, aborting!"?

我正在尝试从Laravel自动生成的登录/注册身份验证模块中重置密码。当我点击重置按钮时,它给我这个错误ClassLoader.php第344行中的FatalErrorException:已达到“100”的最大函数嵌套级别,正在中止!我搜索了一下,找到了一个已接受的answer,但是这个答案对我来说不起作用,我已经按照说明操作了。谁能指导我这是laravel错误还是wamp?以及如何修复它。我想欣赏。 最佳答案 这通常是因为您通过$with属性同时从两个模型加载关系。假设一个Category有许多Product并且一个Product

mysql - MySQL中是否允许嵌套事务?

MySQL是否允许使用嵌套事务? 最佳答案 不,但是InnoDB支持SAVEPOINTS。您可以执行以下操作:CREATETABLEt_test(idINTNOTNULLPRIMARYKEY)ENGINE=InnoDB;STARTTRANSACTION;INSERTINTOt_testVALUES(1);SELECT*FROMt_test;id---1SAVEPOINTtran2;INSERTINTOt_testVALUES(2);SELECT*FROMt_test;id---12ROLLBACKTOtran2;SELECT*FRO