【移动GIS】sqlite的使用(二)

前端之家收集整理的这篇文章主要介绍了【移动GIS】sqlite的使用(二)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

利用sqlite存储瓦片那是最好不过了,做离线地图的时候,你拷那么多图片慢不?累不?

MBTiles是利用sqlite并有一种规则来存储瓦片的,什么是MBTiles?请参照我的博客; 【移动GIS】MBTiles移动存储简介这里就不在獒述了。

MBTiles其实就是一个sqlite数据库,但这个数据库按照了一些规则创建了表来存储瓦片信息,所以把它叫做MBTiles,sqlite生成的数据文件的后缀名其实是可以随便改变的哦,不影响你使用的,一般sqlite数据库文件问 .sqlite或者 .db ,然后存储瓦片呢,我们生成数据库文件的时候就把他生成为 .mbtiles格式

在android移动存储过程中,不需要你再额外的加sqlite的JDBC啦,貌似android SDK就支持sqlite,那么如何将瓦片导入到sqlite数据库中呢?没办法,只能自己写个程序然后遍历本地瓦片再依次插入到sqlite中去了,下面贴出插入瓦片的关键代码

package com.ehl.sqlite;

import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.sqlException;
import java.sql.Statement;
/**
 * sqlite数据操作
 * 
 * @author fazhen.zheng
 *
 */
public class sqliteDB {
	private static Statement statement;
	private static Connection connection  = null;
	private static PreparedStatement insertPS = null;
	private static PreparedStatement deletePS = null;
	public sqliteDB(String mbtilesPath) throws ClassNotFoundException,sqlException{
		Class.forName("org.sqlite.JDBC");
		if(mbtilesPath==null||mbtilesPath.trim().length()==0){
			connection = DriverManager
					.getConnection("jdbc:sqlite:ehl_mbtiles_db.mbtiles");
			statement = connection.createStatement();
			initTable();
		}else{
			connection =  DriverManager.getConnection("jdbc:sqlite:" + mbtilesPath);
			statement = connection.createStatement();
		}
		insertPS = connection.prepareStatement("INSERT INTO tiles (zoom_level,tile_row,tile_column,tile_data) VALUES(?,?,?)");
		deletePS = connection.prepareStatement("DELETE FROM tiles WHERE zoom_level = ? and tile_row = ? and tile_column = ?");
	}
	/**
	 * 初始化表信息
	 * @throws sqlException
	 */
	private void initTable() throws sqlException{
		statement.execute("DROP TABLE IF EXISTS  Metadata");
		statement.execute("DROP TABLE IF EXISTS  tiles");
		
		statement.execute("CREATE TABLE Metadata (name text,value text)");
		statement.execute("CREATE TABLE tiles (zoom_level integer,tile_row integer,tile_column integer,tile_data blob)");

		statement.execute("CREATE UNIQUE INDEX tile_index ON tiles (zoom_level,tile_column)");
		statement.execute("CREATE UNIQUE INDEX name ON Metadata (name)"); 

		statement.execute("INSERT INTO Metadata VALUES ('name','ehl_mbtiles_db')");
		statement.execute("INSERT INTO Metadata VALUES ('type','baselayer')");
		statement.execute("INSERT INTO Metadata VALUES ('version','1.0')");
		statement.execute("INSERT INTO Metadata VALUES ('description','移动GIS')");
		statement.execute("INSERT INTO Metadata VALUES ('format','png')");
	}
	/**
	 * 插入一条数据
	 * @param zoom_level
	 * @param tile_row
	 * @param tile_column
	 * @param tile_data
	 */
	public void insertTiles(String zoom_level,String tile_row,String tile_column,File tile_data) {
		FileInputStream fis;
		ByteArrayOutputStream bos = null;
		try {
			connection.setAutoCommit(false);
			fis = new FileInputStream(tile_data);
			bos = new ByteArrayOutputStream();
			byte[] buf = new byte[1024];
			int readNum;
			while ((readNum = fis.read(buf)) != -1) {
				bos.write(buf,readNum);
			}
			insertPS.setString(1,zoom_level);
			insertPS.setString(2,tile_row);
			insertPS.setString(3,tile_column);
			insertPS.setBytes(4,bos.toByteArray());
			deletePS.setString(1,zoom_level);
			deletePS.setString(2,tile_row);
			deletePS.setString(3,tile_column);

			deletePS.executeUpdate();
			insertPS.executeUpdate();
			connection.commit();
		} catch (Exception e) {
			try {
				connection.rollback();
			} catch (sqlException e1) {
				e1.printStackTrace();
			}
			e.printStackTrace();
		} 
	}
	/**
	 * 使用完毕后需关闭一些对象
	 */
	public void close() {
		try {
			if (insertPS != null)
				insertPS.close();
			if (deletePS != null)
				deletePS.close();
			if(statement!=null)
				statement.close();
			if (connection != null)
				connection.close();
		} catch (sqlException e) {
			System.err.println(e);
		}
	}

}

猜你在找的Sqlite相关文章