Table of Contents
Question content
Workaround
Home Backend Development Golang Gorm preloading gives ambiguous column error

Gorm preloading gives ambiguous column error

Feb 10, 2024 pm 07:12 PM
go language

Gorm 预加载给出了不明确的列错误

php editor Zimo introduces to you the ambiguous column error in Gorm preloading. Gorm is an ORM library commonly used in Go language for implementing database operations. When using Gorm for preloading, you sometimes encounter ambiguous column errors. The reason for this error may be that the database table structure is inconsistent with the Gorm model definition, or the preloaded association table column name is incorrect. The solution to this problem is to check the database table structure and Gorm model definition to ensure that they are consistent, and double-check that the preloaded association table column names are correct. By solving this error, you can successfully use Gorm for preloading operations and improve database operation efficiency.

Question content

I have the following structure

type employee struct {
    employeeid        int64  `gorm:"primary_key;column:employee_id"`
    employeecode      string `gorm:"column:employee_code"`
    firstname         string `gorm:"column:first_name"`
    lastname          string `gorm:"column:last_name"`
    designationid     int64  `gorm:"column:designation_id;"`
    designation       *designation `gorm:"foreignkey:designationid"`
}

type designation struct {
    designationid   int64  `gorm:"primary_key;column:designation_id"`
    designationname string `gorm:"column:designation_name"`
}

func getemployee(id int64) (*employee, error) {
    db := connection.getconn() //get connection
    defer db.close()

    employee := &employee{}
    err := db.model(employees).preload("designation", func(db *gorm.db) *gorm.db {
        return db.join("inner join employees on employees.designation_id = designations.id").order("employees.first_name desc")
    }).find(employee).error
    return employee, err
}
Copy after login

The generated query is

SELECT * FROM employees;
SELECT * FROM designations INNER JOIN employees ON employees.designation_id = designations.id WHERE id IN (1,2) order by employees.first_name DESC;
Copy after login

I have a connection similar to what I wrote in the function above. Here I am not able to connect correctly, but in real case I know I need to connect and there is id field in both preload table and join table. Since both tables have same column name i.e. id in this case mysql will throw error

Error 1052: Column "id" in where clause is ambiguous

I encountered this problem in gorm v1.9.16

I didn't find any resources that mentioned similar issues. How do we solve this problem?

Workaround

Can you try using the latest version (> v1.20.x)?

This issue has been closedhttps://github.com/go-gorm/ gorm/issue/2653

This problem seems to be solved in the new versionhttps://github.com/go-gorm/gorm/commit/2ae0653af2bc19cd31f687e797b189c85f0ac3f6

The above is the detailed content of Gorm preloading gives ambiguous column error. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot Article Tags

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to use reflection to access private fields and methods in golang How to use reflection to access private fields and methods in golang May 03, 2024 pm 12:15 PM

How to use reflection to access private fields and methods in golang

Tips for dynamically creating new functions in golang functions Tips for dynamically creating new functions in golang functions Apr 25, 2024 pm 02:39 PM

Tips for dynamically creating new functions in golang functions

The difference between performance testing and unit testing in Go language The difference between performance testing and unit testing in Go language May 08, 2024 pm 03:09 PM

The difference between performance testing and unit testing in Go language

What pitfalls should we pay attention to when designing distributed systems with Golang technology? What pitfalls should we pay attention to when designing distributed systems with Golang technology? May 07, 2024 pm 12:39 PM

What pitfalls should we pay attention to when designing distributed systems with Golang technology?

Golang technology libraries and tools used in machine learning Golang technology libraries and tools used in machine learning May 08, 2024 pm 09:42 PM

Golang technology libraries and tools used in machine learning

The evolution of golang function naming convention The evolution of golang function naming convention May 01, 2024 pm 03:24 PM

The evolution of golang function naming convention

The role of Golang technology in mobile IoT development The role of Golang technology in mobile IoT development May 09, 2024 pm 03:51 PM

The role of Golang technology in mobile IoT development

Can golang variable parameters be used for function return values? Can golang variable parameters be used for function return values? Apr 29, 2024 am 11:33 AM

Can golang variable parameters be used for function return values?

See all articles