Scan function by reference or by value

后端 未结 1 1099
别那么骄傲
别那么骄傲 2021-01-28 07:16

I have the following code:

statement := `SELECT id from source where mgmt = $1 `
var exists string
errUnique := dr.db.QueryRow(statement, mgmt).Scan(exists)
if e         


        
相关标签:
1条回答
  • 2021-01-28 07:44

    You should have exists be the same type as, or a compatible type to, the type of the value you are retrieving from the database.

    Since you're selecting the id column, I will assume that it is an integer, and therefore you should declare exists as follows var exists int. If, however, you want to find out whether a row is present in the table or not you would generally use a query of the form:

    SELECT EXISTS(SELECT 1 FROM source WHERE mgmt= $1)
    

    (at least in postgres, I'm not sure what db you're using)

    EXISTS:

    The argument of EXISTS is an arbitrary SELECT statement, or subquery. The subquery is evaluated to determine whether it returns any rows. If it returns at least one row, the result of EXISTS is “true”; if the subquery returns no rows, the result of EXISTS is “false”.

    Then your Go code would something like this:

    query := `SELECT EXISTS(SELECT 1 FROM source WHERE mgmt = $1)`
    
    var exists bool
    if err := dr.db.QueryRow(query, mgmt).Scan(&exists); err != nil {
        return err
    }
    
    if exists {
        // already taken
    } else {
        // unique
    }
    

    Also note that since EXISTS always returns a boolean value you don't have to check the error against sql.ErrNoRows, if you do get an error it would not be that one.

    0 讨论(0)
提交回复
热议问题