批量插入,根据传入的值判断是否为null。不为null则插入,为null需要调用函数或者其他方式。

发布于:2024-05-03 ⋅ 阅读:(26) ⋅ 点赞:(0)

第一种 mybatis框架方式
java中,sql insert语句 批量添加 xml中
根据插入的值判断是否为null,不为null 则插入,为null需要调用函数插入 case when then
插入的值不是数据库中查询的值,是代码中参数传递过来的值

在Java中,如果你想在XML配置文件中定义SQL插入语句,并处理插入
值为null的情况,通常你会使用类似MyBatis这样的框架。MyBatis
允许你在XML映射文件中定义SQL语句,并处理参数。

以下是一个使用MyBatis在XML中定义批量插入语句,并根据参数值
是否为null来决定直接插入或调用函数的示例:

首先,假设你有一个Java对象(例如MyEntity),它包含了你想要
插入到数据库中的字段。

java
public class MyEntity {  
    private String field1;  
    private String field2;  
    // getters and setters  
}

然后,在MyBatis的XML映射文件中,你可以定义如下SQL语句:


<mapper namespace="com.example.mapper.MyMapper">  
    <insert id="batchInsert" parameterType="list">  
        INSERT INTO my_table (field1, field2)  
        VALUES  
        <foreach collection="list" item="item" index="index" separator=",">  
            (  
                #{item.field1, jdbcType=VARCHAR, typeHandler=com.example.typehandler.MyTypeHandler},  
                CASE  
                    WHEN #{item.field2, jdbcType=VARCHAR, mode=OUT} IS NULL THEN your_function_to_handle_null()  
                    ELSE #{item.field2, jdbcType=VARCHAR}  
                END  
            )  
        </foreach>  
    </insert>  
</mapper>


在这个例子中,<foreach>元素用于遍历传入的列表(假设为
List<MyEntity>)。对于列表中的每个元素,它生成一个插入语句
的值部分。

对于field1,我们直接插入值。如果field2为null,我们使用
CASE WHEN THEN结构调用一个函数
your_function_to_handle_null()。如果field2不为null,
我们直接插入它的值。

注意几个关键点:

#{item.field1, jdbcType=VARCHAR, typeHandler=
com.example.typehandler.MyTypeHandler}:这里我们使用了
typeHandler来指定一个类型处理器。如果需要特殊处理null值,
你可以自定义一个类型处理器。

mode=OUT:这个属性是MyBatis 3.5.0之后新增的,它用于告诉
MyBatis这个参数是一个输出参数(OUT),在这种情况下,
MyBatis不会设置这个参数的值,而只是用来检查是否为null。

your_function_to_handle_null():这应该替换为你实际要调用
的数据库函数或默认值。

确保你的MyBatis配置文件中包含了该映射文件,并且在你的
Mapper接口中定义了相应的方法:

public interface MyMapper {  
    void batchInsert(List<MyEntity> entities);  
}

最后,在你的服务层或DAO层中,你可以调用这个batchInsert方法
,并传入一个包含MyEntity对象的列表。MyBatis将处理SQL语句的
生成和执行。

请注意,具体的XML语法和MyBatis配置可能因版本不同而有所
差异。确保你查阅了与你使用的MyBatis版本相对应的文档。
此外,还需要考虑数据库的具体方言和函数支持情况。

第二种 不使用mybatis框架方式

insert into 表名 values (值)
可以对值进行判断是否为NUll 进行相应处理吗?

两种方式,都可以试试 。

1、使用 COALESCE 或 IFNULL 函数:
在插入语句中,你可以使用 SQL 的 COALESCE(在大多数数据库
系统中可用)或 IFNULL(在 MySQL 中可用)函数来处理 NULL 
值。这些函数返回其参数中的第一个非 NULL 值。例如:

INSERT INTO 表名 (列1, 列2) VALUES
 (COALESCE(值1, '默认值'), 值2);
在这个例子中,如果 值1 是 NULL,
那么 列1 将被设置为 '默认值'。

2、使用 CASE 表达式:
你也可以在插入语句中使用 CASE 表达式来根据条件设置值。
例如:

	INSERT INTO 表名 (列1, 列2) VALUES (  
    CASE WHEN 值1 IS NULL THEN '默认值' ELSE 值1 END,  
    值2  
);

在这个例子中,如果 值1 是 NULL,则 列1 将被设置为 '默认值',否则它将被设置为 值1。

有人会说第二种不是批量插入的方式,是因为我没有使用myBatis框架,而是使用了其他的非框架的东西。
简单举例子:
DBUtils.batchExecute(list, “KA0050.DEMAND_INFO.INS001”);
list是要插入数据的集合, 通过 KA0050.DEMAND_INFO.INS001 这个字符串找到对应的key就是我们要执行的sql语句。batchExecute 这个是自己封装的批量插入的方法.不过现在很多公司都是使用mybatis框架。所以我也只是举下例子,大家参考看下。

java代码:
 DBUtils.batchExecute(list, "KA0050.DEMAND_INFO.INS001");

xml文件:
   <sql>
        <key>KA0050.DEMAND_INFO.INS001</key>
        <explain>插入要望临时表</explain>
        <query>
            <![CDATA[
		   insert into plant_demand_temp(

网站公告

今日签到

点亮在社区的每一天
去签到