입력 상자에 데이터를 입력하고 입력 결과를 기반으로 데이터베이스의 해당 내용을 퍼지 검색하여 퍼지 쿼리를 수행합니다.
v-model
양방향 바인딩을 사용하여 keyWord
데이터를 쿼리하는 입력 상자를 구현합니다. v-model
双向绑定查询数据keyWord
。
<el-input v-model="keyWord" placeholder="请输入关键字搜索" clearable></el-input> <el-button type="success" icon="el-icon-search" @click="search"></el-button>
由于输入框和显示结果的不再同一view
下,所以在路由跳转时将搜索结果传递给显示结果的页面,这里用的query
。
search函数:
SearchResult.vue
代码
在created
函数中获取输入框传来的keyWord
getData(offset,limit)
函数使用axios
向后端根据keyWord
查询数据,其中offset
和limit
是分页查询的参数。
//请求数据库数据的方法 getData(offset,limit){ this.axios.post('/php/search.php', qs.stringify({ offset: offset, limit: limit, keyWord: this.keyWord }), { headers: { 'Content-Type': 'application/x-www-form-urlencoded' } }).then((res) => { this.total = res.data.total this.resultList = res.data.data }).catch((err) => { this.$message.error(err) })
获取数据成功后就会将数据存入resultList
数组中,只需循环遍历该数组就可以向前端展示查询结果了。
后端使用的是php
写的,主要利用了sql
语句的like
来实现模糊查询。
后端search.php
文件,将数据库连接基本信息改为自己的。
<?php $servername = "主机地址"; $username = "账户"; $password = "密码"; $dbname = "数据库名称"; // 创建连接 $conn = new mysqli($servername, $username, $password, $dbname); // Check connection if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); } $keyWord = $_POST['keyWord']; //获取前端的参数 开始和结束number if ( !isset( $_POST['offset'] ) ) { echo 0; exit(); }; $offset = ( int )$_POST['offset']; if ( !isset( $_POST['limit'] ) ) { echo 0; exit(); }; $limit = ( int )$_POST['limit']; //分页查询数据库 $sql = "SELECT * FROM posts where title like '%$keyWord%' order by id desc LIMIT $limit OFFSET $offset"; $result = $conn->query($sql); $sqlGetCount = "SELECT COUNT(*) cnt FROM posts where title like '%$keyWord%'"; $rescnt = $conn->query($sqlGetCount); $rescnt = $rescnt->fetch_assoc(); $arr = array(); if ($result->num_rows > 0) { while ( $row = $result->fetch_assoc() ) { array_push( $arr, $row ); } //echo json_encode( $arr, JSON_UNESCAPED_UNICODE ); echo json_encode(array_merge(array('data'=>$arr),array('total'=>(int)$rescnt['cnt']))); } else { echo 0; } mysqli_close( $conn ); ?>
注意sql语句:
SELECT * FROM posts where title like '%$keyWord%' order by id desc LIMIT $limit OFFSET $offset;
like
后面应该使用 '%$keyWord%‘
传递参数,而不是 %' $keyWord'%
rrreee
입력란과 표시 결과가 더 이상 동일한 보기
에 있지 않으므로 경로 점프 시 검색 결과가 결과가 표시되는 페이지로 전달됩니다. /code>가 여기에 사용됩니다.
SearchResult.vue
code🎜🎜🎜🎜🎜created
함수의 입력 상자에서 keyWord
를 가져옵니다🎜🎜 getData(offset,limit)
함수는 axios
를 사용하여 백엔드에서 keyWord
를 기반으로 데이터를 쿼리합니다. 여기서 offset
limit
는 페이징 쿼리의 매개변수입니다. 🎜rrreee🎜데이터를 성공적으로 얻은 후에는 데이터가 resultList
배열에 저장됩니다. 쿼리 결과를 프런트 엔드에 표시하려면 배열을 반복하기만 하면 됩니다. 🎜🎜백엔드는 php
로 작성되었으며 주로 sql
문의 like
를 사용하여 퍼지 쿼리를 구현합니다. 🎜백엔드 search.php
파일에서 기본 데이터베이스 연결 정보를 원하는 대로 변경하세요. 🎜rrreee🎜SQL 문에 유의하세요. 🎜rrreee🎜like
뒤에 '%$keyWord%'
가 와야 % '$keyWord'%
, 함정입니다. 🎜이것은 입력 데이터를 기반으로 한 퍼지 쿼리 제목이며, 이는 데이터 세그먼트의 제목으로 변경되어 다른 콘텐츠를 쿼리할 수 있습니다. 🎜🎜3. 결과🎜🎜🎜🎜위 내용은 Vue가 Mysql 데이터베이스 데이터의 퍼지 쿼리를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!