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
目录
相关文章
|
23天前
|
SQL 数据库
如何应用SQL约束条件?
【10月更文挑战第28天】如何应用SQL约束条件?
40 11
|
1月前
|
SQL Oracle 关系型数据库
SQL语言的主要标准及其应用技巧
SQL(Structured Query Language)是数据库领域的标准语言,广泛应用于各种数据库管理系统(DBMS)中,如MySQL、Oracle、SQL Server等
|
15天前
|
SQL 监控 安全
员工上网行为监控软件:SQL 在数据查询监控中的应用解析
在数字化办公环境中,员工上网行为监控软件对企业网络安全和管理至关重要。通过 SQL 查询和分析数据库中的数据,企业可以精准了解员工的上网行为,包括基础查询、复杂条件查询、数据统计与分析等,从而提高网络管理和安全防护的效率。
26 0
|
1月前
|
SQL 数据库 索引
内连接(INNER JOIN)在SQL中的简单应用与技巧
在SQL查询中,内连接(INNER JOIN)是一种基本且常用的连接类型,用于从两个或多个表中检索匹配的记录
|
2月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
4月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
115 13
|
4月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
|
4月前
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
63 6
|
4月前
|
存储 SQL C++
对比 SQL Server中的VARCHAR(max) 与VARCHAR(n) 数据类型
【7月更文挑战7天】SQL Server 中的 VARCHAR(max) vs VARCHAR(n): - VARCHAR(n) 存储最多 n 个字符(1-8000),适合短文本。 - VARCHAR(max) 可存储约 21 亿个字符,适合大量文本。 - VARCHAR(n) 在处理小数据时性能更好,空间固定。 - VARCHAR(max) 对于大文本更合适,但可能影响性能。 - 选择取决于数据长度预期和业务需求。
390 1
|
3月前
|
SQL 安全 Java
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
501 0

热门文章

最新文章

下一篇
无影云桌面