您好,登錄后才能下訂單哦!
這篇文章主要介紹“weed3-2.3.2.查詢的條件是什么”,在日常操作中,相信很多人在weed3-2.3.2.查詢的條件是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”weed3-2.3.2.查詢的條件是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
源碼:https://github.com/noear/weed3 源碼:https://gitee.com/noear/weed3
單表條件查詢(有了簡單的自然能拼成復雜的)
//weed3 的條件構建,是相當自由的 String mobile = "111"; db.table("test") .where("mobile=?",mobile).and().begin("sex=?",1).or("sex=2").end() .limit(20) .select("*").getMapList() db.table("test") .where("mobile=?",mobile).and("(sex=? OR sex=2)",1) .limit(20) .select("*").getMapList() db.table("test").where("mible=? AND (sex=1 OR sex=2)",mobile) .limit(20) .select("*") //以上三種,效果是一樣的。。。因為很自由,所以很容易使用(也有觀點認為:所以很難控制)
有時候一些條件需要動態控制
//這個示例,管理后臺很常見 int type=ctx.paramAsInt("type",0); String key=ctx.param("key"); int date_start=ctx.paramAsInt("date_start",0); int date_end=ctx.paramAsInt("date_end",0); DbTableQuery qr = db.table("test").where("1=1"); if(type > 0){ qr.and("type=?", type); } if(key != null){ qr.and('"title LIKE ?",key+"%"); } if(date_start>0 && date_end >0){ qr.and("( date >=? AND date<=? )", date_start, date_end); } qr.select("id,title,icon,slug").getMapList();
多表關聯查詢:innerJoin(..), leftJoin(..), rightJoin(..)
//innerJoin() db.table("user u") .innerJoin("user_book b").on("u.id = b.user_id") .select("u.name,b.*") //leftJoin() db.table("user u") .leftJoin("user_book b").on("u.id = b.user_id").and("u.type=1") .select("u.name,b.*") //rightJoin() db.table("user u") .rightJoin("user_book b").on("u.id = b.user_id") .where("b.type=1").and("b.price>",12) .select("u.name,b.*")
想別的關聯查詢怎么樣?(如:full join)
//因為不是所有的數據庫都支持 full join,所以... db.table("user u") .append("FULL JOIN user_book b").on("u.id = b.user_id") .select("u.name,b.*") //.append(..) 可以添加任何內容的接口
到此,關于“weed3-2.3.2.查詢的條件是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。