Mybatis批量修改时出现报错问题解决方案
批量修改代码如下
<update id="UPDATE_HOTEL_REAL_TIME_PRICE" parameterType="java.util.List"> <foreach collection="list" item="item" index="index" separator=";"> UPDATE VST_HOTEL_REAL_TIME_PRICE <set> <if test="item.realTimePrice1 != null"> REAL_TIME_PRICE1 = #{item.realTimePrice1}, </if> <if test="item.realTimePrice2 != null"> REAL_TIME_PRICE2 = #{item.realTimePrice2}, </if> <if test="item.realTimeRemain1 != null"> REAL_TIME_REMAIN1 = #{item.realTimeRemain1}, </if> <if test="item.realTimeRemain2 != null"> REAL_TIME_REMAIN2 = #{item.realTimeRemain2}, </if> UPDATE_TIME = NOW() </set> WHERE PRODUCT_ID = ${item.productId} </foreach> </update>
今天在使用mybatis批量修改时报错,错误为sql语句错误:
开始检查xml中代码:
<update id="updateTypeList" parameterType="list"> <foreach collection="list" item="type" index="index" separator=";"> UPDATE t_type <set> <if test="type.name != null"> t_name = #{type.name} </if> </set> where t_id = #{type.id} </foreach> </update>
感觉并没有错误,把错误语句复制到Navicat上能正常运行,于是网上查找了一下需要在url语句中添加allowMultiQueries=true,添加后成功运行。
Mysql中allowMultiQueries=true作用:
1.可以在sql语句后携带分号,实现多语句执行。
2.可以执行批处理,同时发出多个SQL语句
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
相关推荐
-
Mybatis数据批量插入如何实现
1:xml的配置 <insert id="insertUserBatch"> insert into user(username, birthday, sex, address) VALUES <foreach collection="list" item="User" index="index" separator=","> ( #{User.username}, #{User.b
-
给你的MyBatis-Plus装上批量插入的翅膀(推荐)
前言 各位好,我是易哥(thinkYi). 大家有用过MyBatis-Plus(简称MP)的都知道它是一个MyBatis的增强工具,旨在MyBatis的基础上只做增强不做改变,为简化开发.提高效率而生. 特点 无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑 损耗小:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作 强大的 CRUD 操作:内置通用 Mapper.通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足
-
Mybatis传入List实现批量更新的示例代码
Dao层写法 /** * 批量更新新库存 * @param list * @return */ int updateNewStock(@Param(value = "list") List<GreenBeanMsg> list); xml具体实现代码 <update id="updateNewStock" parameterType="java.util.List"> <foreach collection=&quo
-
MyBatis批量添加数据2种实现方法
1.通过for each标签拼接sql(数量较少的时候使用) a.拼接values() public int addPersons(@Param("persons") List<Person> persons);//接口 <insert id="addPersons"> insert into person(username,email,gender) VALUES <foreach collection="persons&q
-
详解mybatis 批量更新数据两种方法效率对比
上节探讨了批量新增数据,这节探讨批量更新数据两种写法的效率问题. 实现方式有两种, 一种用for循环通过循环传过来的参数集合,循环出N条sql, 另一种 用mysql的case when 条件判断变相的进行批量更新 下面进行实现. 注意第一种方法要想成功,需要在db链接url后面带一个参数 &allowMultiQueries=true 即: jdbc:mysql://localhost:3306/mysqlTest?characterEncoding=utf-8&allowMulti
-
MyBatis动态SQL foreach标签实现批量插入的方法示例
需求:查出给定id的记录: <select id="getEmpsByConditionForeach" resultType="comtestbeansEmployee"> SELECT * FROM tb1_emplyee WHERE id IN <foreach collection="list" item="item_id" separator="," open="(&q
-
Mybatis批量更新三种方式的实现
Mybatis实现批量更新操作 方式一: <update id="updateBatch" parameterType="java.util.List"> <foreach collection="list" item="item" index="index" open="" close="" separator=";">
-
mybatisPlus自定义批量新增的实现代码
mybatisPlus底层的新增方法是一条一条的新增的,今天自定义批量新增方法. 创建自定义数据方法注入类 /** * @Description: EasySqlInjector 自定义数据方法注入 * @Author WangYejian * @Date: 2020/11/4 14:34 */ public class EasySqlInjector extends DefaultSqlInjector { @Override public List<AbstractMethod> getM
-
如何在mybatis中向BLOB字段批量插入数据
最近接手一个需求,需要用xxl-job定时任务同步三方库中新增的数据,粗略一看挺得意,以为一两小时就搞定了,但事与愿违,编码两小时却被一个BLOB字段玩了一下午. 每次获取50条数据过来,每条数据中有一个字段是BLOB类型的图片,需求也要将图片放入数据库(个人不建议这么玩,生产上千万的数据会造成数据库很臃肿,建议放到ftp或者minio上比较好),字段中的图片过来时已经被转换成了base64的格式,在往数据库批量插入时,数据库BLOB字段对应的实体使用byte[],程序执行时报了如下错误: or
-
Mybatis批量修改时出现报错问题解决方案
批量修改代码如下 <update id="UPDATE_HOTEL_REAL_TIME_PRICE" parameterType="java.util.List"> <foreach collection="list" item="item" index="index" separator=";"> UPDATE VST_HOTEL_REAL_TIME_PRICE
-
解决mybatis批量更新出现SQL报错问题
一.问题重现 1.配置文件 spring: #DataSource数据源 datasource: url: jdbc:mysql://127.0.0.1:3306/mybatis_test?useSSL=false& username: root password: root driver-class-name: com.mysql.jdbc.Driver #MyBatis配置 mybatis: type-aliases-package: com.hl.mybatis.pojo #别名定义
-
Mybatis collection查询集合属性报错的解决方案
目录 Mybatis collection查询集合属性报错 错误日志 背景 排查 解决方法 MyBatis 包含属性为集合的查询 父实体类 关联子查询实体类 父查询返回结果实体类映射 集合子查询实体类映射 父查询 子查询 Mybatis collection查询集合属性报错 错误日志 org.springframework.http.converter.HttpMessageConversionException: Type definition error: [simple type, cla
-
Spring整合Mybatis 扫描注解创建Bean报错的解决方案
目录 Spring整合Mybatis 扫描注解创建Bean报错 springboot+mybatis使用注解方式,出现错误创建dao层bean Spring整合Mybatis 扫描注解创建Bean报错 情景: LZ在整合Spring 和Mybatis 的时候,整合之后部署到tomcat报错 报错信息: Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name
-
关于使用PLSQL Developer时出现报错ora-12514的问题
在登陆PLSQL Developer时报ora-12513错误,需要修改本地数据库的监听配置文件,其过程相对简单. 在Oracle安装目录中搜索找到listener.ora文件,并修改成txt格式后打开(在修改之前建议做好备份),需要添加的代码及添加位置如下图所示: (SID_DESC = (GLOBAL_DBNAME = ORCL) (ORACLE_HOME =E:\Oracle\product\11.2.0\dbhome_1) (SID_NAME = ORCL) ) 注意:安装的盘符需要更改
-
mysql修改用户密码报错的解决方法
目录 mysql修改密码报错 解决办法: 关于 mysql 密码策略相关参数: 关于 validate_password_policy 的取值: mysql修改密码报错 Your password does not satisfy the current policy requirements 这是 mysql 初始化时,使用临时密码,修改自定义密码时,由于自定义密码比较简单,就出现了不符合密码策略的问题. 密码策略问题异常信息: ERROR 1819 (HY000): Your passwor
-
Mybatis批量修改的操作代码
1.修改的字段值都是一样的,id不同 <update id="batchUpdate" parameterType="String"> update cbp_order set status=1 where id in <foreach item="id" collection="array" open="(" separator="," close=")&q
-
ecshop适应在PHP7的修改方法解决报错的实现
ecshop这个系统,到目前也没见怎么推出新版本,如果是新项目,不太建议使用它.不过,因为我一直以来都在使用中,所以不得不更改让其适应PHP新版本.现在PHP 7已经出发行版了,所以更改来继续使用吧.具体的更改有以下方面: (1)将mysql扩展的使用替换掉,改为使用mysqli或pdo: 从php5.5开始,mysql扩展将废弃了. 具体更改的文件在于includes/cls_mysql.php.这是个不小的工程,文件代码太长-- if (!defined('DITAN_ECS')) { di
-
解决iview打包时UglifyJs报错的问题
使用npm run dev时运行是ok的,但是npm run build打包时iview报错, 如下: 原因是iview中使用了es6语法,然而uglifyJs是不支持的,打开我们的build/webpack.prod.conf.js文件,可以看到 // UglifyJs do not support ES6+, you can also use babel-minify for better treeshaking: https://github.com/babel/minify new we
-
安装python时MySQLdb报错的问题描述及解决方法
问题描述: windows安装python mysqldb时报错python version 2.7 required,which was not found in the registry 网上很多方案,比如方案一: Python3.x时, from _winreg import * 改为 from winreg import * 去掉下划线 import sys from _winreg import * # tweak as necessary version = sys.version
随机推荐
- Python实现的ini文件操作类分享
- 关于验证码在IE中不刷新的快速解决方法
- jsp编程去除空白行的方法
- Validform表单验证总结篇
- 详解nodejs异步I/O和事件循环
- linux系统使用python监测网络接口获取网络的输入输出
- iOS中使用JSPatch框架使Objective-C与JavaScript代码交互
- vc6编写python扩展的方法分享
- GO语言类型转换和类型断言实例分析
- JavaBeans程序开发
- javascript 小数取整简单实现方式
- php清除和销毁session的方法分析
- googlemap 之 javascript实现方法
- 详解webpack异步加载业务模块
- 浅谈MFC 改变控件大小和位置
- XHTML标签的自关闭写法的坏处分析
- ros::spin() 和 ros::spinOnce()函数的区别及详解
- LBS blog sql注射漏洞[All version]-官方已有补丁
- 纯js的右下角弹窗实例
- sql注入之新手入门示例详解