Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
taosdata
TDengine
提交
4d619b3b
T
TDengine
项目概览
taosdata
/
TDengine
1 年多 前同步成功
通知
1185
Star
22016
Fork
4786
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
TDengine
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
4d619b3b
编写于
11月 18, 2022
作者:
dengyihao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix create table error
上级
c628a6e1
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
69 addition
and
79 deletion
+69
-79
examples/go/demo.go
examples/go/demo.go
+69
-79
未找到文件。
examples/go/demo.go
浏览文件 @
4d619b3b
package
main
import
(
"container/heap"
"database/sql"
"database/sql/driver"
"flag"
"fmt"
"reflect"
"strconv"
"strings"
"sync"
"time"
"strings"
"container/heap"
"strconv"
"reflect"
_
"github.com/taosdata/driver-go/v2/taosSql"
)
type
heapElem
struct
{
timeout
int64
colName
string
timeout
int64
colName
string
}
type
MinHeap
[]
heapElem
type
MinHeap
[]
heapElem
type
Column
struct
{
}
func
(
h
MinHeap
)
Len
()
int
{
...
...
@@ -37,16 +32,16 @@ func (h MinHeap) Len() int {
func
(
h
MinHeap
)
Less
(
i
,
j
int
)
bool
{
res
:=
h
[
i
]
.
timeout
-
h
[
j
]
.
timeout
if
res
<
0
{
return
true
;
return
true
}
else
if
res
>
0
{
return
false
;
return
false
}
cmp
:=
strings
.
Compare
(
h
[
i
]
.
colName
,
h
[
j
]
.
colName
)
if
(
cmp
<=
0
)
{
return
true
;
cmp
:=
strings
.
Compare
(
h
[
i
]
.
colName
,
h
[
j
]
.
colName
)
if
cmp
<=
0
{
return
true
}
else
{
return
false
;
return
false
}
}
...
...
@@ -69,20 +64,20 @@ func (h *MinHeap) Top() heapElem {
return
(
*
h
)[
0
]
}
func
(
h
*
MinHeap
)
Pop
()
interface
{}{
func
(
h
*
MinHeap
)
Pop
()
interface
{}
{
res
:=
(
*
h
)[
len
(
*
h
)
-
1
]
*
h
=
(
*
h
)[
:
len
(
*
h
)
-
1
]
return
res
}
type
config
struct
{
hostName
string
serverPort
int
user
string
password
string
dbName
string
srcdbName
string
supTblName
string
hostName
string
serverPort
int
user
string
password
string
dbName
string
srcdbName
string
supTblName
string
}
var
configPara
config
...
...
@@ -97,7 +92,7 @@ func init() {
flag
.
StringVar
(
&
configPara
.
dbName
,
"d"
,
"test1"
,
"check database."
)
flag
.
StringVar
(
&
configPara
.
srcdbName
,
"s"
,
"test"
,
"Destination database."
)
flag
.
Parse
()
}
func
checkErr
(
err
error
,
prompt
string
)
{
...
...
@@ -107,15 +102,13 @@ func checkErr(err error, prompt string) {
}
}
type
schema
struct
{
idx
int
numOfField
int
timestamp
time
.
Time
colName
string
interval
int32
threshold
int32
timestamp
time
.
Time
colName
string
interval
int32
threshold
int32
}
type
demo
struct
{
db
*
sql
.
DB
...
...
@@ -129,13 +122,13 @@ type demo struct {
dInterval
int32
dThreshold
int32
suptabname
string
suptabname
string
metaDict
map
[
string
]
*
schema
heap
MinHeap
timer
*
time
.
Timer
wg
*
sync
.
WaitGroup
wg
*
sync
.
WaitGroup
}
/***
...
...
@@ -148,11 +141,10 @@ type demo struct {
***/
type
taskInfo
struct
{
wg
*
sync
.
WaitGroup
subtask
map
[
string
]
*
demo
wg
*
sync
.
WaitGroup
subtask
map
[
string
]
*
demo
}
type
tableInfo
struct
{
tbname
string
createTime
string
...
...
@@ -163,7 +155,6 @@ type tableInfo struct {
vgId
int32
}
func
taskInit
(
db
*
sql
.
DB
,
dbname
string
,
srcdbname
string
,
metatable
string
,
exptable
string
,
tskinfo
*
taskInfo
)
{
{
sql
:=
fmt
.
Sprintf
(
"create database if not exists %s update 2"
,
dbname
)
...
...
@@ -216,7 +207,7 @@ func taskInit(db *sql.DB, dbname string, srcdbname string, metatable string, exp
fieldTs
:=
time
.
Now
()
.
Add
(
time
.
Hour
*
-
1000
)
for
_
,
e
:=
range
tbs
{
for
_
,
e
:=
range
tbs
{
tbname
:=
e
.
tbname
columns
:=
e
.
columns
stbname
:=
e
.
stbname
...
...
@@ -237,7 +228,7 @@ func taskInit(db *sql.DB, dbname string, srcdbname string, metatable string, exp
var
note
string
subRows
.
Scan
(
&
field
,
&
ty
,
&
len
,
&
note
)
// ignore time and tag col
// ignore time and tag col
if
count
!=
0
&&
strings
.
Compare
(
note
,
"TAG"
)
!=
0
{
// skip first and skip tag col
fields
=
append
(
fields
,
field
)
...
...
@@ -258,7 +249,7 @@ func taskInit(db *sql.DB, dbname string, srcdbname string, metatable string, exp
for
checkRow
.
Next
()
{
count
=
count
+
1
break
break
}
if
count
!=
0
{
continue
...
...
@@ -266,37 +257,37 @@ func taskInit(db *sql.DB, dbname string, srcdbname string, metatable string, exp
defer
checkRow
.
Close
()
}
if
count
==
0
{
sql
:=
fmt
.
Sprintf
(
"insert into %s.%s values(%v,
\"
%s
\"
,
\"
%s
\"
,
\"
%s
\"
, %d, %d)"
,
dbname
,
metatable
,
fieldTs
.
UnixMilli
(),
dbname
,
tbname
,
f
,
2
,
2
)
if
count
==
0
{
sql
:=
fmt
.
Sprintf
(
"insert into %s.%s values(%v,
\"
%s
\"
,
\"
%s
\"
,
\"
%s
\"
, %d, %d)"
,
dbname
,
metatable
,
fieldTs
.
UnixMilli
(),
src
dbname
,
tbname
,
f
,
2
,
2
)
_
,
err
:=
db
.
Exec
(
sql
)
if
err
!=
nil
{
checkErr
(
err
,
sql
)
}
}
}
fieldTs
=
fieldTs
.
Add
(
time
.
Millisecond
*
2
)
}
}
key
:=
fmt
.
Sprintf
(
"%s_%s"
,
srcdbname
,
stbname
)
_
,
ok
:=
tskinfo
.
subtask
[
key
]
if
!
ok
{
tskinfo
.
subtask
[
key
]
=
&
demo
{
db
:
db
,
dbname
:
dbname
,
srcdbname
:
srcdbname
,
suptabname
:
stbname
,
metaTable
:
metatable
,
exceptTable
:
exptable
,
wg
:
tskinfo
.
wg
}
}
}
}
key
:=
fmt
.
Sprintf
(
"%s_%s"
,
srcdbname
,
stbname
)
_
,
ok
:=
tskinfo
.
subtask
[
key
]
if
!
ok
{
tskinfo
.
subtask
[
key
]
=
&
demo
{
db
:
db
,
dbname
:
dbname
,
srcdbname
:
srcdbname
,
suptabname
:
stbname
,
metaTable
:
metatable
,
exceptTable
:
exptable
,
wg
:
tskinfo
.
wg
}
}
}
}
func
subTaskStart
(
d
*
demo
)
{
d
.
Init
()
for
{
select
{
case
<-
d
.
timer
.
C
:
timeout
:=
d
.
NextTimout
()
fmt
.
Printf
(
"stbname %s, timeout %d
\n
"
,
d
.
suptabname
,
timeout
)
d
.
timer
.
Reset
(
time
.
Second
*
time
.
Duration
(
timeout
))
}
select
{
case
<-
d
.
timer
.
C
:
timeout
:=
d
.
NextTimout
()
fmt
.
Printf
(
"stbname %s, timeout %d
\n
"
,
d
.
suptabname
,
timeout
)
d
.
timer
.
Reset
(
time
.
Second
*
time
.
Duration
(
timeout
))
}
}
d
.
wg
.
Done
()
d
.
wg
.
Done
()
}
func
(
d
*
demo
)
Init
()
{
d
.
heap
=
make
(
MinHeap
,
0
,
200
)
...
...
@@ -322,14 +313,13 @@ func (d *demo) Init() {
if
err
!=
nil
{
checkErr
(
err
,
sql
)
}
if
(
strings
.
Compare
(
stbname
,
d
.
suptabname
)
==
0
)
{
tbs
=
append
(
tbs
,
tableInfo
{
tbname
:
tbname
,
createTime
:
createTime
,
columns
:
columns
,
stbname
:
stbname
,
uid
:
uid
,
tid
:
tid
,
vgId
:
vgId
})
}
if
strings
.
Compare
(
stbname
,
d
.
suptabname
)
==
0
{
tbs
=
append
(
tbs
,
tableInfo
{
tbname
:
tbname
,
createTime
:
createTime
,
columns
:
columns
,
stbname
:
stbname
,
uid
:
uid
,
tid
:
tid
,
vgId
:
vgId
})
}
}
rows
.
Close
()
for
_
,
e
:=
range
tbs
{
tbname
:=
e
.
tbname
columns
:=
e
.
columns
...
...
@@ -353,7 +343,7 @@ func (d *demo) Init() {
var
note
string
subRows
.
Scan
(
&
field
,
&
ty
,
&
len
,
&
note
)
// ignore time and tag col
// ignore time and tag col
if
count
!=
0
&&
strings
.
Compare
(
note
,
"TAG"
)
!=
0
{
// skip first and skip tag col
fields
=
append
(
fields
,
field
)
...
...
@@ -555,7 +545,7 @@ func (d *demo) NextTimout() int32 {
if
cost
==
0
{
elem
.
timestamp
=
ts
sql
:=
fmt
.
Sprintf
(
"insert into %s.%s using %s.%s tags(
\"
%s
\"
) values(%v,
\"
%s
\"
,
\"
%s
\"
,
\"
%s
\"
, %v, %d)"
,
d
.
dbname
,
exceptTableName
,
d
.
dbname
,
d
.
exceptTable
,
exceptTableName
,
time
.
Now
()
.
UnixMilli
(),
d
.
dbname
,
tabName
,
colName
,
ts
.
UnixMilli
(),
int
(
time
.
Now
()
.
Sub
(
elem
.
timestamp
)
.
Seconds
()))
fmt
.
Printf
(
"INSERT SQL: %s
\n
"
,
sql
)
fmt
.
Printf
(
"INSERT SQL: %s
\n
"
,
sql
)
_
,
err
:=
d
.
db
.
Exec
(
sql
)
if
err
!=
nil
{
checkErr
(
err
,
sql
)
...
...
@@ -564,7 +554,7 @@ func (d *demo) NextTimout() int32 {
elem
.
timestamp
=
ts
if
cost
>
elem
.
threshold
{
sql
:=
fmt
.
Sprintf
(
"insert into %s.%s using %s.%s tags(
\"
%s
\"
) values(%v,
\"
%s
\"
,
\"
%s
\"
,
\"
%s
\"
, %v, %d)"
,
d
.
dbname
,
exceptTableName
,
d
.
dbname
,
d
.
exceptTable
,
exceptTableName
,
time
.
Now
()
.
UnixMilli
(),
d
.
dbname
,
tabName
,
colName
,
ts
.
UnixMilli
(),
int
(
time
.
Now
()
.
Sub
(
elem
.
timestamp
)
.
Seconds
()))
fmt
.
Printf
(
"INSERT SQL: %s
\n
"
,
sql
)
fmt
.
Printf
(
"INSERT SQL: %s
\n
"
,
sql
)
_
,
err
:=
d
.
db
.
Exec
(
sql
)
if
err
!=
nil
{
...
...
@@ -611,12 +601,12 @@ func main() {
checkErr
(
err
,
"failed to connect db"
)
}
wg
:=
sync
.
WaitGroup
{}
info
:=
&
taskInfo
{
subtask
:
make
(
map
[
string
]
*
demo
),
wg
:
&
wg
}
taskInit
(
db
,
configPara
.
dbName
,
configPara
.
srcdbName
,
"metatable"
,
"exptable"
,
info
)
for
_
,
v
:=
range
info
.
subtask
{
wg
.
Add
(
1
)
go
subTaskStart
(
v
)
}
wg
.
Wait
()
info
:=
&
taskInfo
{
subtask
:
make
(
map
[
string
]
*
demo
),
wg
:
&
wg
}
taskInit
(
db
,
configPara
.
dbName
,
configPara
.
srcdbName
,
"metatable"
,
"exptable"
,
info
)
for
_
,
v
:=
range
info
.
subtask
{
wg
.
Add
(
1
)
go
subTaskStart
(
v
)
}
wg
.
Wait
()
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录