Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
为 GitLab 提交贡献
登录/注册
切换导航
H
h2database
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
计划
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
Administrator
h2database
Commits
92fae177
提交
92fae177
authored
6 年前
作者:
Evgenij Ryazanov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Do not quote already quoted identifiers in JdbcStatement.enquoteIdentifier()
上级
06b00eda
master
无相关合并请求
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
32 行增加
和
5 行删除
+32
-5
JdbcStatement.java
h2/src/main/org/h2/jdbc/JdbcStatement.java
+23
-5
TestStatement.java
h2/src/test/org/h2/test/jdbc/TestStatement.java
+9
-0
没有找到文件。
h2/src/main/org/h2/jdbc/JdbcStatement.java
浏览文件 @
92fae177
...
@@ -1383,17 +1383,35 @@ public class JdbcStatement extends TraceObject implements Statement, JdbcStateme
...
@@ -1383,17 +1383,35 @@ public class JdbcStatement extends TraceObject implements Statement, JdbcStateme
/**
/**
* @param identifier
* @param identifier
* identifier to quote if required
* identifier to quote if required
, may be quoted or unquoted
* @param alwaysQuote
* @param alwaysQuote
* if {@code true} identifier will be quoted unconditionally
* if {@code true} identifier will be quoted unconditionally
* @return specified identifier quoted if required or explicitly requested
* @return specified identifier quoted if required, explicitly requested, or
* if it was already quoted
* @throws SQLException
* if identifier is not a valid identifier
*/
*/
@Override
@Override
public
String
enquoteIdentifier
(
String
identifier
,
boolean
alwaysQuote
)
throws
SQLException
{
public
String
enquoteIdentifier
(
String
identifier
,
boolean
alwaysQuote
)
throws
SQLException
{
if
(
alwaysQuote
||
!
isSimpleIdentifier
(
identifier
))
{
if
(
isSimpleIdentifier
(
identifier
))
{
return
StringUtils
.
quoteIdentifier
(
identifier
)
;
return
alwaysQuote
?
'"'
+
identifier
+
'"'
:
identifier
;
}
}
return
identifier
;
int
length
=
identifier
.
length
();
if
(
length
>
0
&&
identifier
.
charAt
(
0
)
==
'"'
)
{
boolean
quoted
=
true
;
for
(
int
i
=
1
;
i
<
length
;
i
++)
{
if
(
identifier
.
charAt
(
i
)
==
'"'
)
{
quoted
=
!
quoted
;
}
else
if
(!
quoted
)
{
throw
new
SQLException
();
}
}
if
(
quoted
)
{
throw
new
SQLException
();
}
return
identifier
;
}
return
StringUtils
.
quoteIdentifier
(
identifier
);
}
}
/**
/**
...
...
This diff is collapsed.
Click to expand it.
h2/src/test/org/h2/test/jdbc/TestStatement.java
浏览文件 @
92fae177
...
@@ -484,6 +484,15 @@ public class TestStatement extends TestDb {
...
@@ -484,6 +484,15 @@ public class TestStatement extends TestDb {
assertEquals
(
"\"Test\""
,
stat
.
enquoteIdentifier
(
"Test"
,
false
));
assertEquals
(
"\"Test\""
,
stat
.
enquoteIdentifier
(
"Test"
,
false
));
assertEquals
(
"\"test\""
,
stat
.
enquoteIdentifier
(
"test"
,
false
));
assertEquals
(
"\"test\""
,
stat
.
enquoteIdentifier
(
"test"
,
false
));
assertEquals
(
"\"TODAY\""
,
stat
.
enquoteIdentifier
(
"TODAY"
,
false
));
assertEquals
(
"\"TODAY\""
,
stat
.
enquoteIdentifier
(
"TODAY"
,
false
));
assertEquals
(
"\"Test\""
,
stat
.
enquoteIdentifier
(
"\"Test\""
,
false
));
assertEquals
(
"\"Test\""
,
stat
.
enquoteIdentifier
(
"\"Test\""
,
true
));
assertEquals
(
"\"\"\"Test\""
,
stat
.
enquoteIdentifier
(
"\"\"\"Test\""
,
true
));
try
{
stat
.
enquoteIdentifier
(
"\"Test"
,
true
);
fail
();
}
catch
(
SQLException
ex
)
{
// OK
}
// Other lower case characters don't have upper case mappings
// Other lower case characters don't have upper case mappings
assertEquals
(
"\u02B0"
,
stat
.
enquoteIdentifier
(
"\u02B0"
,
false
));
assertEquals
(
"\u02B0"
,
stat
.
enquoteIdentifier
(
"\u02B0"
,
false
));
...
...
This diff is collapsed.
Click to expand it.
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论