色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

MySQL 數據庫 like 語句通配符模糊查詢小結

瀏覽:119日期:2023-10-10 12:58:28

MySQL 報錯:Parameter index out of range (1 > number of parameters, which is 0)——MySQL 數據庫 like 語句通配符模糊查詢小結

前言 今天在使用MySQL語句執行增刪改查操作時,控制臺報出了以下錯誤:Parameter index out of range (1 > number of parameters, which is 0)。翻譯過來意思就是:查到結果數據為1,真實值應為0,參數越界,產生錯誤。如此也就明確了我們具體出錯的地方——參數,即對于通配符'?'的處理。本文分別對執行普通 SQL 語句以及使用 like 語句進行通配符模糊查詢遇到本錯誤進行了剖析,并給出解決方案。

MySQL 數據庫 like 語句通配符模糊查詢小結

一、分析 SQL 語句

1、普通 SQL 語句的查詢分析

首先,我們來分析一下我之前使用的 SQL 語句:

String sql = 'select count(*) from tab_route where cid = ?';

說明:我們直接使用通配符'?'來代替參數,使用 Spring 框架的 JdbcTemplate 執行增刪改查操作。在這里是沒有任何問題的。

2、普通 SQL 查詢語句如何處理

如果在這里出錯,請按照如下方式進行解決:

檢查通配符'?'的格式,注意是在英文輸入法下輸入,非中文問號;檢查 SQL 語句,使用通配符傳遞的參數是不加引號的,比如下面的就是錯誤的:

String sql = 'select count(*) from tab_route where cid = ’?’';

3、使用 like 通配符模糊查詢語句分析

同理,我們依舊采用上面的方式進行模糊查詢操作,來看一下出錯的 SQL 語句:

String sql = 'select count(*) from tab_route where rname like ’%?%’;

執行結果報錯:Parameter index out of range (1 > number of parameters, which is 0)。

結果分析:查到結果數據為1,真實值應為0,參數越界,產生錯誤。

我們明確如下語句是沒有任何問題的:

String sql = select * from tab_route where rname like ’%張%’;

如此也就明確了我們具體出錯的地方——參數,即對于 like 語句中通配符'?'的處理。

二、like 語句使用通配符模糊查詢剖析

1、like 語句的應用場景

使用 like 通配符進行模糊查詢是我們在項目中常遇到的,比如在搜索框中對于數據的模糊查詢。

2、模糊查詢剖析

在 SQL 語句中無法直接對’%?%’進行解析,所以我們需要對連接的字符串進行處理,使用動態拼接concat()方法將’%?%’中的內容進行連接,然后再執行增刪改查操作。

concat(str1,str2,str3...)會生成一個新的字符串

3、正確語句

String sql = 'select count(*) from tab_route where rname like concat(’%’,?,’%’)';

三、MyBatis like 模糊查詢及關鍵字區分

在 MyBatis 中使用 like 模糊查詢,應注意關鍵字為:#{str},查詢子句為:

select * from table where name like concat(’%’,#{name},’%’);

而如果添加排序字段,應注意關鍵字為:${str},查詢子句為:

select * from table where name like concat(’%’,#{name},’%’) order by ${id};

總結 本文分別對執行普通 SQL 語句以及使用 like 語句進行通配符模糊查詢遇到錯誤進行了剖析,并給出相應解決方案。同時補充了在 MyBatis 中對模糊查詢的操作以及不同關鍵字的區分。代碼之路漫漫,望諸君細致。

MySQL 數據庫 like 語句通配符模糊查詢小結

到此這篇關于MySQL 數據庫 like 語句通配符模糊查詢小結的文章就介紹到這了,更多相關MySQL 模糊查詢like內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 一级一片免费播放 | 久久中文字幕综合不卡一二区 | 免费一看一级毛片全播放 | 日韩成人在线视频 | 一级毛片在播放免费 | 日韩一级黄色 | www国产91| 欧美毛片性视频区 | 亚洲天堂成人在线观看 | 欧美日韩在线视频 | 一区二区播放 | 一 级做人爱全视频在线看 一本不卡 | 国产亚洲一区二区手机在线观看 | 国产精品视频久 | 三级视频在线 | 国产高清美女一级a毛片久久 | 亚洲 欧美 国产 中文 | 日韩一区二区三区在线视频 | 欧美精品免费在线 | 国产精品久久久久网站 | 欧美一区二区在线视频 | 一区二区三区免费观看 | 狼人青草久久网尹人 | 美女免费毛片 | 三级全黄a| 国产免费高清在线精品一区 | 亚洲天堂精品在线观看 | 一级毛片观看 | 亚洲成a人不卡在线观看 | 免费看岛国视频在线观看 | 久久99亚洲精品久久久久 | 欧美视频在线观在线看 | 久久精品国内偷自一区 | 中文字幕免费在线视频 | 伊人狠狠丁香婷婷综合色 | 久久精品国产一区二区 | 国产精品九九免费视频 | 色综合久久88色综合天天提莫 | 亚洲欧美在线观看播放 | 欧美成年黄网站色高清视频 | 久久精品二三区 |