目录
问题内容
解决方法
结构体定义
设置和种子
读取逻辑
首页 后端开发 Golang 如何查询关系的嵌入值等于特定值的模型?

如何查询关系的嵌入值等于特定值的模型?

Feb 09, 2024 pm 06:39 PM
sql语句

如何查询关系的嵌入值等于特定值的模型?

在开发和设计数据库模型时,有时我们需要查询关系中的嵌入值是否等于特定值。这个问题在实际应用中经常遇到,但解决起来可能并不容易。在本文中,我将向大家介绍一种有效的方法来查询关系的嵌入值是否等于特定值的模型。无需担心,我会用简明易懂的语言解释清楚,帮助您快速理解并应用到实际开发中。让我们一起来看看吧!

问题内容

我有两个不同的模型(carstypes),它们彼此相关(属于关系),其中两个模型都有一个嵌入式 struct 用于公共数据(post)。我想检索某些 types,但只想收到 postcars 值等于某个值的答案。

shorty说,根据下面的模型,我想找到所有types,其中cars.post.published等于true。

模型

type post struct {
  published bool
}

type car struct {
  gorm.model
  brand string
  post post `gorm:"embedded"`
}

type type struct {
  gorm.model
  name string
  carid uint32
  car car
  post post `gorm:"embedded"`
}
登录后复制

使用 db.preload("car").find(&type) 我能够在答案对象中获取 car 值。如果我在 car 结构上使用 where() 函数(即 where(car{brand: "volvo"}) 我可以通过 brand 获取值,但是当使用 post 时(即 where(car{post: post {published: true})) 它只会返回所有内容。

我最好使用需要查询的主模型作为 where() 函数的基础。例如:

q := Type{Car: Car{Post: Post{Published: true}}}
db.Preload("Car").Where(q).Find(&Type)
登录后复制

...但这似乎不起作用。如何在不使用原始 sql 生成器的情况下实现这样的查询?

解决方法

我能够通过以下方式解决您的问题。首先,我将分享代码,然后我将介绍值得解释的要点。

package main

import (
    "fmt"

    "gorm.io/driver/postgres"
    "gorm.io/gorm"
)

type Post struct {
    Published bool
}

type Car struct {
    gorm.Model
    Brand  string
    TypeID int
    Type   Type
    Post   Post `gorm:"embedded"`
}

type Type struct {
    gorm.Model
    Name  string
    CarID int
    Post  Post `gorm:"embedded"`
}

func main() {
    dsn := "host=localhost port=54322 user=postgres password=postgres dbname=postgres sslmode=disable"
    db, err := gorm.Open(postgres.Open(dsn))
    if err != nil {
        panic(err)
    }
    db.AutoMigrate(&Car{})
    db.AutoMigrate(&Type{})

    // uncomment these to seed data
    // db.Create(&Car{Brand: "Tesla", Type: Type{Name: "SUV", Post: Post{Published: true}}, Post: Post{Published: true}})
    // db.Create(&Car{Brand: "Ford", Type: Type{Name: "City", Post: Post{Published: false}}, Post: Post{Published: false}})

    var cars []Car
    if err := db.Debug().Model(&Car{}).Preload("Type").Where(&Car{Post: Post{Published: true}}).Find(&cars).Error; err != nil {
        panic(err)
    }
    for _, v := range cars {
        fmt.Println(v.Type.Name)
    }
}
登录后复制

现在,让我分享一些见解。

结构体定义

我稍微改变了它来处理这个场景。我从 type 结构中删除了 car 字段,并在 car 结构定义中添加了其对应项。

设置和种子

然后,我通过 gorm 设置了数据库连接。我将代码中定义的模型与数据库中存在的关系同步。为了演示,我手动播种了一些虚拟数据。

读取逻辑

然后,我运行查询来获取相关数据。我使用了以下方法:

  1. debug:用于记录实际的sql语句
  2. model:用于指定我们要处理的关系
  3. preload:用于加载type关联
  4. where:用于指定条件(在我们的例子中,过滤器位于嵌入结构上)
  5. find:用于将结果映射到变量

请告诉我这是否有助于解决您的问题,谢谢!

以上是如何查询关系的嵌入值等于特定值的模型?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1674
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
sql server怎么用sql语句创建表 sql server怎么用sql语句创建表 Apr 09, 2025 pm 03:48 PM

在 SQL Server 中使用 SQL 语句创建表的方法:打开 SQL Server Management Studio 并连接到数据库服务器。选择要创建表的数据库。输入 CREATE TABLE 语句,指定表名、列名、数据类型和约束。单击执行按钮创建表。

sql语句三个表连接怎么写教程 sql语句三个表连接怎么写教程 Apr 09, 2025 pm 02:03 PM

本文介绍了一种使用 SQL 语句连接三个表的详细教程,指导读者逐步了解如何有效地关联不同表中的数据。通过示例和详细的语法讲解,本文将帮助您掌握 SQL 中表的连接技术,从而能够高效地从数据库中检索关联信息。

PHP如何使用phpMyadmin创建Mysql数据库 PHP如何使用phpMyadmin创建Mysql数据库 Apr 10, 2025 pm 10:48 PM

phpMyAdmin 可用于在 PHP 项目中创建数据库。具体步骤如下:登录 phpMyAdmin,点击“新建”按钮。输入要创建的数据库的名称,注意符合 MySQL 命名规则。设置字符集,如 UTF-8,以避免乱码问题。

SQL注入怎么判断 SQL注入怎么判断 Apr 09, 2025 pm 04:18 PM

判断 SQL 注入的方法包括:检测可疑输入、查看原始 SQL 语句、使用检测工具、查看数据库日志和进行渗透测试。检测到注入后,采取措施修补漏洞、验证补丁、定期监控、提高开发人员意识。

PostgreSQL如何添加列? PostgreSQL如何添加列? Apr 09, 2025 pm 12:36 PM

PostgreSQL 添加列的方法为使用 ALTER TABLE 命令并考虑以下细节:数据类型:选择适合新列存储数据的类型,如 INT 或 VARCHAR。默认值:通过 DEFAULT 关键字指定新列的默认值,避免值为 NULL。约束条件:根据需要添加 NOT NULL、UNIQUE 或 CHECK 约束条件。并发操作:使用事务或其他并发控制机制处理添加列时的锁冲突。

怎样检查sql语句 怎样检查sql语句 Apr 09, 2025 pm 04:36 PM

检查 SQL 语句的方法有:语法检查:使用 SQL 编辑器或 IDE。逻辑检查:验证表名、列名、条件和数据类型。性能检查:使用 EXPLAIN 或 ANALYZE,检查索引并优化查询。其他检查:检查变量、权限和测试查询。

mysql 是否要付费 mysql 是否要付费 Apr 08, 2025 pm 05:36 PM

MySQL 有免费的社区版和收费的企业版。社区版可免费使用和修改,但支持有限,适合稳定性要求不高、技术能力强的应用。企业版提供全面商业支持,适合需要稳定可靠、高性能数据库且愿意为支持买单的应用。选择版本时考虑的因素包括应用关键性、预算和技术技能。没有完美的选项,只有最合适的方案,需根据具体情况谨慎选择。

sql语句insert怎么用 sql语句insert怎么用 Apr 09, 2025 pm 06:15 PM

SQL INSERT 语句用于将数据插入表中。步骤包括:指定目标表列出要插入的列指定要插入的值(值的顺序需与列名对应)

See all articles