小编Nug*_*ugs的帖子

在select语句中将Datetime列从UTC转换为本地时间

我正在做一些SQL选择查询,并希望将我的UTC日期时间列转换为本地时间,以便在我的查询结果中显示为本地时间.注意,我不希望通过代码进行此转换,而是在我对数据库进行手动和随机SQL查询时.

sql sql-server

189
推荐指数
11
解决办法
38万
查看次数

正确的方法来重写Equals()和GetHashCode()

我之前从未真正这样做过,所以我希望有人可以告诉我正确实现我的类的Except()和GetHashCode()的重写.

我正在尝试修改类,以便我可以使用LINQ Except()方法.

public class RecommendationDTO{public Guid RecommendationId { get; set; }
public Guid ProfileId { get; set; }
public Guid ReferenceId { get; set; }
public int TypeId { get; set; }
public IList<TagDTO> Tags { get; set; }
public DateTime CreatedOn { get; set; }
public DateTime? ModifiedOn { get; set; }
public bool IsActive { get; set; }
public object ReferencedObject { get; set; }
public bool IsSystemRecommendation { get; set; }
public int VisibilityScore { get; …
Run Code Online (Sandbox Code Playgroud)

c# equality gethashcode

94
推荐指数
3
解决办法
12万
查看次数

IIS Url重写模块导致"无法在Web服务器上启动调试"

我刚刚为IIS 7实现了URL Rewrite Module 2.0,它似乎导致Visual Studio 2010中的"无法在Web服务器上启动调试"错误.

除了在web.config中评论节点之外,是否有人知道VS2010是否可以修复此问题?

谢谢

c# iis-7 url-rewriting visual-studio-2010

8
推荐指数
1
解决办法
1762
查看次数

从另一个IList <>中删除一个IList <>中的项目

很抱歉发布这样的基本问题,我是LINQ的新手,我正试图找出最好的方法来做到这一点IList.

我有2 ILists<>个自定义dto对象.我想从列表中删除另一个中的所有匹配项.

IList<ItemDTO> list1 = itemsbl.GetBestItems();
IList<ItemDTO> list2 = itemsbl.GetWorstItems();
Run Code Online (Sandbox Code Playgroud)

我需要删除所有项目list1list2.我一直在看这个Except()方法,但显然我需要我的ItemsDTO类来覆盖GetHashCodeEquals方法,但我无法找到一些这样的例子.

可能有人请告诉我删除的最佳方式list1list2

再次感谢

c# linq linq-to-entities

8
推荐指数
1
解决办法
7533
查看次数

NuGet与具有EF6实体的类的直接引用

我有一个包含许多EF6实体的类库.我从这个库中生成了一个NuGet.每当我直接引用库时,只将DLL放在bin中,但是当我通过NuGet安装库时,它会将实体*Content.tt和*.tt文件复制到项目的一个文件夹中.

关于这种差异,我有几个问题:

  1. 为什么NuGet在项目引用时不需要这些文件?

  2. 是否需要这些实体文件,或者我是否能够强制NuGet在安装时不克隆这些文件?

我的.nuspec文件是标准的,如下所示:

    <?xml version="1.0"?>
    <package >
      <metadata>
        <id>MYID</id>
        <version>12.0.2</version>
        <title>MYTITLE</title>
        <authors>MYNAME</authors>
        <owners></owners>
        <requireLicenseAcceptance>false</requireLicenseAcceptance>
        <description</description>
        <releaseNotes></releaseNotes>
        <copyright>Copyright 2017</copyright>
        <tags></tags>
      </metadata>
    </package>
Run Code Online (Sandbox Code Playgroud)

我用来生成包的命令是:

c:\nuget.exe pack MYID.csproj -IncludeReferencedProjects -Prop Platform = AnyCPU

c:\nuget.exe添加MYID.1.0.0.nupkg -Source M:\ Dev\NuGetPackages

c# nuget

7
推荐指数
1
解决办法
267
查看次数

在应用程序配置中找不到连接名称"LocalSqlServer",或者连接字符串为空

所以昨天我在我的开发机器上安装了PHP和MySQL.从那时起,我在尝试运行我的一个.NET项目时遇到以下错误:

在应用程序配置中找不到连接名称"LocalSqlServer",或者连接字符串为空.

它引用了Machine.Config的这一行:

<add name="AspNetSqlRoleProvider" connectionStringName="LocalSqlServer" applicationName="/" type="System.Web.Security.SqlRoleProvider, System.Web, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
Run Code Online (Sandbox Code Playgroud)

我在线搜索,高低,可以确认我的machine.config有必要的连接字符串:

  <connectionStrings>
<add name="LocalSqlServer" connectionString="data source=.\SQLEXPRESS;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|aspnetdb.mdf;User Instance=true" providerName="System.Data.SqlClient" />
<add name="LocalMySqlServer" connectionString="" />
Run Code Online (Sandbox Code Playgroud)

有趣的是,我在我的生产服务器(服务器2008)上执行了完全相同的安装PHP和MySQL的操作,并且没有问题.我的开发机器是Windows 7.

因为这个原因,我的整个开发机器都坏了.我如何修复machine.config或修复它并解决此问题?有谁之前经历过这个吗?

猪兔

.net iis .net-4.0 visual-studio-2010 windows-7

6
推荐指数
1
解决办法
2万
查看次数

LINQ Except()方法不起作用

我有2 IList<T>个相同类型的对象ItemsDTO.我想从另一个列表中排除一个列表.然而,这对我来说似乎没有用,我想知道为什么?

IList<ItemsDTO> related = itemsbl.GetRelatedItems();
IList<ItemsDTO> relating = itemsbl.GetRelatingItems().Except(related).ToList();
Run Code Online (Sandbox Code Playgroud)

我正在尝试relatedrelating列表中删除项目.

c# linq linq-to-objects

5
推荐指数
1
解决办法
5778
查看次数

使用 EF6 执行 UPSERT 的更有效方法

我有以下代码块,它基本上检查数据库中实体的存在并将其加载到上下文以进行更新,或者在它不存在的情况下添加新实体。

using (var db = new Entities.DB.DConn())
{
    //...
    foreach (Account account in accounts)
    {
        bool isNewRecord = false;
        Entities.DB.Account dlAccount = new Entities.DB.Account();
        Entities.DB.Account exisitngAcct = db.Accounts.Where(x => x.GId == dlG.Id).FirstOrDefault(); //x.GId is NOT ad primary key
        if (exisitngAcct != null)
        {
            dlAccount = exisitngAcct;
            isNewRecord = true;
        }

        dlAccount.GId = dlG.Id;
        dlAccount.AccountName = account.NameAtFI;
        dlAccount.AccountNumber = account.AcctNumber;
        dlAccount.AcctType = account.AcctType;
        dlAccount.AsOfDate = account.DateCreated;
        dlAccount.IsDeleted = false;
        dlAccount.DateModified = DateTime.UtcNow.ToUniversalTime();

        if (isNewRecord)
        {
            dldb.Accounts.Add(dlAccount);
        }

        db.SaveChanges();
    }
}
Run Code Online (Sandbox Code Playgroud)

我一直在对将实体附加到上下文和使用 …

c# entity-framework-6

4
推荐指数
1
解决办法
2274
查看次数

将 Xamarin.Android 应用迁移到 Xamarin.Forms 应用

我即将开始 Xamarin 项目。我一直在对最佳起点进行大量研究,我得出的结论是,我需要学习 Android 框架,并从在 Xamarin 而不是 Xamarin.Forms 中构建本机 Android 应用程序开始。

然而,展望未来,我希望成为这个应用程序的跨平台。我搜索了很多关于将 Xamarin.Android 应用程序迁移到 Xamarin.Forms 应用程序需要什么的信息,以便我可以为我的项目构建 iOS 应用程序。

有没有人有任何关于这个过程是容易还是难做的信息?你可以将 Xamarin.Android 应用程序迁移到 Xamarin.Forms 项目吗?如果不是,方法是在 Xamarin.Forms 项目下重建应用程序吗?有没有简单的方法来解决这个问题?

任何有关这方面的信息将不胜感激。

xamarin.android xamarin xamarin.forms

3
推荐指数
1
解决办法
874
查看次数

核心 API 控制器捕获所有未知路由

我有一个带有一堆现有控制器的 Core 2.2 API。我现在要做的是添加一个新的控制器,它的作用类似于一个通用路由,但仅适用于该控制器(并且不会干扰现有控制器的路由)

在我现有的控制器中,我将路由定义为控制器属性

[Route("api/[controller]")]
[ApiController]
public class SandboxController : ControllerBase
{
    [HttpGet("Hello")]
    public IEnumerable<string> Hello()
    {
        return new string[] { "Hello World", TimeZoneInfo.ConvertTimeFromUtc(DateTime.UtcNow, TimeZoneInfo.FindSystemTimeZoneById("Pacific Standard Time")).ToString()};
    }
}
Run Code Online (Sandbox Code Playgroud)

对于这个新的“catchall”控制器,我需要它能够捕获路由到它的任何 Get、Post、Put、Delete。例如,这个控制器路由是 ../ api/catchall。如果有人在哪里发帖到 ../api/catchall/ some/random/unknown/route我试图抓住这个并将其路由到 ../api/catchall/ post

到目前为止,我完全没有成功。这是我到目前为止得到的:

在我的 Startup.cs

    app.UseHttpsRedirection();
    app.UseStaticFiles();
    app.UseAuthentication();

...

    app.UseMvc(routes =>
    {
        routes.MapRoute("default", "{controller=Sandbox}/{action=Hello}/{id?}");

        routes.MapRoute(
            name: "catchall",
            template: "{controller}/{*.}", 
            defaults: new { controller = "catchall", action = "post" });
    });
Run Code Online (Sandbox Code Playgroud)

和 catchall 控制器:

[Route("api/[controller]")]
[ApiController]
public class …
Run Code Online (Sandbox Code Playgroud)

c# asp.net-web-api-routing .net-core .net-core-2.2

3
推荐指数
1
解决办法
4468
查看次数