700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > Vue实现模糊查询Mysql数据库数据

Vue实现模糊查询Mysql数据库数据

时间:2022-06-19 10:41:12

相关推荐

Vue实现模糊查询Mysql数据库数据

需求

输入框中输入数据,根据输入的结果模糊搜索数据库对应内容,实现模糊查询。

实现

输入框使用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.totalthis.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 connectionif ($conn->connect_error) {die("连接失败: " . $conn->connect_error);} $keyWord = $_POST['keyWord'];//获取前端的参数 开始和结束numberif ( !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’%,算踩了一个坑吧。

然后这是根据输入的数据模糊查询标题,也就是数据段title的,可以改为查询其他的内容。

结果

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。