SQL과 유사한 구문을 통해 쿼리할 수 있는 PHP 버전의 MONGODB 구문 분석기를 작성했습니다. 필요한 사람이 있을지 모르니 공유해 주세요.
转载请注明作者:wetouns
在使用MONGODB的时候写查询语句总是一件让人蛋疼的事情,如果查询复杂一点,要嵌套好多层对象,于是我就想,能不能使用类似SQL的语法来进行查询呢,这样子代码看起来更加易懂,书写也更为简单,于是就花了些时间把这个想法变为现实该解析器会将类似SQL的语法转换成MONGODB的查询对象,目前条件判断只支持and和or,以及>,=,
例1,我要查询a=0的文档
$query = new MongoQueryParser(); $query->query("a=0"); $queryRst = $query->result;
最终$queryRst的结果将会如下图
例2:
这回来个复杂点的
$query = new MongoQueryParser(); $query->query("a=0 && b > 2"); $queryRst = $query->result;结果如下
例3:
再来个更复杂的
$query = new MongoQueryParser(); $query->query("(a=0 && b > 2) || c result;结果如下
看完以上3个例子,相信不用说明用法,应该也会用了吧,嘿嘿,废话少说,贴上解析器的源码
<?php class MongoQueryParser { function __construct() { $this->result =[]; } public $result; public $leftFirstReg = "/\\(([^\\s]+)\\)(&&|\\|\\|)([^\\s]+$)/";//匹配左括号优先 public $rightFirstReg = "/([^\\s]+?)(&&|\\|\\|)\\(([^\\s]+)\\)$/";//右括号优先 public $allReg = "/\\(([^\\s]+)\\)(&&|\\|\\|)\\(([^\\s]+)\\)$/";//左右括号模式 public $reg1 = "/([^\\s]+)(&&|\\|\\|)([^\\s]+)/"; public $reg2 = "/([\\w]+)([=]+)([^\\s]+)/"; public $opMap = [">"=>'$gt',"'$lt',">="=>'$gte',"'$lte']; private $meetOr = false; /** * 将自定义的查询语句转换成MONGODB的查询语句 * 例1:a=3 * 例2:a>0&&a0&&a3 */ function query($query){ $query =preg_replace("/\s/","",$query); $this->result = $this->exec($query,false,false); return $this->result; } function exec($query,$layer,$fromAnd){ if(preg_match($this->allReg, $query,$matches1) > 0 || preg_match($this->rightFirstReg, $query,$matches2) > 0 || preg_match($this->leftFirstReg, $query,$matches3) > 0 || preg_match($this->reg1, $query,$matches4)){ $mat = null; $leftSame = false; $rightSame = false; if(count($matches1) > 0){ $mat = $matches1; }else if(count($matches2) > 0){ $leftSame = true; $rightSame = false; $mat = $matches2; }else if(count($matches3) > 0){ $leftSame = false; $rightSame = true; $mat = $matches3; }else if(count($matches4) > 0){ $leftSame = true; $rightSame = true; $mat = $matches4; } $op = $mat[2]; $left = $mat[1]; $right = $mat[3]; if($op == "&&"){//如果操作符是AND $rst = null; if(!$layer || !$fromAnd){//如果不同层,或者调用来自上一层的or,那么就建立一个$and操作符 $rst['$and'] = []; $larr = $this->exec($mat[1],$leftSame,true); $rarr = $this->exec($mat[3],$rightSame,true); $rst['$and'] = $this->mergeArr($rst['$and'],$larr, $rarr); return $rst; }else{//如果同层,直接把值都放到同层数组去 $rst = array_merge($this->exec($mat[1],$leftSame,true),$this->exec($mat[3],$rightSame,true)); return $rst; } }else if($op == "||"){ if(!$layer || $fromAnd){//如果不同层 $rst['$or'] = []; $larr = $this->exec($mat[1],$leftSame,false); $rarr = $this->exec($mat[3],$rightSame,false); $rst['$or'] = $this->mergeArr($rst['$or'],$larr, $rarr); }else{ $rst = []; $rst = array_merge($this->exec($mat[1],$leftSame,false),$this->exec($mat[3],$rightSame,false)); } return $rst; } } else{//如果最终已经分解成a=b的形式时,就在此解析 preg_match($this->reg2, $query,$matches); if(count($matches) >= 4){ $left = $matches[1]; $op = $matches[2]; $right = $matches[3]; $rst = []; if($op == "="){ if(is_numeric($right)){ $rst[$left] = (float)$right; }else{ $rst[$left] = $right; } }else{ if(!isset($rst[$left])){ $rst[$left] = []; } if(is_numeric($right)){ $rst[$left][$this->opMap[$op]] = (float)$right; }else{ $rst[$left][$this->opMap[$op]] = $right; } } return $rst; } } } function mergeArr($rst,$larr,$rarr){ foreach ($larr as $lk=>$lv){ $lcond = []; $lcond[$lk] = $lv; $rst[] = $lcond; } foreach ($rarr as $rk=>$rv){ $rcond = []; $rcond[$rk] = $rv; $rst[] = $rcond; } return $rst; } } ?>
好了,就这么多内容,我想应该会有人需要的
有什么问题直接留言吧
以上就介绍了写了一个PHP版本的MONGODB语法解析器,可以通过类似SQL的语法来进行查询,不知道有人需要不,分享一下吧,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

PHP는 현대화 프로세스에서 많은 웹 사이트 및 응용 프로그램을 지원하고 프레임 워크를 통해 개발 요구에 적응하기 때문에 여전히 중요합니다. 1.PHP7은 성능을 향상시키고 새로운 기능을 소개합니다. 2. Laravel, Symfony 및 Codeigniter와 같은 현대 프레임 워크는 개발을 단순화하고 코드 품질을 향상시킵니다. 3. 성능 최적화 및 모범 사례는 응용 프로그램 효율성을 더욱 향상시킵니다.

phphassignificallyimpactedwebdevelopmentandextendsbeyondit

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.

PHP에서는 클론 키워드를 사용하여 객체 사본을 만들고 \ _ \ _ Clone Magic 메소드를 통해 클로닝 동작을 사용자 정의하십시오. 1. 복제 키워드를 사용하여 얕은 사본을 만들어 객체의 속성을 복제하지만 객체의 속성은 아닙니다. 2. \ _ \ _ 클론 방법은 얕은 복사 문제를 피하기 위해 중첩 된 물체를 깊이 복사 할 수 있습니다. 3. 복제의 순환 참조 및 성능 문제를 피하고 클로닝 작업을 최적화하여 효율성을 향상시키기 위해주의를 기울이십시오.

PHP는 웹 개발 및 컨텐츠 관리 시스템에 적합하며 Python은 데이터 과학, 기계 학습 및 자동화 스크립트에 적합합니다. 1.PHP는 빠르고 확장 가능한 웹 사이트 및 응용 프로그램을 구축하는 데 잘 작동하며 WordPress와 같은 CMS에서 일반적으로 사용됩니다. 2. Python은 Numpy 및 Tensorflow와 같은 풍부한 라이브러리를 통해 데이터 과학 및 기계 학습 분야에서 뛰어난 공연을했습니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

Dreamweaver Mac版
시각적 웹 개발 도구
