Форум программистов, компьютерный форум, киберфорум
Наши страницы

LINQ

Войти
Регистрация
Восстановить пароль
 
Ritm
0 / 0 / 0
Регистрация: 19.08.2011
Сообщений: 26
#1

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

02.01.2018, 20:09. Просмотров 235. Ответов 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 (LINQ):

Есть хранимая процедура SQL. Надо сделать linq запрос - LINQ
Есть хранимая процедура sql. Надо сделать linq запрос. Дело вроде бы простое ,но... ALTER PROCEDURE .(@marka varchar(50),@id_narush...

Переписать SQL запрос в LINQ запрос - LINQ
День добрый всем. Подскажите, пожалуйста, как можно преобразовать запрос: SELECT Price * (SELECT COUNT(SeatNumber) FROM...

SQL запрос в LINQ - LINQ
Я не понимаю как перобразовать такой SQL-запрос для MS SQL SELECT * FROM sysobjects WHERE type = 'U' в запрос через LINQ. Может...

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

Перевести SQL-запрос в LINQ - LINQ
Ребят помогите понять как будет такой запрос выглядить на linq: SELECT COUNT(*) FROM members WHERE member_id = (SELECT id FROM users...

Переписать запрос SQL на LINQ - LINQ
всем доброго времени суток! помогите написать запрос на LINQ вот он на MS SQL: SELECT p.Product_id, m.Manufacturer_name,...

1
_exp10der_
Warrior
418 / 375 / 108
Регистрация: 23.11.2014
Сообщений: 873
05.01.2018, 17:23 #2
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
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");
        }
    }
}
0
Вложения
Тип файла: zip ConsoleApp780.zip (2.4 Кб, 0 просмотров)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
05.01.2018, 17:23
Привет! Вот еще темы с ответами:

Запрос SQL записать в виде LINQ To Entities - LINQ
Написал запрос на SQL: select * from Fuel_way inner Join Fuel on Fuel.id_fuel=Fuel_way.id_fuel where Fuel_way.id_column=2 and...

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

Как правильно сделать linq запрос - LINQ
Здравствуйте, есть вот такой запрос Suplier supplier = (from sup in doc.Descendants(aw + &quot;supplier&quot;) ...

Ускорение Linq to SQL (Compiled Linq, Entity SQL, и т.д.) - LINQ
Здравствуйте! У меня задание стоит ускорить прогу. В проге во многих местах по куче Linq запросов. Я решил их как-нибудь ускорить. Запросы...


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

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

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