SQL Servr 2008空间数据应用系列八:基于Bing Maps(Silverlight)的空间数据存储

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介:

 在《SQL Servr 2008空间数据应用系列七:基于Bing Maps(Silverlight) 的空间数据展现》一文中介绍了如何基于Bing Maps呈现SQL Server 2008中存储的空间数据,对于标准的地理空间数据可以通过数据导入的方式将其存放到数据库中(后续文章将详细介绍),对于一些非标准的空间数据或者说是一个软件产品中的业务空间数据,则需要通过人为或其他方式将其存储进数据库,本篇将以如何在Bing Maps(Silverlight)中动态绘制多边图形然后将其存储到SQL Server 2008的空间数据列中为例,详细介绍如何实现自定义图形存储入库的实现方式和原理。

 

一、创建空间数据表

  首先创建空间数据类型字段表,以存储在Bing Maps(Silverlight)中动态绘制的多边形图形数据到空间数据列。

CREATE   TABLE   [ dbo ] . [ DrawnPolygons ] (
    
[ ID ]   [ int ]   IDENTITY ( 1 , 1 NOT   NULL ,
    
[ Name ]   [ varchar ] ( 50 NOT   NULL ,
    
[ Polygon ]   [ geography ]   NOT   NULL )
GO

 

二、编写入库存储过程

  目前Linq To Sql和ASP.NET Entity Framework都不支持SQL Server 2008的空间数据类型,前台只能通过字符串或者对象的形式将数据传递到后台服务端,然后通过调用存储过程,在存储过程中对空间数据的字符串进行空间数据对象转换,然后入库。针对上面所创建的空间数据表可以创建如下存储过程来实现多边形空间数据的入库存储。

SET  ANSI_NULLS  ON
GO
SET  QUOTED_IDENTIFIER  ON
GO
CREATE   PROCEDURE   [ dbo ] . [ SavePolygon ]
    (
    
@name   varchar ( 50 ),
    
@polytext   varchar ( max ),
    
@identity   int  OUTPUT
    )
AS
    
INSERT   INTO     dbo.DrawnPolygons
                (Name,Polygon) 
    
VALUES         ( @name , geography::STPolyFromText( @polytext 4326 ))
    
SET   @identity   =   @@Identity
    
    
RETURN

 

三、编写服务接口

  入库接口可以采用WebService或者WCF技术提供,本篇采用WCF作为数据操作接口技术,Linq To Sql做数据访问,自定义方法调用存储过程实现数据库入库操作。

 

  在项目中添加Linq To Sql文件,然后打开对于的代码隐藏文件,在Linq To Sql自动生产的创建数据库连接的代码下面添加如下自定义方法实现数据库存储过程的调用。

[Function(Name  =   " dbo.SavePolygon " )]
public   int  SavePolygon([Parameter(DbType  =   " VarChar(50) " )]  string  name, 
                    [Parameter(DbType 
=   " VarChar(MAX) " )]  string  polygontext, 
                    [Parameter(DbType 
=   " Int " )]  ref  System.Nullable < int >  identity)
{
    IExecuteResult result 
=   this .ExecuteMethodCall( this , ((MethodInfo)(MethodInfo.GetCurrentMethod())), name, polygontext, identity);
    identity 
=  ((System.Nullable < int > )(result.GetParameterValue( 2 )));
    
return  (( int )(result.ReturnValue));
}

 

  如上实现了Linq To Sql对存储过程的调用,接下来就是创建WCF服务提供给Silverlight调用。

[ServiceContract]
public   interface  IDrawService
{
    
///   <summary>
    
///  保存多边形对象到空间数据库
    
///   </summary>
    
///   <param name="name"></param>
    
///   <param name="arrayOfLatLong"></param>
    
///   <returns></returns>
    [OperationContract]
    
int ?  SavePolygon( string  name, List < MapPoint >  arrayOfLatLong);
}

 

  在WCF服务的详细实现中将Bing Maps客户端传递过来的参数构造为空间数据类型的WKT文本格式,通过上面的存储过程就可以直接将WKT转化为空间数据类型直接入库。

public   class  DrawService : IDrawService
{
    
public   int ?  SavePolygon( string  name, List < MapPoint >  arrayOfLatLong)
    {
        var sb 
=   new  StringBuilder();
        sb.Append(
" POLYGON (( " );

        
for  (var i  =  arrayOfLatLong.Count; i  >=   1 ; i -- )
        {
            var j 
=  i  -   1 ;
            sb.Append(arrayOfLatLong[j].Longitude.ToString());
            sb.Append(
"   " );
            sb.Append(arrayOfLatLong[j].Latitude.ToString());
            sb.Append(
" , " );
        }

        sb.Remove(sb.Length 
-   1 1 );
        sb.Append(
" )) " );

        
int ?  identity  =   0 ;

        var connectionString 
=  ConfigurationManager.ConnectionStrings[ " Sql08ConnectionString " ].ConnectionString;
        BMPTSDataContext ctx 
=   new  BMPTSDataContext(connectionString);
        ctx.SavePolygon(
" 西南大区 " , sb.ToString(),  ref  identity);

        
return  identity;
    }
}

 

  接口中使用的数据传输对象MapPoint的详细定义如下代码块:

///   <summary>
///  地图坐标点(经度,纬度)
///   </summary>
[DataContract]
public   class  MapPoint
{
    [DataMember]
    
public   double  Latitude {  get set ; }
    [DataMember]
    
public   double  Longitude {  get set ; }

    
public  MapPoint() { }
    
public  MapPoint( double  lat,  double  lng)
    {
        
this .Latitude  =  lat;
        
this .Longitude  =  lng;
    }
}

 

四、Bing Maps客户端的实现

  客户端的实现非常简单,首先创建Silverlight应用程序并添加Bing Maps Silverlight Control开发组件的引用,其次在界面中添加Map对象以显示Bing Maps原型界面,最后可以设计一个小的工具面板,以按钮的方式驱动触发绘制多边形的行为,以及保存图形到数据库的命令请求。如下界面效果:  

        

 

  对于绘制多边形的算法这里鉴于篇幅限制就不一一贴出来了,详细可通过文末提供的代码下载链接下载本文的示例代码。比如限制绘制一个【成都-重庆-贵阳-昆明】这四个城市组成的西南大区多变型图形,并将其图形数据以空间数据的形式存储到SQL Server 2008中。图形如下图所示:

        

 

  通过点击“保存数据”按钮则将地图界面绘制的图形数据取出来构造为数组传递到WCF服务接口,调用数据库存储过程实现数据入库操作,下面是保存按钮的代码实现。

private   void  btnSave_Click( object  sender, RoutedEventArgs e)
{
    LocationCollection lc 
=   this ._drawLine.Locations;

    ObservableCollection
< MapPoint >  polygon  =   new  ObservableCollection < MapPoint > ();
    
for  ( int  i  =   0 ; i  <  lc.Count; i ++ )
    {
        polygon.Add(
new  MapPoint { Longitude  =  lc[i].Longitude, Latitude  =  lc[i].Latitude });
    }

    
// 调用WCF接口实现数据入库
    DrawServiceClient client  =   new  DrawServiceClient();
    client.SavePolygonAsync(
this .tbName.Text.Trim(), polygon);
    client.SavePolygonCompleted 
+=  client_SavePolygonCompleted;
}

private   void  client_SavePolygonCompleted( object  sender, SavePolygonCompletedEventArgs e)
{
    
if  (e.Error  !=   null )
    {
        
this .tbResult.Text  =  e.Result.Value  >   0   ?   " 保存成功! "  :  " 保存失败 " ;
    }
}

 

五、数据库中的空间数据

  当通过Bing Maps中动态绘制多边形图形对象,然后将图形数据通过WCF服务接口入库保存后,可以通过SQL Server Management Studio查询并在空间数据结果中直接预览结果。

SELECT   [ ID ] , [ Name ] , [ Polygon ]   FROM   [ dbo ] . [ DrawnPolygons ]

 





本文转自 beniao 51CTO博客,原文链接:http://blog.51cto.com/beniao/522339,如需转载请自行联系原作者

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
3月前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
115 4
|
4月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
4月前
|
SQL 存储 关系型数据库
mysql 数据库空间统计sql
mysql 数据库空间统计sql
63 0
|
4月前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录
|
4月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
4月前
|
SQL 监控 数据处理
SQL数据库数据修改操作详解
数据库是现代信息系统的重要组成部分,其中SQL(StructuredQueryLanguage)是管理和处理数据库的重要工具之一。在日常的业务运营过程中,数据的准确性和及时性对企业来说至关重要,这就需要掌握如何在数据库中正确地进行数据修改操作。本文将详细介绍在SQL数据库中如何修改数据,帮助读者更好
787 4
|
4月前
|
SQL 分布式计算 关系型数据库
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
165 0
|
4月前
|
SQL 分布式计算 关系型数据库
Hadoop-23 Sqoop 数据MySQL到HDFS(部分) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-23 Sqoop 数据MySQL到HDFS(部分) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
71 0
|
4月前
|
SQL 分布式计算 关系型数据库
Hadoop-22 Sqoop 数据MySQL到HDFS(全量) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-22 Sqoop 数据MySQL到HDFS(全量) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
93 0
|
4月前
|
SQL
使用SQL进行集合查询和数据维护
使用SQL进行集合查询和数据维护
63 0