之前遇到一個很麻煩的條件查詢。就是有很多個條件,并且條件可能有,也有可能沒有。又不是像mybatis那樣又專門的SQL.xml文件,需要自己寫sql文。這種情況下,需要去判斷每個條件是不是為空,后來發(fā)現(xiàn)一個很有用的sql語句,能非常簡單的解決這個問題。 我們先上表:
我們的查詢條件有title、desc、courseId、creatId、creadTime五個條件,desc為模糊查詢。這種多條件的情況下,我一開始時每個條件都會依次去判斷是不是存在,然后根據(jù)判斷結(jié)果去寫sql文,這樣下來這個方法的內(nèi)容時非常龐大并且很容易出錯的。我在網(wǎng)上找了找,然后發(fā)現(xiàn)了一個方法,按照那個方法是這個樣的:select * from 表 where (字段=條件 or 條件=' ');這句SQL,我是這樣理解的,當條件不為空時SQL就是這樣的:select * from 表 where 字段=條件; 當條件為空時SQL就是這樣的:select * from 表 where ' '=' ';所以就滿足了多條件并且條件是不是為空未知查詢的這種情況。 然后來說我的這個查詢。title需要輸入完整的數(shù)據(jù);desc不需要完整的數(shù)據(jù),模糊查詢;courseId為0時是查詢?nèi)?,不?時時查詢對應的課程id;creatId為0時是查詢?nèi)?,不?時時查詢對應的創(chuàng)建者id;creadTime我們需要查的是時間是否在我們傳入的這個時間區(qū)間內(nèi),傳入的開始結(jié)束時間區(qū)間要存在則都存在,要不存在則都不存在。下面是我的查詢方法片段:
這樣做就不會像之前那樣,方法龐大還容易出錯。 寫下來自己可以看看,亦希望能幫到大家?。?! |
|
來自: hongjing_z > 《Mysql》