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

网站建设案例怎么样百度竞价排名规则

网站建设案例怎么样,百度竞价排名规则,网站的百度推广怎么做,代办公司是什么意思一、Mybatis有没有比较好的方法隐藏 Pojo 类中的字段 使用 Mybatis 时,为了实现通用的CURD,在定义实体类pojo时,会尽量将能用得上的数据库字段都定义到 pojo中,但是在查询的时候却有不一样的需求。mybatis的文档地址链接&#xff…

一、Mybatis有没有比较好的方法隐藏 Pojo 类中的字段

        使用 Mybatis 时,为了实现通用的CURD,在定义实体类pojo时,会尽量将能用得上的数据库字段都定义到 pojo中,但是在查询的时候却有不一样的需求。mybatis的文档地址链接:XML 映射器_MyBatis中文网icon-default.png?t=O83Ahttps://mybatis.net.cn/sqlmap-xml.html#Result_Maps

        业务中会有不同的人、不同的权限、不同的业务需要读取的字段不尽相同,我们不可能为这种大量重复的内容来定义多个类似的 pojo,但目前我看 Mybatis 里的方法并没有一个好方法。如下,是我将一个业务中拥有十几个字段的表简化一下,只呈现三个字段: pojo 类定义了和数据库表相同的字段列表:

package cn.fangha.pojo;import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;@Data
@AllArgsConstructor
@NoArgsConstructor
public class Event {private Integer id;private String title;private Integer count;}

        在定义的 mapper.xml中,如果我在一个SQL查询里只想取出 pojo中的两个字段,有些地方的介绍说使用 resultMap 定义一下字段关联,但进行尝试,其根本不会把 pojo 中其它的类除去,而只是其值为 null, 但字段会依然存在,这就有点繁琐。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.test.mapper.EventMapper"><resultMap type="Event" id="SimpleEventList" ><result property="id"    column="ls_id"    /><result property="title"    column="ls_title"    /></resultMap><select id="getEventList" resultMap="SimpleEventList">select ls_id,ls_title from table limit 2;</select></mapper>

        并不是说这种情况下没有解决办法,但目前所知道的解决办法都是通过非 mybatis 的方法处理,比如再定义一些不包括这些字段的 pojo,但这个我认为不可取。比如有的说通过在 javaBean 上加注解在序列化的时候忽略此字段,但其会影响所有的地方,如果这样处理,那就直接不要这个pojo属性了:

@JsonProperty(access = JsonProperty.Access.WRITE_ONLY) 

@JsonProperty(access = JsonProperty.Access.WRITE_ONLY)是Jackson库中的注解,用于指定在序列化和反序列化过程中属性的访问权限。

@JsonProperty(access = JsonProperty.Access.WRITE_ONLY)用于标记一个属性,在序列化(对象转为JSON字符串)时忽略该属性,只在反序列化(JSON字符串转为对象)时使用该属性。这意味着该属性的值只能从JSON字符串中读取,而不能通过对象转为JSON字符串时输出。

这个注解通常用于保护敏感信息,例如密码字段。在用户注册或更新密码时,密码字段需要从JSON字符串中读取,但在返回用户信息时,密码字段不应该被包含在JSON字符串中。

使用@JsonProperty(access = JsonProperty.Access.WRITE_ONLY)的优势是可以灵活地控制属性的序列化和反序列化行为,提高数据的安全性和隐私保护。

        也还有一个很简单的解决办法,就是不使用映射集,在定义 select 的时候直接使用 resultType="map",是能解决问题,而且很简洁,但这又不符合JAVA的风格和规范,在IDEA的编辑器中也会提示返回类型报错。

        还有通过对 最后json 处理前操作,通过忽略 null 值字段来实现,如在配置文件中配置spring中 配置 jackson: default-property-inclusion: non_null1,但这就更有点曲线救国了(但目前来看,这个算是较好的解决方法吧)。从而在进行json处理的时候不要这个字段,Mybatis造成的问题要在最后进行 json 响应的时候解决。

        我认为较好的解决办法是在使用 resultMap 的时候有属性指定范围,比如 scope 属性,默认值是使用 pojo 的完整字段, 然后指定其它值如 current 之类就直接使用当前定义的 resultMap 字段为准,忽略 pojo 中其它多余的字段,当然这只是一个初步设想,可以完善更多的值和意义,但这应该是 mybatis 本身应该考虑到的功能,目前来看 resultMap 上只有 autoMapping 和 extends 属性。使用一个 extends 继承类似于多个 pojo ,实现繁琐上会稍微好些。当下比较好的解决方法还只能是在 javaBean 上加注解。扩展一点:

二、基于SpringBoot3+mybatis搭建的历史上的今天API接口服务

        历史上的今天API可以提供历史上的今天国际国内发生的各种大事件记录,包括中英文版本内容。历史上的今天的意义在于提醒人们关注过去发生的重要事件和人物,从中汲取经验和教训,更好地理解现在和未来,了解到人类社会的发展历程,认识到历史的演进和进步。非授权用户只能查看10条事件。页面截图如下:

        本API接口基于SpringBoot3 + Mybatis + Mysql开发,整合Swagger3模块,提供历史上的今天发生的事件明细API接口,同时包括阴历阳历日期、中英文事件内容描述。主要提供二个接口:一是根据日期调取历史上发生的事件明细列表;二是根据事件ID调取事件的详细内容描述,包括中英文版本。

        详细请进入网站查看:www.fangha.cn  放哈API接口 ,其中有链接进入此API接口文档。

        如下为历史上的今天事件列表接口示例图,日期格式示例: 12月20日 请输入 1220

        如下为历史上的今天事件详细 API 接口示例截图,提供事件ID参数。

 

http://www.mmbaike.com/news/79892.html

相关文章:

  • 方案网站seo高级优化技巧
  • 个人网站建设方法和过程兰州网站seo服务
  • 购物商城外贸网站建设太原关键词排名提升
  • 社交网站开发教程做任务赚佣金的平台
  • 编程软件c语言搜索引擎优化的分类
  • 下载网站后怎么做注册一个网站
  • 全面加强政府网站建设域名注册 阿里云
  • 代做原创毕业设计网站竞价排名深度解析
  • 网站开发申请报告各网站收录
  • 苏州新区建网站私人做网站建设
  • asp网站开发基础搜索引擎优化实训
  • 网站里的搜索怎么做的2021最近比较火的营销事件
  • wordpress怎么集成码支付百度关键词优化服务
  • 网站如何做注册类 cpa网站维护需要多长时间
  • 网站名后台修改后 前台不显示网址大全是ie浏览器吗
  • 国外网站设计模板关键词排名是由什么决定的
  • 怎样做网站初中生引流推广效果好的app
  • 做网站流量点击分析的软件南京seo网站管理
  • 怎么用hbuilder做网站百度免费推广登录入口
  • 织梦网站怎么做301官网seo
  • 邢台网站建设与制作专业营销团队外包公司
  • 基层档案网站建设优化大师有用吗
  • 哪个网站做信誉传奇私服网店代运营的套路
  • 做遗嘱的网站有哪些北京网站优化托管
  • 启航网站建设永久免费开网店app
  • 上海网站建设规范珠海做网站的公司
  • 怎么做网站的百度权重石家庄网站建设
  • 当日网站收录查询统计广东疫情最新消息
  • 网站的域名和密码是什么意思怎样做公司网站推广
  • 海口网球场宁波seo外包代运营