-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathmain.go
69 lines (62 loc) · 1.99 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package main
import (
"context"
"fmt"
"log"
"time"
"github.com/kubemq-io/kubemq-go"
"github.com/kubemq-io/kubemq-targets/pkg/uuid"
"github.com/kubemq-io/kubemq-targets/types"
)
var (
transactionString = `DROP TABLE IF EXISTS post;
CREATE TABLE post (
ID bigint,
TITLE varchar(40),
CONTENT varchar(255),
BIGNUMBER bigint,
BOOLVALUE boolean,
CONSTRAINT pk_post PRIMARY KEY(ID)
);
INSERT INTO post(ID,TITLE,CONTENT,BIGNUMBER,BOOLVALUE) VALUES
(0,NULL,'Content One',1231241241231231123,true),
(1,'Title Two','Content Two',123125241231231123,false);`
queryString = `SELECT id,title,content,bignumber,boolvalue FROM post;`
)
func main() {
client, err := kubemq.NewClient(context.Background(),
kubemq.WithAddress("kubemq-cluster", 50000),
kubemq.WithClientId(uuid.New().String()),
kubemq.WithTransportType(kubemq.TransportTypeGRPC))
if err != nil {
log.Fatal(err)
}
transactionRequest := types.NewRequest().
SetMetadataKeyValue("method", "transaction").
SetData([]byte(transactionString))
queryTransactionResponse, err := client.SetQuery(transactionRequest.ToQuery()).
SetChannel("query.gcp.mysql").
SetTimeout(10 * time.Second).Send(context.Background())
if err != nil {
log.Fatal(err)
}
transactionResponse, err := types.ParseResponse(queryTransactionResponse.Body)
if err != nil {
log.Fatal(err)
}
log.Println(fmt.Sprintf("transaction request result: %s ", transactionResponse.Metadata.String()))
queryRequest := types.NewRequest().
SetMetadataKeyValue("method", "query").
SetData([]byte(queryString))
queryResponse, err := client.SetQuery(queryRequest.ToQuery()).
SetChannel("query.gcp.mysql").
SetTimeout(10 * time.Second).Send(context.Background())
if err != nil {
log.Fatal(err)
}
response, err := types.ParseResponse(queryResponse.Body)
if err != nil {
log.Fatal(err)
}
log.Println(fmt.Sprintf("query request results: %s ", string(response.Data)))
}