12

我发现在 SQL Server 中存储 lat 和 long 的最佳类型是十进制 (9,6) (参考。在 SQL 数据库中存储纬度和经度数据时使用什么数据类型?)所以我做了

AddColumn("dbo.Table", "Latitude", c => c.Decimal(nullable: false, precision: 9, scale: 6));
AddColumn("dbo.Table", "Longitude", c => c.Decimal(nullable: false, precision: 9, scale: 6));

SQL 似乎没问题,一切正常,但是当我插入/更新一个值时,即

lat = 44.5912853

它是这样保存的:

44.590000

我检查了流程,就在更新之前,我的实体包含正确的值,所以我认为与我的代码无关,而是与 EF / SQL 所做的某个回合有关。你有什么想法可以避免这种情况吗?

更新

update [dbo].[Breweries]
set [RankId] = @0, 
[Name] = @1, 
[Foundation] = null, 
[DirectSale] = @2, 
[OnlineSale] = @3, 
[StreetAddress] = @4, 
[StreetAddress1] = null, 
[ZIP] = @5, 
[City] = @6, 
[Province] = @7, 
[CountryCode] = @8, 
[Latitude] = @9, 
[Longitude] = @10, 
[PIVA] = null, 
[CodFiscale] = null
where ([BreweryId] = @11)

在此处输入图像描述

POCO 实体

[Table("Breweries")]
public class Brewery : ABrewery 
{
  ....
  public decimal Latitude { get; set; }
  public decimal Longitude { get; set; }
}

SQL 探查器

exec sp_executesql N'update [dbo].[Breweries]
set [RankId] = @0, [Name] = @1, [Foundation] = null, [DirectSale] = @2, [OnlineSale] = @3, [StreetAddress] = @4, [StreetAddress1] = null, [ZIP] = @5, [City] = @6, [Province] = @7, [CountryCode] = @8, [Latitude] = @9, [Longitude] = @10, [PIVA] = null, [CodFiscale] = null
where ([BreweryId] = @11)
',N'@0 int,@1 nvarchar(128),@2 bit,@3 bit,@4 nvarchar(256),@5 varchar(16),@6 nvarchar(64),@7 nvarchar(64),@8 nvarchar(128),@9 decimal(18,2),@10 decimal(18,2),@11 int',@0=2,@1=N'Davide',@2=0,@3=0,@4=N'Via Moscardini, 24',@5='zip',@6=N'city',@7=N'province',@8=N'ITA',

@9=44.59,@10=11.05,@11=2

谢谢

4

4 回答 4

8

显然这个家伙有完全相同的问题并因此解决了它:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Entity<Activity>().Property(a => a.Latitude).HasPrecision(18, 9);
    modelBuilder.Entity<Activity>().Property(a => a.Longitude).HasPrecision(18, 9);
}

尽管您可能希望查看在 SQL Server 2008 及更高版本中使用空间数据类型(尤其是)。geography

于 2013-02-23T11:39:04.627 回答
4

您可以使用DbGeography类型来存储纬度和经度。

using System.Data.Entity.Spatial;

public class Test
{
    public DbGeography Location { get; set; }
}
于 2016-09-03T22:20:16.443 回答
1

两件事情:

  1. 我刚刚购买了一个邮政编码数据库,它将所有纬度和经度值存储为十进制(12,6)数据类型。我不认为这会从根本上改变你的结果。

  2. 我会检查发送到您的 SQL Server 的确切 SQL。然后,您可以检查四舍五入的位置。您可以通过从 EF 获取输出或使用 SQL Profiler 来检查正在发送的 SQL。我的猜测是它发生在您的 C# 代码中。

此外,查看表架构和域实体可能很有用。

于 2013-02-23T11:22:58.800 回答
0

使用这些字段的数据类型为 Float:

 Latitude float,
 Longitude float
于 2013-02-23T11:32:32.353 回答