Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Xiaomi
soar
提交
69e0a1f0
S
soar
项目概览
Xiaomi
/
soar
大约 1 年 前同步成功
通知
387
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,发现更多精彩内容 >>
未验证
提交
69e0a1f0
编写于
11月 15, 2018
作者:
martianzhang
提交者:
GitHub
11月 15, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #102 from wusphinx/refatorHardcode
IndexMaxLength refactor hard code
上级
511ce888
3c2afb20
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
30 addition
and
9 deletion
+30
-9
advisor/index.go
advisor/index.go
+20
-9
advisor/index_test.go
advisor/index_test.go
+10
-0
未找到文件。
advisor/index.go
浏览文件 @
69e0a1f0
...
...
@@ -29,6 +29,11 @@ import (
"vitess.io/vitess/go/vt/sqlparser"
)
const
(
// IndexNameMaxLength Ref. https://dev.mysql.com/doc/refman/8.0/en/identifiers.html
IndexNameMaxLength
=
64
)
// IndexAdvisor 索引建议需要使用到的所有信息
type
IndexAdvisor
struct
{
vEnv
*
env
.
VirtualEnv
// 线下虚拟测试环境(测试环境)
...
...
@@ -447,9 +452,9 @@ func (idxAdv *IndexAdvisor) idxColsTypeCheck(idxList []IndexInfo) []IndexInfo {
}
// 索引名称最大长度64
if
len
(
idxName
)
>
64
{
common
.
Log
.
Warn
(
"index '%s' name large than
64
"
,
idxName
)
idxName
=
strings
.
TrimRight
(
idxName
[
:
64
],
"_"
)
if
len
(
idxName
)
>
IndexNameMaxLength
{
common
.
Log
.
Warn
(
"index '%s' name large than
IndexNameMaxLength
"
,
idxName
)
idxName
=
strings
.
TrimRight
(
idxName
[
:
IndexNameMaxLength
],
"_"
)
}
// 新的alter语句
...
...
@@ -557,10 +562,11 @@ func (idxAdv *IndexAdvisor) mergeIndexes(idxList []IndexInfo) []IndexInfo {
// 检测索引名称是否重复?
if
existedIndexes
:=
indexMeta
.
FindIndex
(
database
.
IndexKeyName
,
idx
.
Name
);
len
(
existedIndexes
)
>
0
{
var
newName
string
if
len
(
idx
.
Name
)
<
59
{
newName
=
idx
.
Name
+
"_"
+
uniuri
.
New
()[
:
4
]
idxSuffix
:=
getRandomIndexSuffix
()
if
len
(
idx
.
Name
)
<
IndexNameMaxLength
-
len
(
idxSuffix
)
{
newName
=
idx
.
Name
+
idxSuffix
}
else
{
newName
=
idx
.
Name
[
:
59
]
+
"_"
+
uniuri
.
New
()[
:
4
]
newName
=
idx
.
Name
[
:
IndexNameMaxLength
-
len
(
idxSuffix
)]
+
idxSuffix
}
common
.
Log
.
Warning
(
"duplicate index name '%s', new name is '%s'"
,
idx
.
Name
,
newName
)
...
...
@@ -578,6 +584,11 @@ func (idxAdv *IndexAdvisor) mergeIndexes(idxList []IndexInfo) []IndexInfo {
return
rmSelfDupIndex
(
indexes
)
}
// getRandomIndexSuffix format: _xxxx, length: 5
func
getRandomIndexSuffix
()
string
{
return
fmt
.
Sprintf
(
"_%s"
,
uniuri
.
New
()[
:
4
])
}
// rmSelfDupIndex 去重传入的[]IndexInfo中重复的索引
func
rmSelfDupIndex
(
indexes
[]
IndexInfo
)
[]
IndexInfo
{
var
resultIndex
[]
IndexInfo
...
...
@@ -654,9 +665,9 @@ func (idxAdv *IndexAdvisor) buildIndex(idxList map[string]map[string][]*common.C
idxName
:=
"idx_"
+
strings
.
Join
(
colNames
,
"_"
)
// 索引名称最大长度64
if
len
(
idxName
)
>
64
{
common
.
Log
.
Warn
(
"index '%s' name large than
64
"
,
idxName
)
idxName
=
strings
.
TrimRight
(
idxName
[
:
64
],
"_"
)
if
len
(
idxName
)
>
IndexNameMaxLength
{
common
.
Log
.
Warn
(
"index '%s' name large than
IndexNameMaxLength
"
,
idxName
)
idxName
=
strings
.
TrimRight
(
idxName
[
:
IndexNameMaxLength
],
"_"
)
}
alterSQL
:=
fmt
.
Sprintf
(
"alter table `%s`.`%s` add index `%s` (`%s`)"
,
idxAdv
.
vEnv
.
RealDB
(
db
),
tb
,
...
...
advisor/index_test.go
浏览文件 @
69e0a1f0
...
...
@@ -19,6 +19,7 @@ package advisor
import
(
"fmt"
"os"
"strings"
"testing"
"github.com/XiaoMi/soar/common"
...
...
@@ -464,3 +465,12 @@ func TestIdxColsTypeCheck(t *testing.T) {
}
}
}
func
TestGetRandomIndexSuffix
(
t
*
testing
.
T
)
{
for
i
:=
0
;
i
<
5
;
i
++
{
r
:=
getRandomIndexSuffix
()
if
!
(
strings
.
HasPrefix
(
r
,
"_"
)
&&
len
(
r
)
==
5
)
{
t
.
Errorf
(
"getRandomIndexSuffix should return a string with prefix `_` and 5 length, but got:%s"
,
r
)
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录