发表于: 2019-10-22 20:57:59

1 938


今天完成的事情:(一定要写非常细致的内容,比如说学会了盒子模型,了解了Margin)

第一:先修改manager的搜索接口;

学习<![CDATA[ <= ]]>

学习Mybatis中用sql实现模糊查询,使用concat连接。

学习trim标签

mybatis的trim标签一般用于去除sql语句中多余的and关键字,逗号,或者给sql语句前拼接 “where“、“set“以及“values(“ 等前缀,或者添加“)“等后缀,可用于选择性插入、更新、删除或者条件查询等操作。

以下是trim标签中涉及到的属性:

<where>和<trim>标签一样的作用。

1、使用trim标签去除多余的and关键字

有这样的一个例子:

    <select id="findActiveBlogLike"
   resultType="Blog">
   SELECT * FROM BLOG
WHERE
<if test="state != null">
   state = #{state}
 </if>
 <if test="title != null">
   AND title like #{title}
 </if>
 <if test="author != null and author.name != null">
   AND author_name like #{author.name}
 </if>
</select>

如果这些条件没有一个能匹配上会发生什么?最终这条 SQL 会变成这样:

SELECT * FROM BLOG

WHERE

这会导致查询失败。如果仅仅第二个条件匹配又会怎样?这条 SQL 最终会是这样:

SELECT * FROM BLOG

WHERE 

AND title like ‘someTitle’








明天计划的事情:(一定要写非常细致的内容)
遇到的问题:(遇到什么困难,怎么解决的)

1.前端要求banner搜索要出现四个东西是可选的搜索。

直接重新写了一个sql的搜索方法。

<select id="select"  resultMap="BaseResultMap">
 select
<include refid="Base_Column_List" />
 from banner
<where>
   <if test="title != null">
     title like CONCAT('%',#{title},'%')
</if>
   <if test="status != null ">
     AND status=#{status}
</if>
   <if test="timeStart != null">
     AND create_at <![CDATA[ >= ]]> #{timeStart}
</if>
   <if test="timeEnd != null">
     AND create_at <![CDATA[ <= ]]> #{timeEnd}
</if>
 </where>
 order by status desc,update_at desc

</select>

开始的时候出现了入参的问题,这里我直接传的变量不是一个对象加两个变量。

List<Banner> select(String title,Integer status,Long timeStart,Long timeEnd);

前端要求我在编辑管理员页面直接返回管理员信息加角色信息都只在一个对象里。

修改mapper,增加一个方法返回封装类。

ManagerDto findById(Long id);

应该是只返回一个对象的,怎么会返回多个对象。

发现了问题,前端,给一个用户加了多个对象,导致了这个错误,我是按照一个管理员一个角色来写的代码。


然后他又要求归还到原来的代码。

我想了想,这里可以返回一个list集合给前端,但是没有密码,前端又要密码。
收获:(通过今天的学习,学到了什么知识)


返回列表 返回列表
评论

    分享到