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

Здесь случаем никто не умеет маппить Даппером ? Можете помочь,

пожалуйста(

18 ответов

9 просмотров

задайте вопрос думаю вам ответят

Документация даппера умеет https://dapper-tutorial.net/result-multi-mapping

Антон-😇 Автор вопроса
К
задайте вопрос думаю вам ответят

Есть строка.. var sql = $"SELECT CR.UserName, CR.DeviceName AS device, CR.LoginTS AS loginTime, UCBD.Country AS unexpectedCountry, UCBD.LoginTS AS unexpectedLoginTime FROM ConcurrentUniqueSessionsWithMultipleDevices CR" + " LEFT JOIN dbo.UniqueCountriesByDay UCBD on CR.UserName = UCBD.UserName AND UCBD.LoginTS = CR.LoginTS"; Которая возвращает результуты в столбцы userName, device, loginTime, unexpectedCountry, unexpectedLoginTime А структура данных которые я должен вывести, имеет следующую сигнатуру. public string? userName { get; set; } public string? device { get; set; } public DateTime loginTime { get; set; } public CleanCountryLogin? unexpectedLogin { get; set; } Где CleanCountryLogin обьект из строки и DateTime И я вот никак не могу замапить эти последнее два столбца в моем коде var insurance = db.Query<CleanConcurrentLogins>( sql, (_userName, _device, _loginTime, _country, _unexpectedLoginTime) => { return new CleanConcurrentLogins() { device = _device, loginTime = _loginTime, userName = _userName, unexpectedLogin = new CleanCountryLogin() { country = _country, loginTime = _unexpectedLoginTime } }; }, splitOn: "unexpectedCountry, unexpectedLoginTime").ToList(); что-то ругается..

Антон-😇 Автор вопроса
Антон 😇
Есть строка.. var sql = $"SELECT CR.UserName,...

Думал еще сделать вот так.. var result = db.Query<CleanConcurrentLogins>(sql) .Select(row => new CleanConcurrentLogins() { userName = row.userName, device = row.device, loginTime = row.loginTime, unexpectedLogin = new CleanCountryLogin(){country = row.unexpectedLogin.country, loginTime = row.unexpectedLogin.loginTime}}) .ToList(); Но почему-то нуллреференс

Антон 😇
Есть строка.. var sql = $"SELECT CR.UserName,...

а просто unexpectedLoginTime в splitOn: пробовал?

Антон 😇
Есть строка.. var sql = $"SELECT CR.UserName,...

db.Query<CleanConcurrentLogins,CleanCountryLogin,CleanConcurrentLogins>(sql,(cleanConcurrentLogins,cleanCountryLogin)=> { })

Slava Zolotov
а просто unexpectedLoginTime в splitOn: пробовал?

а не, там по unexpectedCountry сплит делать надо

Антон-😇 Автор вопроса
Slava Zolotov
а не, там по unexpectedCountry сплит делать надо

Проблема в том, что мне вот это говорит, argument mismatch var insurance = db.Query<CleanConcurrentLogins>( sql, (_userName, _device, _loginTime, _country, _unexpectedLoginTime) => { return new CleanConcurrentLogins() { device = _device, loginTime = _loginTime, userName = _userName, unexpectedLogin = new CleanCountryLogin() { country = _country, loginTime = _unexpectedLoginTime } }; }, splitOn: "unexpectedCountry, unexpectedLoginTime").ToList(); Хотя я вроде бы по примеру делаю со стека

Антон-😇 Автор вопроса
К
db.Query<CleanConcurrentLogins,CleanCountryLogin,C...

А почему целых три типа и зачем последний ?

Антон 😇
А почему целых три типа и зачем последний ?

1и 2 тип для маппа 3 тип возвращаемое значение

Антон 😇
Проблема в том, что мне вот это говорит, argument ...

Сорри за оффтоп. Телега сама коду даёт такой шрифт прикольный?

Антон-😇 Автор вопроса
Kirill
Сорри за оффтоп. Телега сама коду даёт такой шрифт...

Когда-то на винде нужно было его мне оборачивать в А сейчас вот что-то перешел на мак и оно само все делает. Я даже ничего не нажимаю.. Без понятия как оно там сейчас. Главное как и прежде

Антон-😇 Автор вопроса
К
db.Query<CleanConcurrentLogins,CleanCountryLogin,C...

Попробовал сделать как вы и сказали.. var sm = db.Query<CleanConcurrentLogins, CleanCountryLogin, CleanConcurrentLogins>(sql, (cleanConcurrentLogins, cleanCountryLogin) => { return new CleanConcurrentLogins() { device = cleanConcurrentLogins.device, loginTime = cleanConcurrentLogins.loginTime, userName = cleanConcurrentLogins.userName, unexpectedLogin = cleanCountryLogin }; }).ToList(); System.ArgumentException: When using the multi-mapping APIs ensure you set the splitOn param if you have keys other than Id (Parameter 'splitOn') Да что же так сложно-то(

Антон 😇
Попробовал сделать как вы и сказали.. var sm = d...

cleanConcurrentLogins и есть объект CleanConcurrentLogins ,не надо еще один объект создовать)

Slava Zolotov
а не, там по unexpectedCountry сплит делать надо

@AntonioParroni попробуйте еще spliton как тут сказано добавить

Антон-😇 Автор вопроса
К
@AntonioParroni попробуйте еще spliton как тут ск...

Досплитился блин. var sm = db.Query<CleanConcurrentLogins, CleanCountryLogin, CleanConcurrentLogins>( sql:sql, map: (cleanConcurrentLogins, cleanCountryLogin) => { return new CleanConcurrentLogins() { device = cleanConcurrentLogins.device, loginTime = cleanConcurrentLogins.loginTime, userName = cleanConcurrentLogins.userName, unexpectedLogin = cleanCountryLogin };}, splitOn: "unexpectedCountry, unexpectedLoginTime").ToList(); Оно теперь работает.. но возвращает просто какую-то дичь. Страна не мапится, а время 0001-01-01T00:00:00 Прекрасно

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

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

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Заметил в ghci 9.4.8: > :t (<*>) @((->)_) (<*>) @((->)_) :: (w -> (a -> b)) -> (w -> a) -> w -> b Разве не должно (w -> (a -> b)) быть записано как (w -> a -> b)? Это баг, ил...
Михаил
13
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Any electron dev here?
Sayanth Tezro
12
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
так это может кто что знает или использует что-то как макбук только не макбук? на 13…14 дюймов
Michael
9
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Кто-нибудь знает почему SPM клонирует репо целиком? Некоторые репы просто огромные, как та же swift-syntax которая нужна для использования макросов. Сначала подумал, что это...
iMike
6
Карта сайта