170 похожих чатов

Скажите пожалуйста, как правильно парсить sql rows в случае если

там джоин из m2m связи

вот например я делаю запрос чтоб получить user_id, product_id, product_name
получаю такой респонс:


+------------+-------------------------------------------------------------------------+
|user_id |337ade25-d0bf-4e45-b807-a28956a352cc|337ade25-d0bf-4e45-b807-a28956a352cc|
+------------+-------------------------------------------------------------------------+
|product_id |237baa3d-8100-4ae6-bb46-35838a6c3e46|237baa3d-8100-4ae6-bb46-35838a6c3e46|
+------------+-------------------------------------------------------------------------+
|product_name|Wifi |Staging |
+------------+-------------------------------------------------------------------------+


Выходит что я получил 2 продукта (Wifi, Staging), но user_id дублируется для каждого продукта, т.е 2 раза

Я хочу это распарсить в свою гошную структуру:


type User struct {
UserID uuid.UUID
Products []*Products
}

type Product struct {
ProductID uuid.UUID
Name string
}


То есть вот я получил sql.Rows, делаю по ним итерацию и могу достать продукт. Но как мне достать правильно user ID с учетом что он будет лежать в каждой row? просто доставать это из первой записи и все? Только такой вариант мне кажется логичным, но выглядит как костыль)


логика примерно такая выходит:


// сначала достать user id из первой строки
var userID uuid.UUID
rows.Scan(&userID)
// затем создать структуру юзера
user := &User{userID: userID}
// затем итернуться по rows.Next() и сформировать список продуктов


То есть я знаю как работать с sql.Rows, но меня смущает вариант реализации как достать одно какое-то значение, когда оно дублируется во всех остальных строках. Надеюсь вы поняли мой вопрос)

3 ответов

16 просмотров

Обычно m2m выбирается доп запросом Если ты хочешь за раз, то тебе нужно сгруппировать данные по ключу (нарпимер, user_id)

rglitchard- Автор вопроса
First Last
Обычно m2m выбирается доп запросом Если ты хочешь ...

а я чот думал что если все это запихнуть в один запрос то будет быстрее

rglitchard
а я чот думал что если все это запихнуть в один за...

Ну тут чат про го) Выбрать за раз все нужные данные будет быстрее всегда (практически)

Похожие вопросы

Обсуждают сегодня

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Мужики. привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных элементов...
Kraszx
2
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Всем привет! Кто пользуется DevExpress, подскажите пожалуйста, реализован ли в TcxGrid в новых версиях поиск по датам как в Экселе (ну т.е. не просто список чекбоксов со значе...
A Z
4
Карта сайта