GVKun编程网logo

同一张表的两个外键。如何编写此SELECT语句?(一个表两个外键关联同一个表)

23

在本文中,我们将详细介绍同一张表的两个外键。如何编写此SELECT语句?的各个方面,并为您提供关于一个表两个外键关联同一个表的相关解答,同时,我们也将为您带来关于GORM:一张表的两个外键、MySQL

在本文中,我们将详细介绍同一张表的两个外键。如何编写此SELECT语句?的各个方面,并为您提供关于一个表两个外键关联同一个表的相关解答,同时,我们也将为您带来关于GORM:一张表的两个外键、MySQL SELECT同时UPDATE同一张表、mysql – 如何创建Tab Delimited Select语句?、mysql 在一条语句中update和select同一张表的有用知识。

本文目录一览:

同一张表的两个外键。如何编写此SELECT语句?(一个表两个外键关联同一个表)

同一张表的两个外键。如何编写此SELECT语句?(一个表两个外键关联同一个表)

用户表

user_id    username    thumb_id    fullimage_id1          jprescott   14          152          lpausch     18          19

图片表

image_id    path14          jprescott/small.jpg15          jprescott/big.jpg16          msamuels/small.jpg17          msamuels/big.jpg18          lpausch/small.jpg19          lpausch/big.jpg

现在,我该如何编写SELECT语句来检索具有Thumb和fullimage路径的用户?问题是在同一个表中有两个外键。

答案1

小编典典

您执行两次联接:

SELECT u.username, i1.path AS thumb, i2.path AS full  FROM users AS u    JOIN images AS i1 ON u.thumb_id = i1.image_id    JOIN images AS i2 ON u.fullimage_id = i2.image_id

GORM:一张表的两个外键

GORM:一张表的两个外键

gorm:一张表的两个外键

在使用GORM进行数据库操作时,我们常常会遇到一张表需要同时关联两个外键的情况。这种情况下,如何正确地设置和使用外键成为了一个需要解决的问题。在本文中,php小编鱼仔将为大家详细介绍如何使用GORM来处理一张表的两个外键,以及相关的注意事项和实际应用案例。通过学习本文,相信大家能够更好地理解和运用GORM进行数据库操作。

问题内容

我想创建三个表:用户、事件、配对。

在配对表中将有三列:eventId、user1、user2。 所以user1、user2都会通过id引用Users表。

我知道如何在 sql 中执行此操作,但我想尝试使用 ORM。我已阅读文档,但我不知道如何做到这一点

type User struct {
    Id       uint64 `gorm:"primarykey"`
    TGtag    string
    IsActive bool
}

type RCEvent struct {
    Id          uint64 `gorm:"primarykey"`
    DateStarted time.Time
    IsActive    bool
}

type Pair struct {
    EventId uint64
    UserID1 uint64
    UserID2 uint64
}
登录后复制

我尝试用 gorm 标签做一些事情,比如这样,但没有成功:

type User struct {
    Id       uint64 `gorm:"primarykey"`
    TGtag    string
    IsActive bool
}

type RCEvent struct {
    Id          uint64 `gorm:"primarykey"`
    DateStarted time.Time
    IsActive    bool
    Pairs       []Pair `gorm:"many2many:pair;"`
}

type Pair struct {
    EventId uint64 `gorm:"primarykey"`
    UserID1 uint64 `gorm:"primarykey"`
    UserID2 uint64 `gorm:"primarykey"`
}
登录后复制

另外,我尝试了类似的方法并遇到了运行时错误

type User struct {
    Id       uint64 `gorm:"primarykey"`
    TGtag    string
    IsActive bool
}

type RCEvent struct {
    Id          uint64 `gorm:"primarykey"`
    DateStarted time.Time
    IsActive    bool
}

type Pair struct {
    Event   RCEvent
    User1 User //`gorm:"foreignkey:UserId"`
    User2 User //`gorm:"foreignkey:UserId"`
}
登录后复制
[error] failed to parse value &db.Pair{Event:db.RCEvent{Id:0x0, DateStarted:time.Date(1, time.January, 1, 0, 0, 0, 0, time.UTC), IsActive:false}, User1:db.User{Id:0x0, TGtag:"", IsActive:false}, User2:db.User{Id:0x0, TGtag:"", IsActive:false}}, got error invalid field found for struct untitledPetProject/internal/db.Pair''s field Event: define a valid foreign key for relations or implement the Valuer/Scanner interface
登录后复制

解决方法

要使用另一个结构作为外键,您应该将其 id 添加为目标结构中的另一个字段,对于您的情况,这里是工作示例(使用 gorm 示例):

package main

import (
    "log"
    "time"

    "gorm.io/driver/sqlite"
    "gorm.io/gorm"
)

type User struct {
    gorm.Model
    ID       uint64 `gorm:"primarykey"`
    TGtag    string
    IsActive bool
}

type RCEvent struct {
    gorm.Model
    ID          uint64 `gorm:"primarykey"`
    DateStarted time.Time
    IsActive    bool
}

type Pair struct {
    gorm.Model
    ID      uint64 `gorm:"primarykey"`
    EventID uint64
    Event   RCEvent
    User1ID uint64
    User1   User
    User2ID uint64
    User2   User
}

