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

目录

1.需求

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

2.实现

输入框使用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函数:

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

SearchResult.vue代码

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

created函数中获取输入框传来的keyWord

getData(offset,limit)函数使用axios向后端根据keyWord查询数据,其中offsetlimit是分页查询的参数。

//请求数据库数据的方法
    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\'%,算踩了一个坑吧。
然后这是根据输入的数据模糊查询标题,也就是数据段title的,可以改为查询其他的内容。

3.结果

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

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容