> 일반적인 문제 > 마이바티스 동적 SQL이란?

마이바티스 동적 SQL이란?

anonymity
풀어 주다: 2020-09-16 15:27:32
원래의
12553명이 탐색했습니다.

MyBatis의 동적 SQL은 SQL 문을 유연하게 조작하는 것을 말하며, OGNL 표현식을 기반으로 하며 if, choose, when, else, Trim, where, set 및 foreach 태그를 통해 SQL 문을 유연하게 연결하고 조합하여 개발자의 능력을 향상시킵니다. 능률.

마이바티스 동적 SQL이란?

동적 SQL이란 무엇인가요? 동적 SQL의 역할은 무엇인가요?

mybatis 코어는 SQL 문을 유연하게 작동하고, 표현식을 통해 판단하고, SQL을 유연하게 연결하고 어셈블할 수 있습니다.

JDBC를 사용하는 기존 방식에서는 복잡한 SQL 문을 결합할 때 주의를 기울이지 않으면 공백을 놓쳐도 오류가 발생한다고 생각합니다. Mybatis의 동적 SQL 기능은 이 문제를 해결하기 위해 설계되었으며 if, choose, when, else, Trim, where, set 및 foreach 태그를 통해 매우 유연한 SQL 문으로 결합할 수 있어 개발자의 효율성이 향상됩니다.

MyBatis 동적 SQL은 OGNL을 통해 사용됩니다.

현재 동적 SQL은 다음 태그를 지원합니다

마이바티스 동적 SQL이란?

예: if 문은

을 사용하여 사용자 이름과 성별을 기반으로 데이터를 쿼리합니다. 사용자 이름이 비어 있으면 성별을 기준으로만 쿼리됩니다. 그렇지 않으면 사용자 이름을 기준으로만 쿼리됩니다

먼저 위 쿼리 문을 작성하는 데 동적 SQL을 사용하지 마세요

<select id="selectUserByUsernameAndSex"
        resultType="user" parameterType="com.ys.po.User">
    <!-- 这里和普通的sql 查询语句差不多,对于只有一个参数,后面的 #{id}表示占位符,里面不一定要写id,
            写啥都可以,但是不要空着,如果有多个参数则必须写pojo类里面的属性 -->
    select * from user where username=#{username} and sex=#{sex}
</select>
로그인 후 복사

. #{username}이 비어 있습니다. 그러면 쿼리 결과도 비어 있습니다. 이 문제를 해결하려면 어떻게 해야 합니까?

판단하려면 if를 사용하세요

<select id="selectUserByUsernameAndSex" resultType="user" parameterType="com.ys.po.User">
    select * from user where
        <if test="username != null">
           username=#{username}
        </if>
         
        <if test="username != null">
           and sex=#{sex}
        </if>
</select>
로그인 후 복사

이렇게 작성하면 sex가 null과 같을 경우 쿼리 문은 select * from user where username=#{username}라는 것을 알 수 있습니다.

위 내용은 마이바티스 동적 SQL이란?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