当前位置: 首页 > wzjs >正文

做网站多少钱 注意什么广州各区正在进一步优化以下措施

做网站多少钱 注意什么,广州各区正在进一步优化以下措施,有什么网站可以做扣扣头像,档案网站建设规范有哪些在Spring Boot和MyBatis中,实现动态更新不固定字段的步骤如下: 方法一:使用MyBatis动态SQL(适合字段允许为null的场景) 定义实体类 包含所有可能被更新的字段。 Mapper接口 定义更新方法,参数为实体对象&…

在Spring Boot和MyBatis中,实现动态更新不固定字段的步骤如下:

方法一:使用MyBatis动态SQL(适合字段允许为null的场景)

  1. 定义实体类
    包含所有可能被更新的字段。

  2. Mapper接口
    定义更新方法,参数为实体对象:

    java

    void updateUserSelective(User user);
  3. XML映射文件
    使用<set><if>动态生成SQL:

    xml

    <update id="updateUserSelective" parameterType="User">UPDATE user<set><if test="name != null">name = #{name},</if><if test="age != null">age = #{age},</if><if test="address != null">address = #{address},</if><if test="phone != null">phone = #{phone},</if></set>WHERE id = #{id}
    </update>

注意:此方法无法将字段更新为null,因为参数为null时条件不成立。


方法二:使用Map和字段过滤(支持字段更新为null)

  1. Service层过滤字段
    在Service中定义允许更新的字段,并过滤请求参数:

    java

    public void updateUser(Long id, Map<String, Object> updates) {Set<String> allowedFields = Set.of("name", "age", "address", "phone");updates.keySet().retainAll(allowedFields); // 过滤非法字段userMapper.updateUserSelective(id, updates);
    }
  2. Mapper接口
    使用Map接收动态字段:

    java

    void updateUserSelective(@Param("id") Long id, @Param("updates") Map<String, Object> updates);
  3. XML映射文件
    动态生成更新语句:

    xml

    <update id="updateUserSelective">UPDATE user<set><foreach collection="updates" index="key" item="value" separator=",">${key} = #{value}</foreach></set>WHERE id = #{id}
    </update>

注意:使用${key}存在SQL注入风险,需在Service层严格过滤字段名。


方法三:使用@UpdateProvider(灵活且安全)

  1. 定义SQL提供类
    动态构建安全SQL:

    java

    public class UserSqlProvider {public String updateSelective(Map<String, Object> params) {Long id = (Long) params.get("id");Map<String, Object> updates = (Map<String, Object>) params.get("updates");Set<String> allowedFields = Set.of("name", "age", "address", "phone");StringBuilder sql = new StringBuilder("UPDATE user SET ");allowedFields.forEach(field -> {if (updates.containsKey(field)) {sql.append(field).append(" = #{updates.").append(field).append("}, ");}});sql.setLength(sql.length() - 2); // 移除末尾逗号sql.append(" WHERE id = #{id}");return sql.toString();}
    }
  2. Mapper接口
    使用@UpdateProvider注解:

    java

    @UpdateProvider(type = UserSqlProvider.class, method = "updateSelective")
    void updateUserSelective(@Param("id") Long id, @Param("updates") Map<String, Object> updates);

优点:避免SQL注入,动态生成安全语句。


总结

  • 方法一适合简单场景,字段无需设置为null

  • 方法二灵活,需严格过滤字段。

  • 方法三推荐用于生产环境,安全且维护性强。

根据需求选择合适方案,确保字段更新的灵活性和安全性。

http://www.dtcms.com/wzjs/21038.html

相关文章:

  • 政府网站建设政策企业员工培训课程内容
  • 情人做网站阿里指数怎么没有了
  • 关于做ppt的网站有哪些内容吗搜索引擎优化简历
  • 建设网站转赚钱吗兰州网络推广
  • 网站建设服务器对比搜狗网
  • 做的好的政府网站电商推广联盟
  • 织梦网站内容怎么做付费可见电脑网络优化软件
  • 广州做网站系统销售系统
  • wordpress主页制作企业seo排名
  • 广州个人网站制作公司seo外包服务专家
  • 有哪些网站有收录做红酒的商行广告竞价
  • 惠州网站建设企业网页优化方法
  • 架设多个web网站有哪些方法b2b平台都有哪些网站
  • 使用cnnic证书的网站刷排名的软件是什么
  • 潍坊的网站开发公司优化方法
  • 美国服务器购买网站自己怎么优化网站排名
  • 怎么在百度网站上做自己的网站网络营销课程介绍
  • 网站和第三方建设百度客服人工电话
  • 做营销网站要多少钱成人再就业技能培训班
  • 帮人做网站seo关键词快速排名前三位
  • 做网站专业公司电话百度怎么打广告
  • 网络服务商能删除网站百度付费问答平台
  • 重庆旅游网站搜索引擎优化网站的网址
  • 国外服务器网站百度账号登录中心
  • 酒店网站模板下载网店代运营
  • 网站怎么做搜索引擎才能收录百度搜索推广平台
  • 南磨房做网站公司seo有哪些优缺点?
  • 广州推广网站查排名
  • 无锡网站制作哪些公司seo是什么职位
  • 营销型机械网站做任务赚佣金的正规平台