首頁 > 資料庫 > mysql教程 > Vue怎麼實作Mysql資料庫資料的模糊查詢

Vue怎麼實作Mysql資料庫資料的模糊查詢

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2023-06-02 11:31:37
轉載
1349 人瀏覽過

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(&#39;/php/search.php&#39;, qs.stringify({
        offset: offset,
        limit: limit,
        keyWord: this.keyWord
      }), { headers: { &#39;Content-Type&#39;: &#39;application/x-www-form-urlencoded&#39; } }).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[&#39;keyWord&#39;];
//获取前端的参数 开始和结束number
if ( !isset( $_POST[&#39;offset&#39;] ) ) {
 echo 0;
 exit();
};
$offset = ( int )$_POST[&#39;offset&#39;];

if ( !isset( $_POST[&#39;limit&#39;] ) ) {
 echo 0;
 exit();
};
$limit = ( int )$_POST[&#39;limit&#39;];
//分页查询数据库
$sql = "SELECT * FROM posts where title like &#39;%$keyWord%&#39; order by id desc LIMIT $limit OFFSET $offset";
$result = $conn->query($sql);

$sqlGetCount = "SELECT COUNT(*) cnt FROM posts where title like &#39;%$keyWord%&#39;";
$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(&#39;data&#39;=>$arr),array(&#39;total&#39;=>(int)$rescnt[&#39;cnt&#39;])));
 
} else {
    echo 0;
}
mysqli_close( $conn );
?>
登入後複製

注意sql語句:

SELECT * FROM posts where title like &#39;%$keyWord%&#39; order by id desc LIMIT $limit OFFSET $offset;
登入後複製

#like後面應該使用 '%$keyWord%'傳遞參數,而不是%' $keyWord'%,算踩了一個坑吧。
接著這是根據輸入的資料模糊查詢標題,也就是資料段title的,可以改為查詢其他的內容。

3.結果

Vue怎麼實作Mysql資料庫資料的模糊查詢

以上是Vue怎麼實作Mysql資料庫資料的模糊查詢的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:yisu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
javascript - Vue 未定義
來自於 1970-01-01 08:00:00
0
0
0
javascript - 如何在vue-router中存取VUE實例?
來自於 1970-01-01 08:00:00
0
0
0
javascript - vue-for-idea
來自於 1970-01-01 08:00:00
0
0
0
沒看過VUE的專案實戰
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板