8144082: Add Statement.enquoteNCharLiteral

Reviewed-by: joehw
This commit is contained in:
Lance Andersen 2016-01-04 12:25:45 -05:00
parent 9fcb6958fa
commit 3da2de846c
2 changed files with 78 additions and 4 deletions

View File

@ -1582,4 +1582,43 @@ public interface Statement extends Wrapper, AutoCloseable {
return len >= 1 && len <= 128 return len >= 1 && len <= 128
&& Pattern.compile("[\\p{Alpha}][\\p{Alnum}_]*").matcher(identifier).matches(); && Pattern.compile("[\\p{Alpha}][\\p{Alnum}_]*").matcher(identifier).matches();
} }
/**
* Returns a {@code String} representing a National Character Set Literal
* enclosed in single quotes and prefixed with a upper case letter N.
* Any occurrence of a single quote within the string will be replaced
* by two single quotes.
*
* <blockquote>
* <table border = 1 cellspacing=0 cellpadding=5 >
* <caption>Examples of the conversion:</caption>
* <tr>
* <th>Value</th>
* <th>Result</th>
* </tr>
* <tr> <td align='center'>Hello</td> <td align='center'>N'Hello'</td> </tr>
* <tr> <td align='center'>G'Day</td> <td align='center'>N'G''Day'</td> </tr>
* <tr> <td align='center'>'G''Day'</td>
* <td align='center'>N'''G''''Day'''</td> </tr>
* <tr> <td align='center'>I'''M</td> <td align='center'>N'I''''''M'</td>
* <tr> <td align='center'>N'Hello'</td> <td align='center'>N'N''Hello'''</td> </tr>
*
* </table>
* </blockquote>
* @implNote
* JDBC driver implementations may need to provide their own implementation
* of this method in order to meet the requirements of the underlying
* datasource. An implementation of enquoteNCharLiteral may accept a different
* set of characters than that accepted by the same drivers implementation of
* enquoteLiteral.
* @param val a character string
* @return the result of replacing every single quote character in the
* argument by two single quote characters where this entire result is
* then prefixed with 'N'.
* @throws NullPointerException if val is {@code null}
* @throws SQLException if a database access error occurs
*/
default String enquoteNCharLiteral(String val) throws SQLException {
return "N'" + val.replace("'", "''") + "'";
}
} }

View File

@ -65,7 +65,7 @@ public class StatementTests extends BaseTest {
* enquoteLiteral is null * enquoteLiteral is null
*/ */
@Test(expectedExceptions = NullPointerException.class) @Test(expectedExceptions = NullPointerException.class)
public void test01() throws SQLException { public void test01() throws SQLException {
stmt.enquoteLiteral(null); stmt.enquoteLiteral(null);
} }
@ -110,7 +110,7 @@ public class StatementTests extends BaseTest {
} }
/* /*
* Validate a NullPointerException is thrown is the string passed to * Validate a NullPointerException is thrown if the string passed to
* isSimpleIdentifier is null * isSimpleIdentifier is null
*/ */
@Test(expectedExceptions = NullPointerException.class) @Test(expectedExceptions = NullPointerException.class)
@ -119,6 +119,24 @@ public class StatementTests extends BaseTest {
} }
/*
* Verify that enquoteLiteral creates a valid literal and converts every
* single quote to two single quotes
*/
@Test(dataProvider = "validEnquotedNCharLiteralValues")
public void test07(String s, String expected) throws SQLException {
assertEquals(stmt.enquoteNCharLiteral(s), expected);
}
/*
* Validate a NullPointerException is thrown if the string passed to
* enquoteNCharLiteral is null
*/
@Test(expectedExceptions = NullPointerException.class)
public void test08() throws SQLException {
stmt.enquoteNCharLiteral(null);
}
/* /*
* DataProvider used to provide strings that will be used to validate * DataProvider used to provide strings that will be used to validate
* that enquoteLiteral converts a string to a literal and every instance of * that enquoteLiteral converts a string to a literal and every instance of
@ -169,8 +187,7 @@ public class StatementTests extends BaseTest {
{"\"Hel\"lo\"", true}, {"\"Hel\"lo\"", true},
{"Hello" + '\0', false}, {"Hello" + '\0', false},
{"", false}, {"", false},
{maxIdentifier + 'a', false}, {maxIdentifier + 'a', false},};
};
} }
/* /*
@ -194,4 +211,22 @@ public class StatementTests extends BaseTest {
{"", false},}; {"", false},};
} }
/*
* DataProvider used to provide strings that will be used to validate
* that enquoteNCharLiteral converts a string to a National Character
* literal and every instance of
* a single quote will be converted into two single quotes in the literal.
*/
@DataProvider(name = "validEnquotedNCharLiteralValues")
protected Object[][] validEnquotedNCharLiteralValues() {
return new Object[][]{
{"Hello", "N'Hello'"},
{"G'Day", "N'G''Day'"},
{"'G''Day'", "N'''G''''Day'''"},
{"I'''M", "N'I''''''M'"},
{"N'Hello'", "N'N''Hello'''"},
{"The Dark Knight", "N'The Dark Knight'"}
};
}
} }