参数list对象结果如何使用mybatis批量插入数据

使用mybatis oracle,当传来的参数是list对象结果集,如何批量插入数据

sql

3个回答

图片说明


<!--
WARNING - @mbggenerated
This element is automatically generated by MyBatis Generator, do not modify.
-->

<!--
表的序列查询
-->
select TABLE_SEQ.NEXTVAL from DUAL

</selectKey>
insert into TABLE
 ( ID,
    NAME,
    PASSWORD,
    AGE,
    CREATETIME)
    select tableseq.NEXTVAL,a.* from (
    <foreach collection="list" item="item" index="index"
        separator="union all">
        select
        #{item.name,jdbcType=VARCHAR} as name,
        #{item.password,jdbcType=VARCHAR} as password,#{item.age,jdbcType=BECIMAL} as age,#{item.createTime,jdbcType=TIMESTAMP} as createTime
        from dual
    </foreach>
    ) a


INSERT ALL

into TRX_BILL_DETAIL_INFO


ID,


CUST_NO,


TRANS_CODE,


TRANS_REFNO,


TRANS_SEQNO,


ORDER_NO,


TRANS_AMT,


BILL_DATE,


BILL_FLAG,


TRANS_DESC,




#{item.id,jdbcType=DECIMAL},


#{item.custNo,jdbcType=CHAR},


#{item.transCode,jdbcType=CHAR},


#{item.transRefno,jdbcType=CHAR},


#{item.transSeqno,jdbcType=VARCHAR},


#{item.orderNo,jdbcType=CHAR},


#{item.transAmt,jdbcType=DECIMAL},


#{item.billDate,jdbcType=DECIMAL},


#{item.billFlag,jdbcType=CHAR},


#{item.transDesc,jdbcType=VARCHAR},



select 1 from dual


Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
使用mybatis批量插入数据的问题

