>데이터 베이스 >MySQL 튜토리얼 >SQL 문 기술: 쿼리 시 OR을 영리하게 사용하여 논리적 판단 달성

SQL 문 기술: 쿼리 시 OR을 영리하게 사용하여 논리적 판단 달성

伊谢尔伦
伊谢尔伦원래의
2016-11-23 13:43:171544검색

먼저 다음 SQL 논리문 블록을 살펴보세요.

DECLARE @fieldname    varchar(50)
DECLARE @fieldvalue nvarchar(100)
SET @fieldname='chassisno' --这里可传入chassisno,plateno,owner,contacttelno其中之一或不传
SET @fieldvalue='Zuowenjun'
IF @fieldname = 'chassisno'
BEGIN
    SELECT * FROM TABLENAME WHERE chassisno=@fieldvalue
END
ELSE IF @fieldname = 'plateno'
BEGIN
    SELECT * FROM TABLENAME WHERE plateno=@fieldvalue
END
ELSE IF @fieldname = 'owner'
BEGIN
    SELECT * FROM TABLENAME WHERE [owner]=@fieldvalue
END
ELSE IF @fieldname = 'contacttelno'
BEGIN
    SELECT * FROM TABLENAME WHERE contacttelno=@fieldvalue
END
ELSE
BEGIN
    SELECT * FROM TABLENAME
END

이제 위의 논리적 판단을 구현하고 결과를 쿼리하기 위해 SQL 문을 사용해야 한다면 다음 스플라이싱을 사용하는 것을 고려해 볼 수 있습니다. 이를 달성하는 방법:

DECLARE @sqltext NVARCHAR(2000)
SET @sqltext='SELECT * FROM TABLENAME WHERE ' + @fieldname + '=''' + @fieldvalue +''''
EXECUTE (@sqltext)

논리적인 판단과 쿼리 결과를 얻을 수 있는 것처럼 보이지만 충분히 직관적이지 않고 수정이 번거롭고 오류가 발생하기 쉬우며 특정 제한 사항이 있습니다. 여기서 @fieldname은 테이블 필드와 동일하며 접합이 반대입니다. 상황이 동일하지 않으면 달성할 수 없으므로 여기서는 효율성에 대해 이야기하지 않겠습니다. , 그러나 매우 간단하고 사용하기 쉽고 충분히 유연합니다. 다음 SQL 문을 참조하십시오.

SELECT * FROM TABLENAME a WHERE 1=1 --(如果需要其它条件则用其它条件,否则可以这样或不要,如果不要则下面的第一个AND需去掉)
AND ((@fieldname = &#39;chassisno&#39; AND a.chassisno=@fieldvalue) OR (@fieldname<>&#39;chassisno&#39;) )
AND ((@fieldname = &#39;plateno&#39; AND a.plateno=@fieldvalue) OR (@fieldname<>&#39;plateno&#39;) )
AND ((@fieldname = &#39;owner&#39; AND a.[owner]=@fieldvalue) OR (@fieldname<>&#39;owner&#39;) )
AND ((@fieldname = &#39;contacttelno&#39; AND b.contacttelno=@fieldvalue) OR (@fieldname<>&#39;contacttelno&#39;) )

이 SQL 문은 논리적 판단 및 쿼리 결과를 구현할 수 있음을 확인했습니다. fieldname은 테이블 필드와 다르므로 해당 필드를 직접 대체할 수 있습니다. 이제 원리를 간략하게 설명하겠습니다.

AND ((@fieldname = 'chassisno' AND a.chassisno=@fieldvalue) OR (@fieldname< ;>'chassisno') )

AND 연관이기 때문에 다음 괄호 안의 조건을 만족해야 하고, 괄호 안에 OR 관계를 사용하기 때문에 괄호 양쪽의 조건이 충족되어야 합니다. @fieldname = 'chassisno'이면 a.chassisno=@fieldvalue가 필요합니다. 그렇지 않으면 @fieldnamea8093152e673feb7aba1828c43532094'chassisno'인 경우 이전 연결 조건이 무시됩니다. 즉, OR 양쪽의 조건은 둘 중 하나만 충족할 수 있다는 점에 유의하세요. 물론 더 좋은 방법이 있거나 다른 의견이 있다면 교환을 환영합니다. 함께 발전해 보세요!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.