asp.net core 3.0 新手问题:如何这段带“count” 和 group by的sql代码,怎么转成 linq的写法?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了asp.net core 3.0 新手问题:如何这段带“count” 和 group by的sql代码,怎么转成 linq的写法?相关的知识,希望对你有一定的参考价值。
原始sql:select EOI_Reach, count(EOI_Reach) from survey where EOI_Category='Valid' group by EOI_Reach
求linq写法,asp.net core 3.0 (mvc)可用
where a.eoi-category=="Valid"
group by a.eoi_reach into g
select new eoi_reach=g.Key,count=g.Count();
如何在 asp.net core 1.0 中查看当前 url
【中文标题】如何在 asp.net core 1.0 中查看当前 url【英文标题】:How to get current url in view in asp.net core 1.0 【发布时间】:2016-07-18 12:41:00 【问题描述】:在以前的asp.net版本中,我们可以使用
@Request.Url.AbsoluteUri
但它似乎改变了。我们如何在 asp.net core 1.0 中做到这一点?
【问题讨论】:
喜欢这个? ***.com/questions/28120222/… @DavidG 看来你现在可以使用 UriHelper.GetDisplayUrl(Request) 【参考方案1】:你必须分别获取主机和路径。
@Context.Request.Host
@Context.Request.Path
【讨论】:
如果您的应用程序位于虚拟目录中,这将不会报告正确的 url。如果有,您需要在 Request.Path 值前面加上 Request.PathBase 值。这也适用于该问题的几乎所有其他答案。 @MohammedNoureldin:这是剃刀视图语法。 对于剃须刀页面,我必须使用@HttpContext
而不是@Context
。对于部分视图@Context
有效。我忘记使用了吗?
MVC中有一个简单的方法Url.Action("Action", null, null, Request.Url.Scheme);
***.com/questions/434604/…
您需要将Request.QueryString
添加到末尾,因为 Request.Path 不包含查询字符串【参考方案2】:
您需要方案、主机、路径和查询字符串
@string.Format("0://123", Context.Request.Scheme, Context.Request.Host, Context.Request.Path, Context.Request.QueryString)
或使用新的 C#6 功能“字符串插值”
@($"Context.Request.Scheme://Context.Request.HostContext.Request.PathContext.Request.QueryString")
【讨论】:
如何获取片段,比如test.com/abc#123,如何从请求中获取#123 片段? @fanray 你不能。浏览器不会向服务器发送 URI 片段 考虑使用UriBuilder 构建url。【参考方案3】:可以使用Request
的扩展方法:
Request.GetDisplayUrl()
【讨论】:
如果您添加@using Microsoft.AspNetCore.Http.Extensions
然后@Context.Request.GetDisplayUrl()
,则此方法有效
仍然得到 - 当前上下文中不存在请求
记住这个函数的intellisense摘要说Suitable only for display. This format should not be used in HTTP headers or other HTTP operations.
基于此,我认为@tmg的解决方案是最好的(也许包装在你自己的扩展方法中)。
如果您希望它在与以前相同类型的 Url 对象中,您可以在获得显示 url 后执行此操作:var uri = new Uri(displayUrl);【参考方案4】:
这在带有Microsoft.AspNetCore.Http.Extensions
的.net core 1.0 中显然总是可行的,它为HttpRequest
添加了扩展以获得完整的URL; GetEncodedUrl.
例如从剃刀的角度来看:
@using Microsoft.AspNetCore.Http.Extensions
...
<a href="@Context.Request.GetEncodedUrl()">Link to myself</a>
从2.0开始,也有相对路径和查询GetEncodedPathAndQuery。
【讨论】:
感谢您提供@using 声明【参考方案5】:使用 Uri 的 AbsoluteUri 属性,使用 .Net 核心,您必须像这样从请求构建 Uri,
var location = new Uri($"Request.Scheme://Request.HostRequest.PathRequest.QueryString");
var url = location.AbsoluteUri;
例如如果请求 url 是 'http://www.contoso.com/catalog/shownew.htm?date=today' 这将返回相同的 url。
【讨论】:
这样的事情让我觉得 .Net Core 在某些方面是倒退了一步。这是否比我无法想象的 Asp.Net 中的 Request.Url 更好?【参考方案6】:可以考虑使用这种扩展方式(来自Microsoft.AspNetCore.Http.Extensions
命名空间:
@Context.Request.GetDisplayUrl()
对于我的一些项目,我更喜欢更灵活的解决方案。有两种扩展方法。
1) 第一种方法从传入的请求数据创建Uri
对象(通过可选参数有一些变体)。
2) 第二种方法接收Uri
对象并以以下格式返回string
(不带斜杠):Scheme_Host_Port
public static Uri GetUri(this HttpRequest request, bool addPath = true, bool addQuery = true)
var uriBuilder = new UriBuilder
Scheme = request.Scheme,
Host = request.Host.Host,
Port = request.Host.Port.GetValueOrDefault(80),
Path = addPath ? request.Path.ToString() : default(string),
Query = addQuery ? request.QueryString.ToString() : default(string)
;
return uriBuilder.Uri;
public static string HostWithNoSlash(this Uri uri)
return uri.GetComponents(UriComponents.SchemeAndServer, UriFormat.UriEscaped);
用法:
//before >> https://localhost:44304/information/about?param1=a¶m2=b
Request.GetUri(addQuery: false);
//after >> https://localhost:44304/information/about
//before >> https://localhost:44304/information/about?param1=a¶m2=b
new Uri("https://localhost:44304/information/about?param1=a¶m2=b").GetHostWithNoSlash();
//after >> https://localhost:44304
【讨论】:
【参考方案7】:接受的答案对我有帮助,@padigan 的评论对我也有帮助,但如果你想像我一样包含查询字符串参数,那么试试这个:
@Context.Request.PathBase@Context.Request.GetEncodedPathAndQuery()
您需要在视图中添加 @using Microsoft.AspNetCore.Http.Extensions
才能使用 GetEncodedPathAndQuery() 方法。
【讨论】:
【参考方案8】:public string BuildAbsolute(PathString path, QueryString query = default(QueryString), FragmentString fragment = default(FragmentString))
var rq = httpContext.Request;
return Microsoft.AspNetCore.Http.Extensions.UriHelper.BuildAbsolute(rq.Scheme, rq.Host, rq.PathBase, path, query, fragment);
【讨论】:
但是你从哪里得到httpContext
?这不适用于Microsoft.AspNetCore.Http.HttpContext.Request
【参考方案9】:
如果您还希望从请求中获取端口号,则需要通过 AspNet Core 的 Request.Host
属性访问它。
Request.Host
属性不仅仅是一个字符串,而是一个包含主机域和端口号的对象。如果在 URL 中明确写出端口号(即"https://example.com:8080/path/to/resource"
),那么调用Request.Host
将为您提供主机域和端口号,如下所示:"example.com:8080"
。
如果您只需要主机域的值或只需要端口号的值,那么您可以单独访问这些属性(即Request.Host.Host
或Request.Host.Port
)。
【讨论】:
【参考方案10】:有一种从 Razor 页面或 PageModel 类获取当前 URL 的简洁方法。那就是:
Url.PageLink()
请注意,我的意思是“ASP.NET Core Razor Pages”,而不是 MVC。
当我想在 ASP.NET Core razor 页面中打印规范 URL 元标记时,我使用此方法。但是有一个问题!它会为您提供应该是该页面正确 URL 的 URL。让我解释一下。
假设你已经为你的页面定义了一个名为“id”的路由,因此你的 URL 应该是这样的
http://example.com/product?id=34
Url.PageLink() 将为您提供如上所示的准确 URL。
现在,如果用户在该 URL 上添加任何额外内容,例如,
http://example.com/product?id=34&somethingElse
然后,您将不会从该方法中获得“其他东西”。这就是为什么它非常适合在 HTML 页面中打印规范的 URL 元标记。
【讨论】:
【参考方案11】:var returnUrl = string.IsNullOrEmpty(Context.Request.Path) ? "~/" : $"~Context.Request.Path.ValueContext.Request.QueryString";
【讨论】:
以上是关于asp.net core 3.0 新手问题:如何这段带“count” 和 group by的sql代码,怎么转成 linq的写法?的主要内容,如果未能解决你的问题,请参考以下文章
如何在 Asp.Net Core 3.0 WebAPI 中启用 CORS
这是如何使用 Entity Framework Core 和 ASP.NET Core MVC 2.2+ 和 3.0 创建数据传输对象 (DTO)
在 Razor (chtml) 中渲染动态视图,如何在 asp.net core 3.0 中将 FileProvider 添加到 razor?
.NET Core 3.0 Preview 6中对ASP.NET Core和Blazor的更新
如何在 ASP NET CORE 3.0 中获取当前登录的用户 ID?
如何在 ASP.NET CORE 3.0 中配置路由以使用带有 [FromQuery] 参数的重载 [HttpGet] 方法?