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

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

пожалуйста(

18 ответов

25 просмотров

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

Документация даппера умеет 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 Прекрасно

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта