Форум программистов, компьютерный форум, киберфорум
Наши страницы
LINQ
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
Ritm
0 / 0 / 0
Регистрация: 19.08.2011
Сообщений: 26
#1

Есть запрос в SQL какой можно сделать аналог в LINQ

02.01.2018, 20:09. Просмотров 894. Ответов 1
Метки нет (Все метки)

SQL
1
2
3
4
5
6
7
8
9
SELECT d.title, a.route_grp
    FROM route a
    JOIN schedule b ON a.schedule_id = b.id
    JOIN station c ON b.station_id = c.id
    JOIN train d ON a.train_id = d.id
    WHERE (b.departure_date = '01.12.2017' AND c.title LIKE 'Орел') 
       OR (b.arrival_date IS NOT NULL AND c.title LIKE 'Москва')
    GROUP BY d.title,a.route_grp
    HAVING COUNT(a.route_grp)>1
Есть запрос в SQL какой можно сделать аналог в LINQ


Есть ли в LINQ аналог Having
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.01.2018, 20:09
Ответы с готовыми решениями:

Есть хранимая процедура SQL. Надо сделать linq запрос
Есть хранимая процедура sql. Надо сделать linq запрос. Дело вроде бы простое...

Переписать SQL запрос в LINQ запрос
День добрый всем. Подскажите, пожалуйста, как можно преобразовать запрос: ...

SQL запрос в LINQ
Я не понимаю как перобразовать такой SQL-запрос для MS SQL SELECT * FROM...

Перевести SQL-запрос в LINQ
Ребят помогите понять как будет такой запрос выглядить на linq: SELECT...

Переписать запрос SQL на LINQ
всем доброго времени суток! помогите написать запрос на LINQ вот он на MS...

1
_exp10der_
Warrior
490 / 417 / 177
Регистрация: 23.11.2014
Сообщений: 932
05.01.2018, 17:23 #2
Лучший ответ Сообщение было отмечено Ritm как решение

Решение

Ritm, Что бы на стороне сервера развернулось в хевинг то нет.
Но рано или позно появиться движение в эту сторону есть в след версии 2.1 https://github.com/aspnet/EntityFrameworkCore/issues/2341
Приближенная кверя

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
using System;
using System.Collections.Generic;
using System.Linq;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Metadata.Builders;
using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Logging.Console;
 
namespace ConsoleApp780
{
    internal class Program
    {
        public static readonly LoggerFactory LoggerFactory
            = new LoggerFactory(new[] {new ConsoleLoggerProvider((_, __) => true, true)});
 
        private static void Main(string[] args)
        {
            var builder = new DbContextOptionsBuilder<ApplicationDbContext>();
            var connectionString =
                "Data Source=192.168.1.56;Initial Catalog=TestDb;Persist Security Info=True;User ID=sa; Password=zxc12EE;";
            builder.UseLoggerFactory(LoggerFactory)
                .UseSqlServer(connectionString);
 
            using (var context = new ApplicationDbContext(builder.Options))
            {
                context.Database.EnsureCreated();
 
                var date = new DateTime(2017, 12, 1);
 
               var query = context.Routes
                    .Where(r =>
                        (r.Schedule.DepartureDate == date && EF.Functions.Like(r.Schedule.Station.Title, "Орел")) ||
                        (r.Schedule.ArrivalDate != null && EF.Functions.Like(r.Schedule.Station.Title, "Москва")))
                    .GroupBy(r => new {r.Train.Title, r.RouteGrp})
                    .Where(g => g.Count() > 1)
                    .Select(g => new {title = g.Key.Title, route_grp = g.Key.RouteGrp});
 
                var result = query.ToList();
            }
        }
    }
 
    internal class ApplicationDbContext : DbContext
    {
        public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options)
            : base(options)
        {
        }
 
