MySql中管理百万级要注意些什么东西

转http://hi.baidu.com/leilumail/blog/item/4910f32a170d0a28d52af127.html

以MapXtreme为例说明图片切割算法:

1、定义地图范围、地图视野、输出图片大小。所要切割的地图范围。

   int x1 = int.Parse(txtX1.Text);     int x2 = int.Parse(txtX2.Text);     int y1 = int.Parse(txtY1.Text);     int y2 = int.Parse(txtY2.Text);

   double startzoom = System.Convert.ToDouble(txtStartZoom.Text);

   int mapWidth = int.Parse(txtWidth.Text);     int mapHeight = int.Parse(txtHeight.Text);

2、设置地图视野。

   map.Zoom = new MapInfo.Geometry.Distance(startzoom ,MapInfo.Geometry.DistanceUnit.Mile);

3、计算输出图片的边长对应的地理长度。

    MapInfo.Geometry.DRect rect = map.Bounds;      double dx = rect.x2 - rect.x1;      double dy = rect.y2 - rect.y1;

4、循环输出当前视野下的地图图片。

   MapInfo.Mapping.MapExport mapExport = new MapInfo.Mapping.MapExport(map); 

    double tmpy = y1;      int row = 0;      while (tmpy < y2)      {       row ++;       double tmpx = x1;       int col = 0;       while(tmpx < x2)       {        col ++;        rect = new MapInfo.Geometry.DRect(tmpx,tmpy,tmpx+dx,tmpy+dy);        map.SetView(rect,map.GetDisplayCoordSys());        MakePic(mapExport,row,col);        tmpx += dx;       }       tmpy += dy;      }

5、MakePic是地图输出函数。

   int mapWidth = int.Parse(txtWidth.Text);     int mapHeight = int.Parse(txtHeight.Text);     mapExport.ExportSize = new MapInfo.Mapping.ExportSize(mapWidth, mapHeight);     mapExport.Format = MapInfo.Mapping.ExportFormat.Png;     mapExport.Border = MapInfo.Mapping.ExportBorder.Off;     if(!System.IO.Directory.Exists(txtPicPath.Text + @"/map"))     {      System.IO.Directory.CreateDirectory(txtPicPath.Text + @"/map" );     }     string filename = txtPicPath.Text + @"/map/" + row.ToString() + "-" + col.ToString() + ".PNG";     mapExport.Export(filename);

你可能感兴趣的:(mysql,算法,String)