HHH-13608 Oracle8iDialect should use CASE_INSENSITIVE pattern matching when checking the statement type
This commit is contained in:
parent
21e79125e6
commit
f08abf3628
|
@ -66,7 +66,7 @@ public class Oracle8iDialect extends Dialect {
|
|||
|
||||
private static final Pattern UNION_KEYWORD_PATTERN = Pattern.compile( "\\bunion\\b" );
|
||||
|
||||
private static final Pattern SQL_STATEMENT_TYPE_PATTERN = Pattern.compile("^(?:\\/\\*.*?\\*\\/)?\\s*(select|insert|update|delete)\\s+.*?");
|
||||
private static final Pattern SQL_STATEMENT_TYPE_PATTERN = Pattern.compile("^(?:\\/\\*.*?\\*\\/)?\\s*(select|insert|update|delete)\\s+.*?", Pattern.CASE_INSENSITIVE);
|
||||
|
||||
private static final AbstractLimitHandler LIMIT_HANDLER = new AbstractLimitHandler() {
|
||||
@Override
|
||||
|
|
|
@ -153,7 +153,32 @@ public class QueryHintTest extends BaseNonConfigCoreFunctionalTestCase {
|
|||
sqlStatementInterceptor.clear();
|
||||
}
|
||||
|
||||
@Entity
|
||||
@Test
|
||||
@TestForIssue( jiraKey = "HHH-13608")
|
||||
public void testQueryHintCaseInsensitive() {
|
||||
sqlStatementInterceptor.clear();
|
||||
|
||||
doInHibernate( this::sessionFactory, s -> {
|
||||
List results = s.createNativeQuery(
|
||||
"SELECT e.id as id " +
|
||||
"FROM Employee e " +
|
||||
"JOIN Department d ON e.department_id = d.id " +
|
||||
"WHERE d.name = :departmentName" )
|
||||
.addQueryHint( "ALL_ROWS" )
|
||||
.setComment( "My_Query" )
|
||||
.setParameter( "departmentName", "Sales" )
|
||||
.getResultList();
|
||||
|
||||
assertEquals(results.size(), 2);
|
||||
} );
|
||||
|
||||
sqlStatementInterceptor.assertExecutedCount( 1 );
|
||||
|
||||
assertTrue( sqlStatementInterceptor.getSqlQueries().get( 0 ).contains( "/* My_Query */ SELECT /*+ ALL_ROWS */" ) );
|
||||
sqlStatementInterceptor.clear();
|
||||
}
|
||||
|
||||
@Entity(name = "Employee")
|
||||
public static class Employee {
|
||||
@Id
|
||||
@GeneratedValue
|
||||
|
@ -163,7 +188,7 @@ public class QueryHintTest extends BaseNonConfigCoreFunctionalTestCase {
|
|||
public Department department;
|
||||
}
|
||||
|
||||
@Entity
|
||||
@Entity(name = "Department")
|
||||
public static class Department {
|
||||
@Id
|
||||
@GeneratedValue
|
||||
|
|
Loading…
Reference in New Issue