前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【JavaWeb】110:搜索业务的实现

【JavaWeb】110:搜索业务的实现

作者头像
刘小爱
发布2020-08-07 17:08:48
8060
发布2020-08-07 17:08:48
举报
文章被收录于专栏:零基础自学Java零基础自学Java

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

感谢你的观看,谢谢你。

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

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

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

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

一、sql语句动态拼接

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

但是有的时候会存在某个参数不存在的情况。

比如说这一次查询前端传来了3个参数,下一次却只传了2个参数。

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

就需要使用到sql语句的动态拼接了。

其中代码编写如下:

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

②StringBuilder的使用

在StringBuilder中存放确定的sql语句,再创建一个集合存放参数。

③对cid做出判断

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

④拼接cid后面其它的参数

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

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

⑤查询数据

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

二、前后台代码编写

1业务分析

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

要解决两个问题:

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

绑定的函数为queryByRame()。

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

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

2前端代码实现

定义函数queryByRame()

①获取搜索框中的内容

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

②跳转route_list.html页面

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

③route_list.html页面代码

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

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

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

3后台接受该参数

在web层中获取rname具体的值。

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

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

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

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

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

三、搜索框数据回填

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

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

就需要考虑到数据回填:

大致的一个思路是:

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

其中值得注意的是:

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

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-08-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 刘小爱 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、sql语句动态拼接
  • 二、前后台代码编写
  • 三、搜索框数据回填
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档