ホームページ データベース mysql チュートリアル Mysql使用自定义方法以及cakephp分页使用join查询的方法_MySQL

Mysql使用自定义方法以及cakephp分页使用join查询的方法_MySQL

Jun 01, 2016 pm 01:37 PM
cakephp

bitsCN.com

Mysql使用自定义方法以及cakephp分页使用join查询的方法

 

第一步:设置SET GLOBAL log_bin_trust_function_creators=TRUE;

如果报ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable)这种错误

第二步:

Sql代码  

DELIMITER $$  

  

USE `zhiku`$$  

  

DROP FUNCTION IF EXISTS `getChildDept`$$  

  

CREATE  FUNCTION `getChildDept`(rootId INT) RETURNS TEXT CHARSET utf8  

BEGIN  

    DECLARE sTemp VARCHAR(1000);  

    DECLARE sTempChd VARCHAR(1000);  

    SET sTemp = '$';  

    SET sTempChd =CAST(rootId AS CHAR);  

    WHILE sTempChd IS NOT NULL DO  

        SET sTemp = CONCAT(sTemp,',',sTempChd);  

        SELECT GROUP_CONCAT(id) INTO sTempChd FROM zk_departments WHERE FIND_IN_SET(parent_id,sTempChd)>0;  

    END WHILE;  

    RETURN sTemp;  

    END$$  

DELIMITER ;  

 

第三步:直接调用

SELECT DISTINCT(d.user_id) AS user_id,d.dept_id,u.compellation FROM zk_user_departments d INNER JOIN zk_users u ON u.id=d.user_id  AND  INSTR(u.pinyin,'h')=2 WHERE FIND_IN_SET(d.dept_id, getChildDept(128)) GROUP BY d.user_id;

放在cakephp为:

Php代码  

$conditions = array('FIND_IN_SET(dept_id, getChildDept('.$dept_id.'))');  

            $condition_join = '`User`.`id` = `UserDepartment`.`user_id`';  

            if(!emptyempty($c))$condition_join  .= ' AND INSTR(User.pinyin,"'.$c.'")=2';  

            //分页  

            $this->paginate = array(  

                    'UserDepartment' => array(  

                            'conditions' => $conditions,  

                            'order'      => array('dept_id'=>'ASC'),  

                            'limit'      => 10,  

                            'recursive'  => -1,  

                            'group'      => array('user_id'),  

                            'fields'     => array('user_id','dept_id'),  

                            'joins'      => array(array(  

                                                 'alias' => 'User',  

                                                 'table' => 'zk_users',  

                                                 'type' => 'INNER',  

                                                 'conditions' => $condition_join,  

                                            )),  

                    )  

            );  

            $data = $this->paginate('UserDepartment');  

 

bitsCN.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

CakePHP プロジェクトの構成 CakePHP プロジェクトの構成 Sep 10, 2024 pm 05:25 PM

この章では、CakePHP の環境変数、一般設定、データベース設定、電子メール設定について理解します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP でデータベース クエリ ビルダーを使用するにはどうすればよいですか? CakePHP でデータベース クエリ ビルダーを使用するにはどうすればよいですか? Jun 04, 2023 am 09:02 AM

CakePHP は、Web アプリケーション開発で広く使用されているオープンソースの PHPMVC フレームワークです。 CakePHP には、インタラクティブなパフォーマンス データベース用の強力なデータベース クエリ ビルダーなど、多くの機能とツールがあります。このクエリ ビルダーを使用すると、面倒な SQL ステートメントを作成することなく、オブジェクト指向構文を使用して SQL クエリを実行できます。この記事では、CakePHP でデータベース クエリ ビルダーを使用する方法を紹介します。データベース接続の確立 データベース クエリ ビルダーを使用する前に、まず Ca でデータベース接続を作成する必要があります。

CakePHP でカスタム ページネーションを作成するにはどうすればよいですか? CakePHP でカスタム ページネーションを作成するにはどうすればよいですか? Jun 04, 2023 am 08:32 AM

CakePHP は、開発者に多くの便利なツールと機能を提供する強力な PHP フレームワークです。その 1 つはページネーションです。これは、大量のデータを複数のページに分割し、閲覧と操作を容易にするのに役立ちます。デフォルトでは、CakePHP はいくつかの基本的なページネーション メソッドを提供しますが、場合によってはカスタムのページネーション メソッドを作成する必要がある場合があります。この記事では、CakePHP でカスタム ページネーションを作成する方法を説明します。ステップ 1: カスタム ページネーション クラスを作成する まず、カスタム ページネーション クラスを作成する必要があります。これ

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

この章では、ルーティングに関連する次のトピックを学習します。

CakePHP はファイルのアップロードをどのように処理しますか? CakePHP はファイルのアップロードをどのように処理しますか? Jun 04, 2023 pm 07:21 PM

CakePHP は、Web アプリケーションの開発プロセスを簡素化する、PHP 言語に基づいて構築されたオープンソース Web アプリケーション フレームワークです。 CakePHP ではファイルのアップロード処理が一般的な要件であり、アバター、写真、ドキュメントのアップロードのいずれであっても、対応する機能をプログラムに実装する必要があります。この記事では、CakePHPでのファイルアップロードの扱い方と注意点を紹介します。アップロードされたファイルをコントローラーで処理する CakePHP では、アップロードされたファイルは通常 Cont で処理されます。

CakePHP で Twig を使用するにはどうすればよいですか? CakePHP で Twig を使用するにはどうすればよいですか? Jun 05, 2023 pm 07:51 PM

CakePHP で Twig を使用すると、テンプレートとビューを分離し、コードをよりモジュール化して保守しやすくすることができます。この記事では、CakePHP で Twig を使用する方法を紹介します。 1. Twig をインストールします。まずプロジェクトに Twig ライブラリをインストールします。このタスクは Composer を使用して完了できます。コンソールで次のコマンドを実行します:composerrequire "twig/twig:^2.0" このコマンドはプロジェクトのベンダーに表示されます。

See all articles