最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-09 18:28:04
文档

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

Mysql使用自定义方法以及cakephp分页使用join查询的方法_MySQL:bitsCN.com Mysql使用自定义方法以及cakephp分页使用join查询的方法 第一步:设置SET GLOBAL log_bin_trust_function_creators=TRUE;如果报ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO
推荐度:
导读Mysql使用自定义方法以及cakephp分页使用join查询的方法_MySQL:bitsCN.com Mysql使用自定义方法以及cakephp分页使用join查询的方法 第一步:设置SET GLOBAL log_bin_trust_function_creators=TRUE;如果报ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO


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

文档

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

Mysql使用自定义方法以及cakephp分页使用join查询的方法_MySQL:bitsCN.com Mysql使用自定义方法以及cakephp分页使用join查询的方法 第一步:设置SET GLOBAL log_bin_trust_function_creators=TRUE;如果报ERROR 1418 (HY000): This function has none of DETERMINISTIC, NO
推荐度:
标签: mysql join CakePHP
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top