func main() {
    db, err := gorm.Open(sqlite.Open("test.db"), &gorm.Config{})
    if err != nil {
        panic("failed to connect database")
    }

    // Migrate the schema
    err = db.AutoMigrate(&User{})
    if err != nil {
        log.Fatal(err)
    }
    err = db.AutoMigrate(&RCEvent{})
    if err != nil {
        log.Fatal(err)
    }
    err = db.AutoMigrate(&Pair{})
    if err != nil {
        log.Fatal(err)
    }

    // Create
    user1 := User{ID: 2, TGtag: "mohammad"}
    user2 := User{ID: 3, TGtag: "ali"}
    event := RCEvent{ID: 2}
    pair := Pair{ID: 2, EventID: 2, Event: event, User1ID: 2, User1: user1, User2ID: 3, User2: user2}
    db.Create(&user1)
    db.Create(&user2)
    db.Create(&event)
    db.Create(&pair)

    // Read
    var user User
    db.First(&user, 3)                   // find product with integer primary key
    db.First(&user, "t_gtag = ?", "ali") // find product with code D42

    // Update - update product''s price to 200
    db.Model(&user).Update("is_active", false)
    // Update - update multiple fields
    db.Model(&user).Updates(User{ID: 4, TGtag: "ahmad"}) // non-zero fields
    db.Model(&user).Updates(map[string]interface{}{"Id": 5, "TGtag": "hasan"})

    // Delete - delete product
    db.Delete(&user, 2)
}
登录后复制

以上就是GORM:一张表的两个外键的详细内容,更多请关注php中文网其它相关文章!

MySQL SELECT同时UPDATE同一张表

MySQL SELECT同时UPDATE同一张表

MySQL不允许SELECT FROM后面指向用作UPDATE的表,有时候让人纠结。当然,有比创建无休止的临时表更好的办法。本文解释如何UPDATE

mysql不允许select from后面指向用作update的表,有时候让人纠结。当然,有比创建无休止的临时表更好的办法。本文解释如何update一张表,同时在查询子句中使用select.

问题描述

假设我要UPDATE的表跟查询子句是同一张表,这样做有许多种原因,例如用统计数据更新表的字段(此时需要用group子句返回统计值),从某一条记录的字段update另一条记录,而不必使用非标准的语句,等等。举个例子:

create table apples(variety char(10) primary key, price int);

insert into apples values(''fuji'', 5), (''gala'', 6);

update apples
    set price = (select price from apples where variety = ''gala'')
    where variety = ''fuji'';

错误提示是:ERROR 1093 (HY000): You can''t specify target table ''apples'' for update in FROM clause. MySQL手册UPDATE documentation这下面有说明 : “Currently, you cannot update a table and select from the same table in a subquery.”

在这个例子中,要解决问题也十分简单,,但有时候不得不通过查询子句来update目标。好在我们有办法。

解决办法

既然MySQL是通过临时表来实现FROM子句里面的嵌套查询,那么把嵌套查询装进另外一个嵌套查询里,可使FROM子句查询和保存都是在临时表里进行,然后间接地在外围查询被引用。下面的语句是正确的:

update apples
  set price = (
      select price from (
        select * from apples
      ) as x
      where variety = ''gala'')
  where variety = ''fuji'';

如果你想了解更多其中的机制,请阅读MySQL Internals Manual相关章节。

linux

mysql – 如何创建Tab Delimited Select语句?

mysql – 如何创建Tab Delimited Select语句?

我需要将列与select statment组合在一起,以便创建制表符分隔文件.

对于.例如

Select ColumnA || "," || ColumnB

上面的语句将创建逗号分隔文件.我应该写什么来创建制表符分隔文件?

请告诉我.

最佳答案
MysqL的:

select concat(ColumnA,"\t",ColumnB)

sql Server:

select ColumnA + char(9) + ColumnB

甲骨文:

select ColumnA || chr(9) || ColumnB

mysql 在一条语句中update和select同一张表

mysql 在一条语句中update和select同一张表

MySQL不允许SELECT FROM后面指向用作UPDATE的表,有时候让人纠结。本文解释如何UPDATE一张表,同时在查询子句中使用SELECT. 问题描述 假设我要UPDATE的表跟查询子句是同一张表,这样做有许多种原因,例如用统计数据更新表的字段(此时需要用group子句返回统计值),从某一条记录的字段update另一条记录,而不必使用非标准的语句,等等。举个例子:

create table apples(variety char(10) primary key, price int);

insert into apples values(''fuji'', 5), (''gala'', 6);

update apples
set price = (select price from apples where variety = ''gala'')
where variety = ''fuji'';

错误提示是:ERROR 1093 (HY000): You can''t specify target table ''apples'' for update in FROM clause. MySQL手册UPDATE documentation这下面有说明 : “Currently, you cannot update a table and select from the same table in a subquery.” 在这个例子中,要解决问题也十分简单,但有时候不得不通过查询子句来update目标。好在我们有办法。

解决办法 既然MySQL是通过临时表来实现FROM子句里面的嵌套查询,那么把嵌套查询装进另外一个嵌套查询里,可使FROM子句查询和保存都是在临时表里进行,然后间接地在外围查询被引用。下面的语句是正确的:

update apples
set price = (
select price from (
select * from apples
) as x
where variety = ''gala'')
where variety = ''fuji'';

今天关于同一张表的两个外键。如何编写此SELECT语句?一个表两个外键关联同一个表的讲解已经结束,谢谢您的阅读,如果想了解更多关于GORM:一张表的两个外键、MySQL SELECT同时UPDATE同一张表、mysql – 如何创建Tab Delimited Select语句?、mysql 在一条语句中update和select同一张表的相关知识,请在本站搜索。

本文标签: