먼저 다음 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 = 'chassisno' AND a.chassisno=@fieldvalue) OR (@fieldname<>'chassisno') ) AND ((@fieldname = 'plateno' AND a.plateno=@fieldvalue) OR (@fieldname<>'plateno') ) AND ((@fieldname = 'owner' AND a.[owner]=@fieldvalue) OR (@fieldname<>'owner') ) AND ((@fieldname = 'contacttelno' AND b.contacttelno=@fieldvalue) OR (@fieldname<>'contacttelno') )
이 SQL 문은 논리적 판단 및 쿼리 결과를 구현할 수 있음을 확인했습니다. fieldname은 테이블 필드와 다르므로 해당 필드를 직접 대체할 수 있습니다. 이제 원리를 간략하게 설명하겠습니다.
AND ((@fieldname = 'chassisno' AND a.chassisno=@fieldvalue) OR (@fieldname< ;>'chassisno') )
AND 연관이기 때문에 다음 괄호 안의 조건을 만족해야 하고, 괄호 안에 OR 관계를 사용하기 때문에 괄호 양쪽의 조건이 충족되어야 합니다. @fieldname = 'chassisno'이면 a.chassisno=@fieldvalue가 필요합니다. 그렇지 않으면 @fieldname<>'chassisno'인 경우 이전 연결 조건이 무시됩니다. 즉, OR 양쪽의 조건은 둘 중 하나만 충족할 수 있다는 점에 유의하세요. 물론 더 좋은 방법이 있거나 다른 의견이 있다면 교환을 환영합니다. 함께 발전해 보세요!