有and 有OR的依据几个字段生成SQL语句
有and 有OR的根据几个字段生成SQL语句
有如下图的数据表信息,有什么好的方法把它们组合成一条SQL?如果全是and 的或者全是or的,这方法好办,可是两个同时都有的,怎么办呢?
全是AND 或OR的话
- PHP code
<!-- Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ --> $sql = "select * from sk_cvfilter where cvid=58 and columnname!=''"; $query = mysql_query($sql); $sql = ''; while($row = mysql_fetch_assoc($query)){ if($row['comparator']=='eq'){$comparator="=";} else{$comparator=$row['comparator'];} $sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' '; }
------解决方案--------------------
- SQL code
select * from sk_cvfilter where cvid=58 and columnname!='' and andor='and' or andor='or' <br><font color="#e78608">------解决方案--------------------</font><br>你的这个记录有问题,为什么呢?<br><br>例如出现一个 (a = 1 or (b=2 and b=3)),这个时候,你是怎么记录的?<br><br>我猜是这样的<br><br>columnname comparator value andor<br>a eq 1 or<br>b eq 2 and<br>c eq 3 <br><br>这个时候问题出现了,假如你不知道上面的那个关系式(a = 1 or (b=2 and b=3)),<br>如果只从结构看的话,你是认为<br><br>(a = 1 or b =2 ) and b = 3<br><br>还是<br><br> a = 1 or (b=2 and b=3)<br><br>上述问题不考虑,所有or为一个条件和其他条件and的写法<br><br><br>
- PHP code
<?php $sql = "select * from sk_cvfilter where cvid=58 and columnname!=''"; $query = mysql_query($sql); $sql = ''; // 记录上一句的是不是or $is_last_or = false; while($row = mysql_fetch_assoc($query)){ if($row['comparator']=='eq'){$comparator="=";} else{$comparator=$row['comparator'];} if($is_last_or) { if($row['andor'] == 'and') { // 和下一句是and关系说明括号要结束了 $sql .=$row['columnname'].$comparator."'".$row['value']."' ) ".$row['andor'].' '; } else { // 持续括号里的内容 $sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' '; } } elseif($row['andor'] == 'or') { // 如果有or则意味着和下一句有或的关系(因为你这里没有括号) $is_last_or = true; // 加上括号吧 $sql .= '( ' . $row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' '; } else { $sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' '; } } <br /><font color="#e78608">------解决方案--------------------</font><br>
- PHP code
<?php $sql = "select * from sk_cvfilter where cvid=58 and columnname!=''"; $query = mysql_query($sql); $sql = ''; // 记录上一句的是不是or $is_last_or = false; while($row = mysql_fetch_assoc($query)){ if($row['comparator']=='eq'){$comparator="=";} else{$comparator=$row['comparator'];} if($is_last_or) { if($row['andor'] != 'or') { // 和下一句是and或者结束了关系说明括号要结束了 $sql .=$row['columnname'].$comparator."'".$row['value']."' ) ".$row['andor'].' '; } else { // 持续括号里的内容 $sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' '; } } elseif($row['andor'] == 'or') { // 如果有or则意味着和下一句有或的关系(因为你这里没有括号) $is_last_or = true; // 加上括号吧 $sql .= '( ' . $row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' '; } else { $sql .=$row['columnname'].$comparator."'".$row['value']."' ".$row['andor'].' '; } } <div class="clear">

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











1. 정렬 및 중복 제거 일상적인 작업에는 항상 결과 집합을 필터링해야 하는 몇 가지 시나리오가 있습니다. 예를 들어, 제3자와 상호 작용한 후 얻은 결과 집합을 다시 정렬하고 중복 제거해야 하는 경우 결과 집합은 특정 필드에 따라 중복 제거되거나 특정 필드별로 정렬됩니다. Java에서는 중복제거를 하면 Set(순서 없음, 중복 없음)의 특징을 쉽게 생각할 수 있고, TreeSet(순서 있음, 중복 없음)도 중복 제거 규칙(일반적으로 중복 제거 후 오름차순 결과 집합)을 지정할 수 있습니다. 정렬이라고 하면 다양한 정렬 알고리즘을 쉽게 생각할 수 있지만 Java는 이미 컬렉션에 sort() 메서드와 같은 정렬 기능을 제공하고 있으며 정렬 필드와 오름차순 및 내림차순을 지정할 수도 있습니다. 여기서 한 가지 더 말씀드리자면, Set의 특징(순서 없음, 중복 없음): 무질서: 무질서

php提交表单通过后,弹出的对话框怎样在当前页弹出php提交表单通过后,弹出的对话框怎样在当前页弹出而不是在空白页弹出?想实现这样的效果:而不是空白页弹出:------解决方案--------------------如果你的验证用PHP在后端,那么就用Ajax;仅供参考:HTML code

Comparable 및 ComparatorComparable 및 Comparator는 두 가지 Java 정렬 관련 인터페이스로, 자연 정렬 및 사용자 정의 정렬이라고도 합니다. 최근 관련 내용을 읽었으며, 이제 아래에 나만의 학습 현황을 기록하겠습니다. Comparable과 Comparator는 정렬에 관한 두 가지 인터페이스로, Java 컬렉션에서 정렬 기능을 구현하는 데 사용됩니다. 특정 기능은 API를 보면 얻을 수 있습니다. Comparable 다음은 API 문서의 간략한 소개입니다. 이 인터페이스는 각 클래스의 개체에 대한 전체 순서를 부과합니다.

1. Java는 비교를 위해 Comparable 비교 인터페이스를 제공한다는 점을 설명합니다. 이 인터페이스를 구현하는 모든 클래스는 이 비교 방법을 동적으로 구현합니다. 실제로 Java는 비교 인터페이스뿐만 아니라 또 다른 인터페이스도 제공합니다. Comparator 인터페이스에도 비교 기능이 있지만 이 인터페이스는 컨테이너 비교에 중점을 둡니다. 2. 인스턴스 비교기는 Java8 이전에 널리 사용되었습니다. Java8은 기능적 인터페이스로 업그레이드할 뿐만 아니라 기본 메소드도 확장합니다. Comparatorcomparator=(p1,p2)->p1.firstName.compareTo(p2.firstName);Personp1=ne

不用数据库来实现用户的简单的下载,代码如下,但是却不能下载,请高手找下原因,文件路劲什么的没问题。

图片消失如何解决先是图片文件上传$file=$_FILES['userfile']; if(is_uploaded_file($file['tmp_name'])){$query=mysql_query("INSERT INTO gdb_banner(image_src ) VALUES ('images/{$file['name'

图片消失如何解决先是图片文件上传$file=$_FILES['userfile']; if(is_uploaded_file($file['tmp_name'])){$query=mysql_query("INSERT INTO gdb_banner(image_src ) VALUES ('images/{$file['name'
