1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- package sdk
- import (
- "encoding/json"
- "git.sxidc.com/go-tools/utils/reflectutils"
- "git.sxidc.com/service-supports/ds-sdk/grpc_client/v1"
- "git.sxidc.com/service-supports/ds-sdk/grpc_client/v1/request"
- "github.com/pkg/errors"
- "reflect"
- )
- type TxFunc func(tx *Transaction) error
- type Transaction struct {
- stream v1.SqlService_TransactionClient
- }
- func (tx *Transaction) ExecuteRawSql(sql string, values ...any) ([]map[string]any, int64, error) {
- var retErr error
- defer func() {
- if retErr != nil {
- innerErr := tx.stream.CloseSend()
- if innerErr != nil {
- panic(innerErr)
- }
- }
- }()
- rawSqlValues := make([]map[string]any, 0)
- for _, value := range values {
- typedValueReflectValue := reflect.ValueOf(value)
- if !typedValueReflectValue.IsValid() {
- return nil, 0, errors.New("无效值")
- }
- typedValueReflectValueElem := reflectutils.PointerValueElem(typedValueReflectValue)
- values = append(values, map[string]any{
- "kind": typedValueReflectValueElem.Kind(),
- "value": typedValueReflectValueElem.Interface(),
- })
- }
- requestMap := map[string]any{
- "sql": sql,
- "values": rawSqlValues,
- }
- requestJsonBytes, err := json.Marshal(requestMap)
- if err != nil {
- retErr = err
- return nil, 0, retErr
- }
- err = tx.stream.SendMsg(&request.TransactionOperation{
- Request: &request.TransactionOperation_ExecuteRawSqlJsonRequest{
- ExecuteRawSqlJsonRequest: string(requestJsonBytes),
- },
- })
- if err != nil {
- retErr = err
- return nil, 0, retErr
- }
- resp, err := tx.stream.Recv()
- if err != nil {
- retErr = err
- return nil, 0, retErr
- }
- if !resp.Success {
- retErr = errors.New(resp.Msg)
- return nil, 0, retErr
- }
- tableRows := make([]map[string]any, 0)
- err = json.Unmarshal([]byte(resp.Results), &tableRows)
- if err != nil {
- retErr = err
- return nil, 0, retErr
- }
- results := make([]map[string]any, len(tableRows))
- for i, row := range tableRows {
- results[i] = row
- }
- return results, resp.RowsAffected, nil
- }
|