mybatis配置文件如下:插入的为集合中的数据,当集合中只有一条数据时可以插入进去,但是当一条以上数据时将会报错 ``` <insert id="batchInsert" parameterType="java.util.List"> <selectKey keyProperty="waybillNo" order="BEFORE" resultType="int"> select current_timestamp () </selectKey> insert into oal_tb_waybill_history ( waybill_no,waybill_type,account, cabinet_code,box_code,recover_box_code, captcha,phone,msg_id,msg_state,charge_mode, money,number,state,receive_time,send_time, operator_id,create_time,update_time,del_tag ) values <foreach collection="list" item="item" index="index" open="(" separator="," close=")"> #{item.waybillNo,jdbcType=VARCHAR}, #{item.waybillType,jdbcType=INTEGER}, #{item.account,jdbcType=VARCHAR}, #{item.cabinetCode,jdbcType=VARCHAR}, #{item.boxCode,jdbcType=VARCHAR}, #{item.recoverBoxCode,jdbcType=VARCHAR}, #{item.captcha,jdbcType=VARCHAR}, #{item.phone,jdbcType=VARCHAR}, #{item.msgId,jdbcType=BIGINT}, #{item.msgState,jdbcType=INTEGER}, #{item.chargeMode,jdbcType=INTEGER}, #{item.money,jdbcType=DECIMAL}, #{item.number,jdbcType=TINYINT}, #{item.state,jdbcType=INTEGER}, #{item.receiveTime,jdbcType=TIMESTAMP}, #{item.sendTime,jdbcType=TIMESTAMP}, #{item.operatorId,jdbcType=INTEGER}, #{item.createTime,jdbcType=TIMESTAMP}, #{item.updateTime,jdbcType=TIMESTAMP}, #{item.delTag,jdbcType=INTEGER} </foreach> </insert> ``` 报如下错误:![图片说明](https://img-ask.csdn.net/upload/201501/10/1420859244_482832.png) 大家帮忙看看是哪里的错误,感谢!!!

mybatis 批量进行插入更新,数据库为postgreSQL?

没有发现mybatis的批量更新和插入,用for查询感觉很慢,又需要有这样的需求, 其他数据库查到一些,但是postgre没查到,恳求各位大神稍加指点

mybatis 带序列批量插入数据

我的mybatis批量插入,报oracle 的未明确列错误,求大神帮忙看看,以下是mybatis的配置文件 <insert id="insertBatch" parameterType="com.***.entity.Container"> insert into <include refid="table_name"/> ( container_id, parent_id, container_name, total_well_count, empty_well_count, sort, is_box, xNumber, yNumber, remarks, creat_time, creator, last_modify_person, last_modify_time, domain ) select seq_container.nextval, c.* from ( <foreach collection="containerList" item="item" index="index" separator="union all"> select #{item.containerId,jdbcType=NUMERIC}, #{item.parentId,jdbcType=NUMERIC}, #{item.containerName,jdbcType=VARCHAR}, #{item.totalWellCount,jdbcType=NUMERIC}, #{item.emptyWellCount,jdbcType=NUMERIC}, #{item.sort,jdbcType=VARCHAR}, #{item.isBox,jdbcType=NUMERIC}, #{item.xNumber,jdbcType=NUMERIC}, #{item.yNumber,jdbcType=NUMERIC}, #{item.remarks,jdbcType=VARCHAR}, sysdate, #{item.creator,jdbcType=VARCHAR}, #{item.lastModifyPerson,jdbcType=VARCHAR}, sysdate, #{item.domain,jdbcType=VARCHAR} from dual </foreach> ) c </insert>

mybatis批量插入的时候,为什么会存储很多insert语句导致内存溢出

我在这个一个while 循环里,有两条sql语句,一条sql查询出来list对象,另一条sql语句 将list批量插入到数据库,用的mybatis持久层,我用的slqsession直接操作的, 但是程序运行一段时间后,堆内存一直在增长,我用了jdk下面的可视化监控工具 发现,对内存好多insert 语句被存储起来了,我并没有启用二级缓存,用的sqlsession,每一次循环重新获取,然后关闭,并且claercache,这是为什么

myBatis如何批量插入序列

myBatis如何批量插入序列 序列不是主键 只是一个字段 要求在导入时批量插入这个序列字段 求救大神!!!!!!!!!!!!!!!!!! 急急急

mybatis 批量插入的时候为什么会出现主键为空的数据

<insert id="insertBath" parameterType="java.util.List"> insert into sys_user (<include refid="getColumns"/>) values <foreach collection="list" index="index" separator="," item="item"> (#{item.userId},#{item.loginName},#{item.realName},#{item.telNo},#{item.pub},#{item.sal},#{item.pri}) </foreach> </insert>![图片说明](https://img-ask.csdn.net/upload/201703/20/1490014983_669760.png)

Mybatis批量插入Oracle,程序报错_frch_item_0 not found

**Mybatis批量插入Oracle时,Oracle中sql执行成功,程序中报错_frch_item_0 not found???? ** ``` 这条sql语句执行没问题: insert all into fr_employee (EMP_NO, EMP_NAME, DEPT_NO) values (10000, 'dsadadwa', 155) into fr_employee (EMP_NO, EMP_NAME, DEPT_NO) values (10002, 'dsadadwa', 155) into fr_employee (EMP_NO, EMP_NAME, DEPT_NO) values (10003, 'dsadadwa', 155) SELECT 1 FROM dual; sqlmap配置部分如下: <insert id="addList1" parameterType="java.util.List" useGeneratedKeys="false" flushCache="false"> INSERT ALL <foreach item="item" index="index" collection="list"> into fr_employee (EMP_NO, EMP_NAME, DEPT_NO) VALUES ( #{item.EMPNO,jdbcType=INTEGER}, #{item.EMPNAME,jdbcType=VARCHAR}, #{item.DEPTNO,jdbcType=INTEGER} ) </foreach> SELECT 1 FROM DUAL </insert> ```

Mybatis怎么实现批量的id自增插入到oracle中

因为oracle中并不支持自增id,所以使用下面这种批量的先查询id,再把id的值加1后放到id字段中去,老是报ORA-00933: SQL 命令未正确结束,请大神帮帮忙。 ``` <insert id="addRoleInfo" parameterType="java.util.List" useGeneratedKeys="false" > <selectKey resultType="int" keyProperty="ID" order="BEFORE"> SELECT MAX(ID)+1 FROM PORTAL_SYSTEM_ROLE </selectKey> insert into PORTAL_SYSTEM_ROLE (ID,ROLE_ID,ROLE_NAME,CREATE_TIME,UPDATE_TIME) values <foreach collection="list" item="item" index="index" separator="," > (#{item.id,jdbcType=VARCHAR}, #{item.roleId,jdbcType=VARCHAR}, #{item.roleName,jdbcType=VARCHAR}, #{item.createTime,jdbcType=TIMESTAMP}, #{item.updateTime,jdbcType=TIMESTAMP}) </foreach> </insert> ``` ``` org.springframework.jdbc.BadSqlGrammarException: ### Error updating database. Cause: java.sql.SQLException: ORA-00933: SQL 命令未正确结束 ### The error may exist in file [E:\HTML\apache-tomcat-7.0.69\webapps\4asyn\WEB-INF\classes\mybatis\RoleMapper.xml] ### The error may involve com.boco.eoms.portal.role.mapper.RoleMapper.addRoleInfo-Inline ### The error occurred while setting parameters ### SQL: insert into PORTAL_SYSTEM_ROLE (ID,ROLE_ID,ROLE_NAME,CREATE_TIME,UPDATE_TIME) values (?, ?, ?, ?, ?) , (?, ?, ?, ?, ?) ### Cause: java.sql.SQLException: ORA-00933: SQL 命令未正确结束 ; bad SQL grammar []; nested exception is java.sql.SQLException: ORA-00933: SQL 命令未正确结束 ```

Mybatis批量添加insert报错

向mybatis批量insert数据。 这个是在批量添加的接口。我在添加之前会进行一下删除,把ID没有的删除出去 ![图片说明](https://img-ask.csdn.net/upload/201710/18/1508315114_225416.png) 这个是xml ![图片说明](https://img-ask.csdn.net/upload/201710/18/1508315206_680048.png) 空的对象我认为在遍历删除ID的时候就会被筛出去。 但是报得错误: 15:36:22.843 [main] ERROR com.ioe.efficiency.service.impl.ReferenceValueServiceImpl - [DUBBO] createReferenceValue have an error:, dubbo version: 2.4.10, current host: 10.1.140.152 org.springframework.jdbc.BadSqlGrammarException: ### Error updating database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 4 ### The error may involve defaultParameterMap ### The error occurred while setting parameters ### SQL: INSERT INTO t_reference_value(customer_id,station_id,record_id,quarterly_time,node_id,type,day, twenty_three,twenty_two,twenty_one,twenty,nineteen,eighteen,seventeen,sixteen,fifteen,fourteen, thirteen,twelve,eleven,ten,nine,eight,seven,six,five,four,three,two,one,zero,sys_record_status) VALUES ### Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 4 ; bad SQL grammar []; nested exception is com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 4 at org.springframework.jdbc.support.SQLErrorCodeSQLExceptionTranslator.doTranslate(SQLErrorCodeSQLExceptionTranslator.java:231) at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:73) at org.mybatis.spring.MyBatisExceptionTranslator.translateExceptionIfPossible(MyBatisExceptionTranslator.java:74) at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:399) at com.sun.proxy.$Proxy30.insert(Unknown Source) at org.mybatis.spring.SqlSessionTemplate.insert(SqlSessionTemplate.java:253) at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:52) at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53) at com.sun.proxy.$Proxy42.createReferenceValue(Unknown Source) at com.ioe.efficiency.service.impl.ReferenceValueServiceImpl.createReferenceValue(ReferenceValueServiceImpl.java:64) at com.ioe.efficiency.service.impl.ReferenceValueServiceImpl$$FastClassBySpringCGLIB$$4e0863e3.invoke(<generated>) at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204) at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:717) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157) at org.springframework.transaction.interceptor.TransactionInterceptor$1.proceedWithInvocation(TransactionInterceptor.java:99) at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:281) at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:96) at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179) at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:653) at com.ioe.efficiency.service.impl.ReferenceValueServiceImpl$$EnhancerBySpringCGLIB$$f0b98299.createReferenceValue(<generated>) at com.ioe.efficiency.timingtask.ReferenceValueTask.operateUpperCircuit(ReferenceValueTask.java:539) at com.ioe.efficiency.timingtask.ReferenceValueTask.operateUpperCircuit(ReferenceValueTask.java:544) at com.ioe.efficiency.timingtask.ReferenceValueTask.operateUpperCircuit(ReferenceValueTask.java:544) at com.ioe.efficiency.timingtask.ReferenceValueTask.operateUpperCircuit(ReferenceValueTask.java:544) at com.ioe.efficiency.timingtask.ReferenceValueTask.timingOfReferenceValue(ReferenceValueTask.java:253) at com.ioe.efficiency.timingtask.ReferenceValueTask.oneHour(ReferenceValueTask.java:51) at com.ioe.efficiency.service.impl.ReferenceValueTaskTest.oneHour(ReferenceValueTaskTest.java:36) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:601) at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50) at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47) at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26) at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27) at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325) at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78) at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57) at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26) at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27) at org.junit.runners.ParentRunner.run(ParentRunner.java:363) at org.junit.runner.JUnitCore.run(JUnitCore.java:137) at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68) at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47) at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242) at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70) Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 4 at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) at java.lang.reflect.Constructor.newInstance(Constructor.java:525) at com.mysql.jdbc.Util.handleNewInstance(Util.java:400) at com.mysql.jdbc.Util.getInstance(Util.java:383) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:980) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3847) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3783) at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2447) at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2594) at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2545) at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1901) at com.mysql.jdbc.PreparedStatement.execute(PreparedStatement.java:1193) at org.apache.commons.dbcp2.DelegatingPreparedStatement.execute(DelegatingPreparedStatement.java:198) at org.apache.commons.dbcp2.DelegatingPreparedStatement.execute(DelegatingPreparedStatement.java:198) at sun.reflect.GeneratedMethodAccessor193.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:601) at org.apache.ibatis.logging.jdbc.PreparedStatementLogger.invoke(PreparedStatementLogger.java:59) at com.sun.proxy.$Proxy49.execute(Unknown Source) at org.apache.ibatis.executor.statement.PreparedStatementHandler.update(PreparedStatementHandler.java:45) at org.apache.ibatis.executor.statement.RoutingStatementHandler.update(RoutingStatementHandler.java:73) at org.apache.ibatis.executor.SimpleExecutor.doUpdate(SimpleExecutor.java:49) at org.apache.ibatis.executor.BaseExecutor.update(BaseExecutor.java:115) at org.apache.ibatis.executor.CachingExecutor.update(CachingExecutor.java:75) at org.apache.ibatis.session.defaults.DefaultSqlSession.update(DefaultSqlSession.java:170) at org.apache.ibatis.session.defaults.DefaultSqlSession.insert(DefaultSqlSession.java:157) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:601) at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:386) ... 49 common frames omitted 语句的values之前什么也没有,难道是传进了空对象么?但是空对象在之前已经筛出去了。

怎么让mybatis批量新增返回所有uuid主键?

我现在有个需求,比如新增3条数据,主键是uuid自增,然后在xml文件中循环添加,那怎么返回这3条主键ID呢?service该怎么接? 谢谢大神们

mybatis 带序列批量插入 如何返回ID?

<insert id="addCustomerApplyBlacklist" parameterType="java.util.List"> insert into table( ID, OPTIMISTIC, RESTRICTS_TYPE, RESTRICTS_CONTENT, ENABLE_STATUS, REMARK_INFO, OPERATOR, CREATE_TIME, APP, BUSINESS_CODE) select ***********_ID.nextval,0,A.* from ( <foreach collection="list" item="item" index="index" separator="union all"> select #{item.RESTRICTS_TYPE,jdbcType=VARCHAR}, #{item.RESTRICTS_CONTENT,jdbcType=VARCHAR}, #{item.ENABLE_STATUS,jdbcType=VARCHAR}, #{item.REMARK_INFO, jdbcType=VARCHAR}, #{item.OPERATOR, jdbcType=VARCHAR}, SYSDATE, #{item.APP,jdbcType=VARCHAR}, #{item.BUSINESS_CODE,jdbcType=VARCHAR} from dual </foreach> ) A </insert>

关于mybatis批量插入的问题

自己写了一个批量插入的方法 public void batchAdd(List<SnapshotDf> list) { getSqlSession().insert(this.getClassName()+".batchAdd",list); } 对应的map <insert id="batchAdd" parameterType="java.util.List"> insert into snapshot_df( link_id, sid, df_name, df_storage, df_used, df_free, df_usage, df_mount, record_time )values <foreach collection="list" item="item" index="index" separator=","> ( #{item.linkId}, #{item.sid}, #{item.dfName}, #{item.dfStorage}, #{item.dfUsed}, #{item.dfFree}, #{item.dfUsage}, #{item.dfMount}, #{item.recordTime} ) </foreach> </insert> 但是从后台日志看到拼成的运行sql是select count(1) from (insert into snapshot_df(....... 多出select count(1) from这样的一句,从而导致语法错误 为什么会这样呢?

SpringMVC+Mybatis mysql语句 批量插入 无法 返回主键的问题

<insert id="insertList" parameterType="java.util.List"keyProperty="id"useGeneratedKeys="true"> INSERT INTO table_A ( a,b,c ) VALUES <foreach collection="list" close=")" item="item" open="(" separator=","> #{item.a},#{item.b},#{item.c} </foreach> </insert> 主键id是自增型,支持自动生成 报错是 未找到属性id

mybatis 批量新增时,怎么批量返回自增ID,数据库是mysql

各位大侠你们好。。如题。。求解,下面是DAO和SQL: spring Dao的方法定义: public List<Catalog> saveCatalogList(@Param("catalist") List<Catalog> catalist);​ mybatis的批量插入SQL: <insert id="saveCatalogList" parameterType="java.util.List" keyColumn="Catalog_ID" > insert into CATALOG (Marc_Type,Catalog_State,Doc_Type,LANG_CODE,Country_Code,Catalog_Title, Catalog_Author,Publisher,Publisher_Year,isbn,cip,Created_By,Last_Updated_By,Date_Created,catatype,callno,price) values <foreach collection="catalist" item="item" index="index" separator=","> (#{item.marcType}, #{item.CatalogState}, #{item.docType}, #{item.lang}, #{item.country}, #{item.title}, #{item.author}, #{item.publisher}, #{item.publisherYear},#{item.isbn},#{item.cip},#{item.CreatedBy.id}, #{item.UpdatedBy.id},sysdate(),#{item.cataType},#{item.callNo},#{item.price}) </foreach> </insert> 目前这样子执行是报错的,因为mybatis的insert返回类型没有LIST。。求大神指点,我在批量新增时,怎么返回批量的自增ID ​

我在使用mybatis批量更新mysql数据库的时候,更新不了,我怀疑是集合没有传进foreach

我在使用mybatis批量更新mysql数据库的时候,更新不了,我怀疑是集合没有传进foreach但是list里面确实有值 <update id="updateReturnFeeMoneyCenter" parameterType="java.util.List"> <foreach collection="list" item="it" index="index" open="" close="" separator=";"> UPDATE tb_ml3_operate_center SET retutn_fee_money = retutn_fee_money + #{it.totalFee}, return_fee_total_money = return_fee_total_money + #{it.totalFee} WHERE id = #{it.centerId} </foreach> </update> ``` ```

mybatis怎么智能判断数据是否需要插入?

## mybatis怎么智能判断数据是否需要插入?? 前端传了10条数据, Controler转化为一个List<MsgEntity>如下面这样的: ``` {msg:[{id:1,content:"未修改"},{id:2,content:"未修改​"},{id:2,content:"已经修改"}....​]} ``` * 前2条数据是数据库中存在的,没有改,不插入到数据库; * 3-5条数据是改过的,要更新到数据库中,并把旧数据插入历史库; * 6-10条数据是新加的,要插入到数据库中; ``` 关键是数据对比,我可以手动把数据库中的所有值查出来手动做对比,但是这太累了....完全没有效率呀字段多了我总不能一个一个的对比吧.... 况且数据库有成千上万行数据呀,每次更新时都查一遍多没效率呀 ``` 用Hibernate完全不用管这类事情.... 大神来个可用解决方案 ``` (目前6-10条数据很好判断,只需要把id全部查询出来,不存在就插入,关键是判断数据是否需要更新) ``` 最好优雅一点的解决方案,有没有工具库这类的..

Mybatis批量添加,页面获取到的值怎么放入List<类>里面

![图片说明](https://img-ask.csdn.net/upload/201508/17/1439799837_387269.png)

Mybatis批量添加:报错信息:ORA-00933: SQL 命令未正确结束

Mybatis里面: <insert id="insert" useGeneratedKeys="true" parameterType="java.util.Map"> insert into USER_ROLE_AUT (RU_ID, RU_ROLE_ID, RU_AUT_ID, RU_TIME_INS, RU_USER_INS, RU_TIME_LST, RU_USER_LST, RU_STATUS) select U.* from USER_ROLE_AUT ( <foreach collection="maps" item="item" index="index" separator="union all" > select RU_ID_SEQ.Nextval, #{item.ruRoleId,jdbcType=DECIMAL}, #{item.ruAutId,jdbcType=DECIMAL}, #{item.ruTimeIns,jdbcType=TIMESTAMP}, #{item.ruUserIns,jdbcType=VARCHAR}, #{item.ruTimeLst,jdbcType=TIMESTAMP}, #{item.ruUserLst,jdbcType=VARCHAR}, #{item.ruStatus,jdbcType=CHAR} from USER_ROLE_AUT </foreach> )U </insert> action里面: @RequestMapping("roleAutSave") @ResponseBody public Map roleAutSave(HttpServletRequest request, HttpSession session) throws SystemException { Map<String, Object> rtnmap = null; Map<String, Object> map = new HashMap<String, Object>(); try { String ruAutId = request.getParameter("ruAutId");// 获取到树形菜单选中的节点 System.out.println(ruAutId); String[] adeArrs = ruAutId.split(","); System.out.println(adeArrs); String ruRoleId = request.getParameter("ruRoleId");// 获取选中的角色id String ruUserIns = request.getParameter("ruUserIns");// 获取登录的账号 List<UserRoleAut> ls = new ArrayList<UserRoleAut>(); UserRoleAut ur = null; for (String ade : adeArrs) { ur = new UserRoleAut(); ur.setRuRoleId(new Long(ruRoleId)); ur.setRuAutId(new Long(ade)); ur.setRuUserIns(ruUserIns); ls.add(ur); } map.put("maps", ls); userRoleAutMapper.insert(map);// 保存 userRoleAutMapper.deleteByPrimaryKey(); rtnmap = okMap("roleAut"); } catch (Exception e) { rtnmap = failMap("roleAut"); e.printStackTrace(); } return rtnmap; }

mybatis多线程批量插入MySQL报主键冲突

<insert id="batchInsert" parameterType="java.util.List"> insert into SMS_DOWN_HISTORY(templateCode,activityCode,activityId,sendRoundId,arrangeDate,expireDate,messageId,mobile,requestId,senderId,depName,depId,flag,level,smsTemplateVar,systemName,mtime,ctime) values <foreach collection="list" item="item" index="index" separator="," > (#{item.templateCode},#{item.activityCode},#{item.activityId},#{item.sendRoundId},#{item.arrangeDate},#{item.expireDate},#{item.messageId},#{item.mobile},#{item.requestId},#{item.senderId},#{item.depName},#{item.depId},#{item.flag},#{item.level},#{item.smsTemplateVar},#{item.systemName},#{item.mtime},#{item.ctime}) </foreach> </insert> 以上是我的SQL语句,在多线程的请求下就会报主键冲突异常,并且并发量越大主键冲突异常就越频繁。

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解!

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解! 目录 博客声明 大数据了解博主粉丝 博主的粉丝群体画像 粉丝群体性别比例、年龄分布 粉丝群体学历分布、职业分布、行业分布 国内、国外粉丝群体地域分布 博主的近期访问每日增量、粉丝每日增量 博客声明 因近期博主写专栏的文章越来越多,也越来越精细,逐步优化文章。因此,最近一段时间,订阅博主专栏的人数增长也非常快,并且专栏价

我说我不会算法,阿里把我挂了。

不说了,字节跳动也反手把我挂了。

培训班出来的人后来都怎么样了?(二)

接着上回说,培训班学习生涯结束了。后面每天就是无休止的背面试题,不是没有头脑的背,培训公司还是有方法的,现在回想当时背的面试题好像都用上了,也被问到了。回头找找面试题,当时都是打印下来天天看,天天背。 不理解呢也要背,面试造飞机,上班拧螺丝。班里的同学开始四处投简历面试了,很快就有面试成功的,刚开始一个,然后越来越多。不知道是什么原因,尝到胜利果实的童鞋,不满足于自己通过的公司,嫌薪水要少了,选择...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

工作八年,月薪60K,裸辞两个月,投简历投到怀疑人生!

近日,有网友在某职场社交平台吐槽,自己裸辞两个月了,但是找工作却让自己的心态都要崩溃了,全部无果,不是已查看无回音,就是已查看不符合。 “工作八年,两年一跳,裸辞两个月了,之前月薪60K,最近找工作找的心态崩了!所有招聘工具都用了,全部无果,不是已查看无回音,就是已查看不符合。进头条,滴滴之类的大厂很难吗???!!!投简历投的开始怀疑人生了!希望 可以收到大厂offer” 先来看看网...

97年世界黑客编程大赛冠军作品(大小仅为16KB),惊艳世界的编程巨作

这是世界编程大赛第一名作品(97年Mekka ’97 4K Intro比赛)汇编语言所写。 整个文件只有4095个字节, 大小仅仅为16KB! 不仅实现了3D动画的效果!还有一段震撼人心的背景音乐!!! 内容无法以言语形容,实在太强大! 下面是代码,具体操作看最后! @echo off more +1 %~s0|debug e100 33 f6 bf 0 20 b5 10 f3 a5...

不要再到处使用 === 了

我们知道现在的开发人员都使用 === 来代替 ==,为什么呢?我在网上看到的大多数教程都认为,要预测 JavaScript 强制转换是如何工作这太复杂了,因此建议总是使用===。这些都...

什么是a站、b站、c站、d站、e站、f站、g站、h站、i站、j站、k站、l站、m站、n站?00后的世界我不懂!

A站 AcFun弹幕视频网,简称“A站”,成立于2007年6月,取意于Anime Comic Fun,是中国大陆第一家弹幕视频网站。A站以视频为载体,逐步发展出基于原生内容二次创作的完整生态,拥有高质量互动弹幕,是中国弹幕文化的发源地;拥有大量超粘性的用户群体,产生输出了金坷垃、鬼畜全明星、我的滑板鞋、小苹果等大量网络流行文化,也是中国二次元文化的发源地。 B站 全称“哔哩哔哩(bilibili...

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

MySQL性能优化(五):为什么查询速度这么慢

前期回顾: MySQL性能优化(一):MySQL架构与核心问题 MySQL性能优化(二):选择优化的数据类型 MySQL性能优化(三):深入理解索引的这点事 MySQL性能优化(四):如何高效正确的使用索引 前面章节我们介绍了如何选择优化的数据类型、如何高效的使用索引,这些对于高性能的MySQL来说是必不可少的。但这些还完全不够,还需要合理的设计查询。如果查询写的很糟糕,即使表结构再合理、索引再...

用了这个 IDE 插件,5分钟解决前后端联调!

点击上方蓝色“程序猿DD”,选择“设为星标”回复“资源”获取独家整理的学习资料!作者 |李海庆我是一个 Web 开发前端工程师,受到疫情影响,今天是我在家办公的第78天。开发了两周,...

大厂的 404 页面都长啥样?最后一个笑了...

每天浏览各大网站,难免会碰到404页面啊。你注意过404页面么?猿妹搜罗来了下面这些知名网站的404页面,以供大家欣赏,看看哪个网站更有创意: 正在上传…重新上传取消 腾讯 正在上传…重新上传取消 网易 淘宝 百度 新浪微博 正在上传…重新上传取消 新浪 京东 优酷 腾讯视频 搜...

【高并发】高并发秒杀系统架构解密,不是所有的秒杀都是秒杀!

网上很多的文章和帖子中在介绍秒杀系统时,说是在下单时使用异步削峰来进行一些限流操作,那都是在扯淡! 因为下单操作在整个秒杀系统的流程中属于比较靠后的操作了,限流操作一定要前置处理,在秒杀业务后面的流程中做限流操作是没啥卵用的。

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

代码注释如此沙雕,会玩还是你们程序员!

某站后端代码被“开源”,同时刷遍全网的,还有代码里的那些神注释。 我们这才知道,原来程序员个个都是段子手;这么多年来,我们也走过了他们的无数套路… 首先,产品经理,是永远永远吐槽不完的!网友的评论也非常扎心,说看这些代码就像在阅读程序员的日记,每一页都写满了对产品经理的恨。 然后,也要发出直击灵魂的质问:你是尊贵的付费大会员吗? 这不禁让人想起之前某音乐app的穷逼Vip,果然,穷逼在哪里都是...

Java14 新特性解读

Java14 已于 2020 年 3 月 17 号发布,官方特性解读在这里:https://openjdk.java.net/projects/jdk/14/以下是个人对于特性的中文式...

爬虫(101)爬点重口味的

小弟最近在学校无聊的很哪,浏览网页突然看到一张图片,都快流鼻血。。。然后小弟冥思苦想,得干一点有趣的事情python 爬虫库安装https://s.taobao.com/api?_ks...

疫情后北上广深租房价格跌了吗? | Alfred数据室

去年3月份我们发布了《北上广深租房图鉴》(点击阅读),细数了北上广深租房的各种因素对租房价格的影响。一年过去了,在面临新冠疫情的后续影响、城市尚未完全恢复正常运转、学校还没开学等情况下...

面试官给我挖坑:a[i][j] 和 a[j][i] 有什么区别?

点击上方“朱小厮的博客”,选择“设为星标”后台回复&#34;1024&#34;领取公众号专属资料本文以一个简单的程序开头——数组赋值:int LEN = 10000; int[][] ...

又一起程序员被抓事件

就在昨天互联网又发生一起让人心酸的程序员犯罪事件,著名的百度不限速下载软件 Pandownload PC 版作者被警方抓获。案件大致是这样的:软件的作者不仅非法盗取用户数据,还在QQ群进...

应聘3万的职位,有必要这么刁难我么。。。沙雕。。。

又一次被面试官带到坑里面了。面试官:springmvc用过么?我:用过啊,经常用呢面试官:springmvc中为什么需要用父子容器?我:嗯。。。没听明白你说的什么。面试官:就是contr...

太狠了,疫情期间面试,一个问题砍了我5000!

疫情期间找工作确实有点难度,想拿到满意的薪资,确实要点实力啊!面试官:Spring中的@Value用过么,介绍一下我:@Value可以标注在字段上面,可以将外部配置文件中的数据,比如可以...

Intellij IDEA 美化指南

经常有人问我,你的 IDEA 配色哪里搞的,我会告诉他我自己改的。作为生产力工具,不但要顺手而且更要顺眼。这样才能快乐编码,甚至降低 BUG 率。上次分享了一些 IDEA 有用的插件,反...

【相亲】96年程序员小哥第一次相亲,还没开始就结束了

颜值有点高,条件有点好

太厉害了,终于有人能把TCP/IP 协议讲的明明白白了

一图看完本文 一、 计算机网络体系结构分层 计算机网络体系结构分层 计算机网络体系结构分层 不难看出,TCP/IP 与 OSI 在分层模块上稍有区别。OSI 参考模型注重“通信协议必要的功能是什么”,而 TCP/IP 则更强调“在计算机上实现协议应该开发哪种程序”。 二、 TCP/IP 基础 1. TCP/IP 的具体含义 从字面意义上讲,有人可能会认为...

腾讯面试题: 百度搜索为什么那么快?

我还记得去年面腾讯时,面试官最后一个问题是:百度/google的搜索为什么那么快? 这个问题我懵了,我从来没想过,搜素引擎的原理是什么 然后我回答:百度爬取了各个网站的信息,然后进行排序,当输入关键词的时候进行文档比对……巴拉巴拉 面试官:这不是我想要的答案 我内心 这个问题我一直耿耿于怀,终于今天,我把他写出来,以后再问,我直接把这篇文章甩给他!!! 两个字:倒排,将贯穿整篇文章,也是面试官...

相关热词 c#树形选择 c#中类图的使用方法 c# 传参 调用exe c# 怎么定义方法 c# 修改本地时间 c#前台怎么读取资源文件 c# xml转list c#实现框选截图 m*m乘法表c# c# 乘法99表
立即提问