検索

ホームページ  >  に質問  >  本文

tp5 フレームワークを使用して SQL ステートメントを作成する

tp を使用して次の SQL ステートメントを記述するにはどうすればよいですか?

rreeee

**1240日前1184

全員に返信(3)返信します

  • *

    *2021-09-03 17:57:42

    プロジェクト内のコード

    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 = 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';
    }

    返事
    0
  • 小李大人

    小李大人2021-09-03 17:39:56

    $sql = 'あなたの SQL';

    $結果 = Db::query($sql);

    返事
    0
  • *

    ありがとうございます。でも、ネイティブ バージョンを使用した私のコードは少し複雑で、あまり使いやすいものではありません。ここに簡単な例を書いただけです。プロジェクトではクロージャー クエリを使用しました。現時点では、この方法が最善ではありません。

    * · 2021-09-03 17:48:20
  • キャンセル返事