java 搜索框快速查询_Java项目搜索功能的实现

今天是刘小爱自学Java的第110天。

感谢你的观看,谢谢你。

话不多说,开始今天的学习:

5832c16266b82d24ff4968ab35033dd3.png

事先说明:关于今天的搜索功能实现。

并没有使用到倒排索引这样的主流搜索技术,就一个普通的模糊查询。

在此之前,先学一个小的知识点,sql语句动态拼接。

一、sql语句动态拼接

我们编写sql语句,一般都是通过预编译查询,使用问号这个通配符”?“

但是有的时候会存在某个参数不存在的情况,比如说这一次查询前端传来了3个参数,下一次却只传了2个参数。

面对这个问题,那该怎么办呢?

就需要使用到sql语句的动态拼接了,代码编写如下:

b6c6047759856dc7cd7890e6f185177c.png

①sql语句中的cid这个参数是不确定的,有时有,有时可能没有。

②StringBuilder的使用

先将sql语句中确定的部分存放到StringBuilder中,再创建一个集合存放参数。

③对cid做出判断

如果cid不为空且存在,就在sql语句中拼接“ and cid = ?”,同时将cid存入参数集合中。

④拼接cid后面其它的参数

在sql语句中拼接“  limit ?,?”,然后将另外两个固定参数存入集合。

注意:sql拼接过程中空格不要忘记了,总之要保证拼接后的sql要和①中的一样,通过debug可以查看。

⑤查询数据

将动态存放sql语句的StringBuilder转换成字符串,将存放参数的集合转换成数组,再使用jdbcTemp查询。

二、前后台代码编写

1业务分析

我们要找到搜索框所在的静态页面,如下图:

57f26cf003691de6701e7e2a04a91685.png

要解决两个问题:

①是我们要给搜索绑定一个点击事件,点击之后就会跳转到route_list页面,展示查询到的对应数据。

绑定的函数为queryByRname()

②我们要获取搜索框中输入的数据。

这里就可以通过层级选择器$(“.search input”)选中搜索框对应的标签。

2前端代码实现

定义函数queryByRname()

9e188ac08bed3c618c7d65fb225f8a76.png

①获取搜索框中的内容

使用层级选择器,调用jQuery的val()方法可以获取对应标签中的数据,这里也就是搜索框。

②跳转route_list.html页面

location.href即可跳转对应页面。同时将rname作为参数传递给后台。

③route_list.html页面代码

在②中跳转是携带了一个参数,自然是需要获取该参数,再将其增加到服务器请求参数中。

其中要将参数进行解码,因为浏览器会自动将在搜索框中输入的数据进行编码。

使用decodeURL()功能即可完成编码。

3后台接受该参数

在已有的业务逻辑基础上添加参数即可

4e187d516b17a1103a73909a6ae16218.png

只需要在web层中增加获取rname这个数据的代码。

同时在将其作为参数传递给service层,而service层也增加该参数去dao层查询。

其它代码都不用改变,只是增加了一个rname参数。

9f7c816a3d84e9b17332916624757f70.png

同样的道理,在dao层中也动态拼接sql查询语句。

总之可以先写出完整的sql语句,再动态拼接rname这个参数。

检查方式就可以通过debug来判断sql语句拼接的是否正确。

三、搜索框数据回填

我们在搜索框中输入信息之后,点击搜索,搜索框的内容会消失。

而事实上都应该还会存在,那该怎么办呢?

就需要考虑到数据回填:

03b85eb37e917faf75c84a81b5a13982.png

大致的一个思路是:

获取搜索框中的数据后,将其重新设定到对应的标签中。

其中值得注意的是:

参数要解码,以及要绑定页面加载事件。

最后

谢谢你的观看。

如果可以的话,麻烦帮忙点个赞,谢谢你。

  • 7
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值