mysql 多字段模糊查询_Mybatis mysql 一个搜索框多个字段模糊查询 几种方法

第一种 or

根据搜索框给定的关键词,模糊搜索用户名和账号都匹配的用户集合

SELECT

*

FROM

user

WHERE

1 = 1AND CONCAT(user_name, user_account) LIKE CONCAT('%',#{searchParam},'%')

但是以上查询中,如果user_name 或者 user_account 中任意一个属性的所有数据为null时(比如account字段的所有值均未赋值,默认值为null),即使另一个中包含查询的数据,也查询不到数据。

两种解决方法:

1.给可能为null的查询字段设置默认值,空字符串或者其他;

2.改用or连接多个模糊查询

AND CONCAT(user_name, user_account) LIKE CONCAT('%',#{searchParam},'%')

改为

AND user_name like CONCAT('%',#{searchParam},'%')

or user_account like CONCAT('%',#{searchParam},'%')

and station_name like CONCAT('%',#{queryRecordVO.stationName},'%')

or user_number like CONCAT('%',#{queryRecordVO.stationName},'%')

3e81a4784df7f7cf75db4ae0df441642.png

感觉用or的话 用postman测试接口的时候 把前面模糊查询有点影响 查出来的数据感觉有点乱

第二种 CONCAT(VALUE_CODE, NAME)

SELECT

a.PARAM_CODE,

a.VALUE_CODE,

a.`NAME`,

a.IS_READ_ONLY,

a.DESCR

FROM

TPT_PARAM_CONFIG a

WHERE

1 = 1AND a.PARAM_CODE = #{paramCode}

AND CONCAT(`VALUE_CODE`, `NAME`) LIKE CONCAT('%',#{searchParam},'%')

注:CONCAT(VALUE_CODE, NAME) 其中字段如果是关键字是要用”`”来引起来的,不然会报错!

暂时在用第二种

第三种 concat_ws(...)

百度方法 https://jingyan.baidu.com/article/11c17a2c6da078f446e39daa.html

mysql可以对数据库多个字段同时进行模糊查询,例如:数据库设计中把姓名设计为两个字段,一个字段为姓LASTNAME,一个字段为名字FIRSTNAME。当界面进行模糊搜索时,mysql中有concat(...),concat_ws(...)两个函数。

例子如下:

SELCET * FROM T-USER U WHERE CONCAT(U.LASTNAME,U.FIRSTNAME) LIKE '%$LSP_NAME$%'

LASTNAME 字段是姓

FIRSTNAME字段是名字

e3124e85892caf8a385023d1135bf085.png

当查询字段为null时,返回结果为null。与concat_ws(...)不同。

4f796e30f65b031834ba87ec438500ab.png

如果为多个字段同时进行查询时,使用concat_ws(...).

select concat_ws(',','11','22','33');

select concat_ws(',','11','22','33',null);

都返回11,22,33

41daffa406948b17e39f84effe5a1b82.png

CONCAT_WS() 代表 CONCAT With Separator,是CONCAT()的特殊形式。第一个参数是其它参数的分隔符。分隔符的位置放在要连接的两个字符串之间。分隔符可以是一个字符串,也可以是其它参数。

1e117912ccdc125a50b7c3daade3f52c.png

CONCAT()可以连接一个或者多个字符串,CONCAT_WS()可以添加分割符参数。

5c382d9c5579878e83d8de1cdbebbc3e.png

  • 5
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为你解答。以下是一个简单的实现步骤: 1. 创建数据库表 首先,你需要在 MySQL 数据库中创建一个表来存储搜索数据。例如,可以创建一个名为 `product` 的表,包含 `id`、`name` 和 `description` 三个字段。 ```sql CREATE TABLE product ( id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(255), description TEXT ); ``` 2. 创建后端服务 使用 Spring Boot 和 MyBatis 框架来创建一个后端服务,可以接收搜索请求并从数据库中获取数据。具体实现步骤如下: - 添加相关依赖 在 `pom.xml` 文件中添加 MyBatisMySQL 相关依赖: ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.0.6</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.25</version> </dependency> ``` - 配置数据库连接 在 `application.properties` 中添加数据库连接配置: ``` spring.datasource.url=jdbc:mysql://localhost:3306/test?serverTimezone=UTC&useUnicode=true&characterEncoding=utf8&useSSL=false spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver ``` - 创建数据模型 创建一个名为 `Product` 的 Java 类,用于映射数据库表中的数据: ```java public class Product { private Integer id; private String name; private String description; // 省略 getter 和 setter 方法 } ``` - 创建 MyBatis 映射文件 创建一个名为 `ProductMapper.xml` 的 MyBatis 映射文件,用于定义 SQL 语句和数据模型的映射关系: ```xml <mapper namespace="com.example.demo.mapper.ProductMapper"> <select id="search" resultType="com.example.demo.model.Product"> SELECT * FROM product WHERE name LIKE CONCAT('%', #{keyword}, '%') </select> </mapper> ``` - 创建数据访问层 创建一个名为 `ProductMapper` 的 Java 接口,用于定义数据访问方法: ```java @Mapper public interface ProductMapper { List<Product> search(String keyword); } ``` - 创建控制器 创建一个名为 `ProductController` 的 Spring MVC 控制器,用于接收搜索请求和返回搜索结果: ```java @RestController public class ProductController { @Autowired private ProductMapper productMapper; @GetMapping("/search") public List<Product> search(@RequestParam("keyword") String keyword) { return productMapper.search(keyword); } } ``` 至此,后端服务的实现就完成了。 3. 创建前端界面 在前端界面中,可以使用 Vue 和 ElementUI 的 `el-input` 和 `el-table` 组件来实现搜索和显示数据的功能。例如,可以实现如下代码: ```html <template> <div> <el-input v-model="keyword" placeholder="请输入搜索关键字" @keyup.enter.native="search" /> <el-table :data="data"> <el-table-column prop="name" label="名称" /> <el-table-column prop="description" label="描述" /> </el-table> </div> </template> <script> export default { data() { return { keyword: '', data: [] }; }, methods: { async search() { const { data } = await this.$http.get('/search', { params: { keyword: this.keyword } }); this.data = data; } } }; </script> ``` 这段代码会创建一个包含搜索输入框和显示搜索结果的界面,当用户输入关键字并按下回车键时,会向后端发送搜索请求,并将结果显示在表格中。 以上就是一个简单的使用 Spring Boot、MyBatis、Vue 和 ElementUI 来创建搜索功能的实现步骤。当然,具体实现方式还需要根据你的具体需求来进行调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值