免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
MySql當(dāng)查詢條件為空時不作為條件查詢

之前遇到一個很麻煩的條件查詢。就是有很多個條件,并且條件可能有,也有可能沒有。又不是像mybatis那樣又專門的SQL.xml文件,需要自己寫sql文。這種情況下,需要去判斷每個條件是不是為空,后來發(fā)現(xiàn)一個很有用的sql語句,能非常簡單的解決這個問題。

我們先上表:

  1. CREATE TABLE `clazz` (
  2. `id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵',
  3. `title` VARCHAR(140) NOT NULL DEFAULT '0' COMMENT '題目',
  4. `desc` VARCHAR(200) NULL DEFAULT NULL COMMENT '課節(jié)描述',
  5. `courseId` INT(11) NOT NULL DEFAULT '1' COMMENT '所屬課程',
  6. `video` VARCHAR(200) NULL DEFAULT NULL COMMENT '課節(jié)視頻地址',
  7. `work` INT(11) NOT NULL DEFAULT '0' COMMENT '0是無效,1是有效',
  8. `createId` INT(11) NOT NULL COMMENT '創(chuàng)建課節(jié)的管理員id',
  9. `createTime` DATETIME NULL DEFAULT NULL COMMENT '課節(jié)創(chuàng)建時間',
  10. `order` INT(11) NULL DEFAULT '0' COMMENT '順序',
  11. `level` INT(11) NOT NULL DEFAULT '0' COMMENT '0是免費(fèi)課程,1是付費(fèi)課程',
  12. PRIMARY KEY (`id`)
  13. )
  14. COMMENT='課節(jié)'
  15. COLLATE='utf8_general_ci'
  16. ENGINE=InnoDB
  17. AUTO_INCREMENT=10
  18. ;

我們的查詢條件有title、desc、courseId、creatId、creadTime五個條件,desc為模糊查詢。這種多條件的情況下,我一開始時每個條件都會依次去判斷是不是存在,然后根據(jù)判斷結(jié)果去寫sql文,這樣下來這個方法的內(nèi)容時非常龐大并且很容易出錯的。我在網(wǎng)上找了找,然后發(fā)現(xiàn)了一個方法,按照那個方法是這個樣的:select * from 表 where (字段=條件 or 條件=' ');這句SQL,我是這樣理解的,當(dāng)條件不為空時SQL就是這樣的:select * from 表 where 字段=條件; 當(dāng)條件為空時SQL就是這樣的:select * from 表 where ' '=' ';所以就滿足了多條件并且條件是不是為空未知查詢的這種情況。

然后來說我的這個查詢。title需要輸入完整的數(shù)據(jù);desc不需要完整的數(shù)據(jù),模糊查詢;courseId為0時是查詢?nèi)?,不?時時查詢對應(yīng)的課程id;creatId為0時是查詢?nèi)?,不?時時查詢對應(yīng)的創(chuàng)建者id;creadTime我們需要查的是時間是否在我們傳入的這個時間區(qū)間內(nèi),傳入的開始結(jié)束時間區(qū)間要存在則都存在,要不存在則都不存在。下面是我的查詢方法片段:

  1. ?
  2. /**
  3. * 條件查詢
  4. *
  5. * @param title
  6. * @param desc
  7. * @param courseId
  8. * @param createId
  9. * @param startTime
  10. * @param endTime
  11. * @return
  12. */
  13. public List<Clazz> findByPara(String title, String desc, int courseId, int createId, String startTime,
  14. String endTime) {
  15. desc = "%" + desc + "%";
  16. String sql = "select * from clazz cl where (cl.title=? or ?='')"
  17. + " and cl.`desc` like ?"
  18. + " and (cl.courseId=? or ?=0) "
  19. + "and (cl.createId=? or ?=0) "
  20. + "and (cl.createTime between ? and ? or ?='')";
  21. return dao.find(sql, title, title, desc, courseId, courseId, createId, createId, startTime, endTime,
  22. startTime);
  23. }
  24. ?

這樣做就不會像之前那樣,方法龐大還容易出錯。

寫下來自己可以看看,亦希望能幫到大家?。?!

本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
總結(jié)SQL Server窗口函數(shù)的簡單使用
數(shù)據(jù)庫操作類(SQLHelper)
急,這個SQL不會寫了,大家?guī)臀铱纯丛趺磳懙?
Oracle(PLSQL)入門學(xué)習(xí)二
ibatis動態(tài)sql
MySQL 語法小冊
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服