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

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

用tp5框架寫sql語句

瀏覽:103日期:2022-06-01 16:12:31

問題描述

如何用tp寫如下sql語句?

select * from `student` where sex = 1 and ((`age` in (10,11,12) and `name` like '%李%') or (`age` in (15,16,17) and `name` like '%長%'));

問題解答

回答1:

在項目中的代碼

model('MaterialLike')->alias('like_material')->join('materials materials' , $materialsAlias.'id = '.$likeMaterailsAlias. 'material_id')->where($map)->where(function ($query) use ($where_map){ $query->where($where_map);})->whereOr(function ($query) use ($where_or_map){ $query->where($where_or_map);})->field($field)->order($order)->page($page,$limit)->select();

打印的sql語句是

SELECT `materials`.`id`, `materials`.`uid`, `materials`.`title`, `materials`.`type`, `materials`.`tag`, `materials`.`description`, `materials`.`content`, `materials`.`photo_list`, `materials`.`video_list`, `materials`.`view`, `materials`.`likes`, `materials`.`share`, `materials`.`comment`, `materials`.`customer`, `materials`.`create_time`, `materials`.`is_top`, `materials`.`status` FROM `ap_material_like` `like_material` INNER JOIN `ap_materials` `materials` ON `materials`.`id` = `like_material`.`material_id` WHERE `materials`.`seller_id` = 2 AND `materials`.`status` = 1 AND `materials`.`display` = 1 AND( `materials`.`m_category_id` IN ( 10001, 10005, 10008 ) AND ( ( `materials`.`tag` LIKE '%胖%' ) OR ( `materials`.`content` LIKE '%胖%' ) ) AND `like_material`.`uid` = '196893' AND `like_material`.`typeid` = 3 AND `like_material`.`status` = 1 ) OR ( `materials`.`m_category_id` IN ( 10011, 10012, 10013, 10014, 10015 ) AND ( ( `materials`.`title` LIKE '%胖%' ) OR ( `materials`.`description` LIKE '%胖%' ) OR ( `materials`.`tag` LIKE '%胖%' ) ) AND `like_material`.`uid` = '196893' AND `like_material`.`typeid` = 3 AND `like_material`.`status` = 1 ) ORDER BY `like_material`.`create_time` DESC LIMIT 0, 20

然后我實際的需要的是

SELECT `materials`.`id`, `materials`.`uid`, `materials`.`title`, `materials`.`type`, `materials`.`tag`, `materials`.`description`, `materials`.`content`, `materials`.`photo_list`, `materials`.`video_list`, `materials`.`view`, `materials`.`likes`, `materials`.`share`, `materials`.`comment`, `materials`.`customer`, `materials`.`create_time`, `materials`.`is_top`, `materials`.`status` FROM `ap_material_like` `like_material` INNER JOIN `ap_materials` `materials` ON `materials`.`id` = `like_material`.`material_id` WHERE `materials`.`seller_id` = 2 AND `materials`.`status` = 1 AND `materials`.`display` = 1 AND ( {括號開頭} (`materials`.`m_category_id` IN ( 10001, 10016, 10017 ) AND ( ( `materials`.`tag` LIKE '%胖%' ) OR ( `materials`.`content` LIKE '%胖%' ) ) AND `like_material`.`uid` = '196893' AND `like_material`.`typeid` = 3 AND `like_material`.`status` = 1 ) OR (`materials`.`m_category_id` IN ( 10020, 10021, 10022, 10023, 10024 ) AND ( ( `materials`.`title` LIKE '%胖%' ) OR ( `materials`.`description` LIKE '%胖%' ) OR ( `materials`.`tag` LIKE '%胖%' ) ) AND `like_material`.`uid` = '196893' AND `like_material`.`typeid` = 3 AND `like_material`.`status` = 1 ) ){括號結束}ORDER BY `like_material`.`create_time` DESC LIMIT 0, 20

而且這個keyword還是這樣的

$keyword = trim($keyword);if($keyword !== '') { $keywords = explode(' ', $keyword); //把空字符串的元素篩選掉 $keywords = array_filter($keywords, function ($i) {return $i != ''; }); foreach ($keywords as $key => $val) {$keyword_where[] = array('like', "%{$val}%"); } $keyword_where[] = 'or';}回答2:

$sql = '你的sql';

$result = Db::query($sql);

相關文章:
主站蜘蛛池模板: 国产成人免费手机在线观看视频 | 亚洲国产成a人v在线观看 | 一级片中文字幕 | 欧美日韩一区二区综合 | 国产在线观看免费一级 | 一级毛片区 | 99久久精品费精品国产一区二区 | 欧美高清性刺激毛片 | 亚洲欧美国产高清va在线播放 | 怡红院成人在线 | 成人在线观看不卡 | 亚洲精品国产成人 | 精品国产免费第一区二区 | 91精品国产美女福到在线不卡 | 99久久综合国产精品免费 | 亚洲视频手机在线 | 日本免费毛片在线高清看 | 国产精品毛片一区 | 国产午夜免费视频片夜色 | 成人二区| 日本69xxxxxxxxx69 日本a v 黄 日本aaaa级 日本aaaa级毛片在线看 | 成人在线精品视频 | 日本三级成人中文字幕乱码 | 欧美日韩亚洲综合久久久 | 亚洲图片视频在线观看 | 亚洲精品99久久久久中文字幕 | 日韩欧美久久一区二区 | 一区二区三区在线看 | 美女黄页网站免费进入 | 国产欧美日韩综合二区三区 | 日韩三级精品 | 成人国产一区二区三区 | 国产一级做a爰片在线看免费 | 成人欧美一区二区三区黑人免费 | 亚洲免费视频一区二区三区 | 手机免费看毛片 | 日本在线观看不卡免费视频 | 欧美做爰性欧美 | 玖草在线观看 | 亚洲国产激情 | 欧美午夜免费观看福利片 |