        public DbSet<Station> Stations { get; set; }
        public DbSet<Schedule> Schedules { get; set; }
        public DbSet<Route> Routes { get; set; }
        public DbSet<Train> Trains { get; set; }
 
        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            modelBuilder.ApplyConfiguration(new StationConfiguration());
            modelBuilder.ApplyConfiguration(new ScheduleConfiguration());
            modelBuilder.ApplyConfiguration(new RouteConfiguration());
            modelBuilder.ApplyConfiguration(new TrainConfiguration());
        }
    }
 
    internal class Station
    {
        public int Id { get; set; }
        public string Title { get; set; }
        public List<Schedule> Schedules { get; set; }
    }
 
    internal class StationConfiguration : IEntityTypeConfiguration<Station>
    {
        public void Configure(EntityTypeBuilder<Station> builder)
        {
            builder.HasKey(i => i.Id);
            builder.Property(i => i.Id).HasColumnName("id");
 
            builder.Property(i => i.Title).HasColumnType("varchar(100)");
 
            builder.ToTable("station");
        }
    }
 
    internal class Schedule
    {
        public int Id { get; set; }
        public int? StationId { get; set; }
        public Station Station { get; set; }
        public int? StationPos { get; set; }
        public DateTime? ArrivalDate { get; set; }
        public TimeSpan? ArrivalTime { get; set; }
        public int? Parking { get; set; }
        public DateTime? DepartureDate { get; set; }
        public TimeSpan? DepartureTime { get; set; }
        public List<Route> Routes { get; set; }
    }
 
    internal class ScheduleConfiguration : IEntityTypeConfiguration<Schedule>
    {
        public void Configure(EntityTypeBuilder<Schedule> builder)
        {
            builder.HasKey(i => i.Id);
            builder.Property(i => i.Id).HasColumnName("id");
 
            builder.HasOne(i => i.Station).WithMany(i => i.Schedules).HasForeignKey(i => i.StationId);
            builder.Property(i => i.StationId).HasColumnName("station_id");
 
            builder.Property(i => i.StationPos).HasColumnName("station_pos");
            builder.Property(i => i.ArrivalDate).HasColumnType("date").HasColumnName("arrival_date");
            builder.Property(i => i.ArrivalTime).HasColumnType("time(7)").HasColumnName("arrival_time");
 
            builder.Property(i => i.Parking).HasColumnType("tinyint").HasColumnName("parking");
            builder.Property(i => i.DepartureDate).HasColumnType("date").HasColumnName("departure_date");
            builder.Property(i => i.DepartureTime).HasColumnType("time(7)").HasColumnName("departure_time");
 
            builder.ToTable("schedule");
        }
    }
 
    internal class Route
    {
        public int Id { get; set; }
        public int RouteGrp { get; set; }
        public int TrainId { get; set; }
        public Train Train { get; set; }
        public int ScheduleId { get; set; }
        public Schedule Schedule { get; set; }
    }
 
    internal class RouteConfiguration : IEntityTypeConfiguration<Route>
    {
        public void Configure(EntityTypeBuilder<Route> builder)
        {
            builder.HasKey(i => i.Id);
            builder.Property(i => i.Id).HasColumnName("id");
 
            builder.Property(i => i.RouteGrp).HasColumnName("route_grp");
 
            builder.HasOne(i => i.Train).WithMany(i => i.Routes).HasForeignKey(i => i.TrainId);
            builder.Property(i => i.TrainId).HasColumnName("train_id");
 
            builder.HasOne(i => i.Schedule).WithMany(i => i.Routes).HasForeignKey(i => i.ScheduleId);
            builder.Property(i => i.ScheduleId).HasColumnName("schedule_id");
 
            builder.ToTable("route");
        }
    }
 
    internal class Train
    {
        public int Id { get; set; }
        public string Title { get; set; }
        public List<Route> Routes { get; set; }
    }
 
    internal class TrainConfiguration : IEntityTypeConfiguration<Train>
    {
        public void Configure(EntityTypeBuilder<Train> builder)
        {
            builder.HasKey(i => i.Id);
            builder.Property(i => i.Id).HasColumnName("id");
 
            builder.Property(i => i.Title).HasColumnType("varchar(100)");
 
            builder.ToTable("train");
        }
    }
}
1
Вложения
Тип файла: zip ConsoleApp780.zip (2.4 Кб, 0 просмотров)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
05.01.2018, 17:23

Перевести запрос с SQL в LINQ
Доброго времени суток, требуется помощь в переводе запроса с SQL в LINQ, кто...

Перевести SQL запрос в LINQ
Доброе время суток! Вот до этого времени не сталкивался с Join в LINQ....

Как будет выглядеть SQL запрос в LINQ?
SELECT .OrdCount, .OrdInDate, Zak.ZakName FROM Zak INNER JOIN ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru