首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Golang如何在SqlC中使用Validator

Golang如何在SqlC中使用Validator
EN

Stack Overflow用户
提问于 2022-10-13 02:50:00
回答 1查看 95关注 0票数 1

有没有任何方法可以组合JSON验证github.com/go-游乐场/验证器/V10和JSON查询sqlc,而不必创建两个不同的结构?

我有下表定义

代码语言:javascript
复制
CREATE TABLE table1 (
   columnName1 VARCHAR(200) NOT NULL PRIMARY KEY,
   columnName2 VARCHAR(200) NOT NULL
)

和下面的查询

代码语言:javascript
复制
-- name: GetTable1:one
SELECT * FROM table1
WHERE columnName1 = $1 LIMIT 1;

执行SQLC生成以下代码

代码语言:javascript
复制
...
// 
// This struct is created automatically by sqlC
//
type CreateTable1Params struct {
    Columnname1 string                `json:"columnname1"`
    Columnname2 string                `json:"columnname2"`
}

func (q *Queries) CreateTable1(ctx context.Context, arg CreateTable1Params ) (Table1, error) {
...
}

现在,我需要验证CreateTable1的REST参数,假设需要columnName2,所以我有一个控制器包,如下所示

table1Controller.go

代码语言:javascript
复制
import (
    ...
    validator "github.com/go-playground/validator/v10"
)

type Table1Controller struct {
    Validate   *validator.Validate
}

//
// This struct is created manually for validation
//
type InT1Param struct {
    ColumnName1 string `validate:"required" form:"columnName1" json:"columnName1" db:"columnname1"`
    ColumnName2 string `validate:"required" form:"columnName2" json:"columnName2" db:"columnname2" binding="required"`
}

func (c *Table1Controller) validateInput(t1 InT1Param) error {
    err := service.Validate.Struct(t1)
    if err != nil {
        errStr := ""
        for _, mapErr := range err.(validator.ValidationErrors) {
            errStr = fmt.Sprintf("%s%s\n", errStr, mapErr.Translate(service.Translator))
        }
        return errors.New(errStr)
    }

    return nil
}

func (c *Table1Controller) Insert(ctx *gin.Context, dbQueries *dbModel.Queries, t1 InT1Param) error {
    err := c.validateInput(t1)
    if err != nil {
        return err

    inParam = dbModel.CreateTable1Param {
        Columnname1: t1.columnName1,
        Columnname2: t2.ColumnName2
    }

    outParam, err := dbQueries.CreateTable1(ctx, inParam)
    if err != nil {
        return err

    return nil
}
EN

回答 1

Stack Overflow用户

发布于 2022-10-15 14:07:31

使用覆盖配置的sqlc.yaml键,我能够将以下字段添加到列中。

代码语言:javascript
复制
version: 2
sql:
  - schema: "./dbModel/migration/schema_20221008.sql"
    queries: "./dbModel/query/query.sql"
    engine: "postgresql"
    gen:
      go:
        package: "dbModel"
        out: "dbModel"
        emit_json_tags: true
        emit_db_tags: true
        emit_prepared_queries: false
        emit_interface: false
        emit_exact_table_names: false
        json_tags_case_style: camel
        overrides:
          - column: table1.column_name1
            go_struct_tag: validate:"required" x:"y,z"
          - column: table1.column_name2
            go_struct_tag: validate:"required"

此配置为表生成了以下结构:

代码语言:javascript
复制
type table1 struct {
    ColumnName1 string `db:"column_name1" json:"columnName1" validate:"required" x:"y,z"`
    ColumnName2 string `db:"column_name2" json:"columnName2" validate:"required"`

我无法更改Param结构,但我猜使用表主结构使用验证。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74049973

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档