Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Xiaomi
soar
提交
a2b44da7
S
soar
项目概览
Xiaomi
/
soar
大约 1 年 前同步成功
通知
386
Star
8512
Fork
1328
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
soar
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
a2b44da7
编写于
8月 11, 2020
作者:
L
liuzhenwu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix sql comment distinguish in quoted string
上级
ee6cfd0c
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
5 addition
and
3 deletion
+5
-3
ast/testdata/TestSplitStatement.golden
ast/testdata/TestSplitStatement.golden
+1
-0
ast/token.go
ast/token.go
+2
-2
ast/token_test.go
ast/token_test.go
+2
-1
未找到文件。
ast/testdata/TestSplitStatement.golden
浏览文件 @
a2b44da7
...
...
@@ -40,6 +40,7 @@ tb;
20 select /*!50000 1,*/ 1;
21 UPDATE xxx SET c1=' LOGGER.error(""); }' WHERE id = 2 ;
22 UPDATE `xxx` SET aaa='a;' WHERE `id` = 15;
23 UPDATE `xxx` SET aaa='a -- b' WHERE `id` = 15;
0 select * from test\G
1 select 'hello\Gworld', col from test\G
2 -- select * from test\Ghello
...
...
ast/token.go
浏览文件 @
a2b44da7
...
...
@@ -863,12 +863,12 @@ func SplitStatement(buf []byte, delimiter []byte) (string, string, []byte) {
b
:=
buf
[
i
]
// single line comment
if
b
==
'-'
{
if
i
+
2
<
len
(
buf
)
&&
buf
[
i
+
1
]
==
'-'
&&
buf
[
i
+
2
]
==
' '
{
if
!
quoted
&&
i
+
2
<
len
(
buf
)
&&
buf
[
i
+
1
]
==
'-'
&&
buf
[
i
+
2
]
==
' '
{
singleLineComment
=
true
i
=
i
+
2
continue
}
if
i
+
2
<
len
(
buf
)
&&
i
==
0
&&
buf
[
i
+
1
]
==
'-'
&&
(
buf
[
i
+
2
]
==
'\n'
||
buf
[
i
+
2
]
==
'\r'
)
{
if
!
quoted
&&
i
+
2
<
len
(
buf
)
&&
i
==
0
&&
buf
[
i
+
1
]
==
'-'
&&
(
buf
[
i
+
2
]
==
'\n'
||
buf
[
i
+
2
]
==
'\r'
)
{
sql
=
"--
\n
"
break
}
...
...
ast/token_test.go
浏览文件 @
a2b44da7
...
...
@@ -173,7 +173,8 @@ select col from tb;
[]
byte
(
`select /*!50000 1,*/ 1;`
),
// 20
[]
byte
(
`UPDATE xxx SET c1=' LOGGER.error(""); }' WHERE id = 2 ;`
),
// 21
[]
byte
(
"UPDATE `xxx` SET aaa='a;' WHERE `id` = 15;"
),
// 22
// []byte(`/* comment here */ SET MAX_JOIN_SIZE=#`), // 23
[]
byte
(
"UPDATE `xxx` SET aaa='a -- b' WHERE `id` = 15; UPDATE `xxx` SET aaa='c -- d' WHERE `id` = 16;"
),
// 23
// []byte(`/* comment here */ SET MAX_JOIN_SIZE=#`), // 24
}
// \G 分隔符
buf2s
:=
[][]
byte
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录