|
sqlite是一个轻量的数据库,轻量到所有数据存放到一个.db文件,如果你要备份和转移整个数据库只需要复制这个文件就可以了,最近想自己开发一个记录个人情况的小系统方便在家里和公司同步数据。选择了sqlite,sqlite可以说麻雀虽小五脏俱全,符合sql标准,一些小型系统或者演示系统都有人在使用了。sqlite的详细介绍可以参看“SQLite数据库扫盲”http://www.sqlite.com.cn/MySqlite/6/522.Html
sqlite官方网址http://www.sqlite.org/
可google搜索Sqlite管理工具.rar,我使用的是sqliteadmin
下面开始创建一个java创建并访问sqlite的示例:
1.用eclipse新建一个java工程
2.下载sqlite的jdbc包http://www.zentus.com/sqlitejdbc/
我当时下载的是当时最新的sqlitejdbc-v056.jar
3.将jar包放到工程的buildpath中
4.java类
import java.sql.*;
//import org.sqlite.JDBC;
/**
* 这是个非常简单的SQLite的Java程序,
* 程序中创建数据库、创建表、然后插入数据,
* 最后读出数据显示出来
* @author licoolxue (http://licoolxue.iyunv.com/)
*/
public class TestSQLite {
public static void main(String[] args)
{
try
{
//连接SQLite的JDBC
Class.forName("org.sqlite.JDBC");
//建立一个数据库名employees.db的连接,如果不存在就在当前目录下创建之
Connection conn = DriverManager.getConnection("jdbc:sqlite:db/employees.db");
Statement statement = conn.createStatement();
ResultSet rsExist = statement.executeQuery("SELECT * FROM sqlite_master where type='table' and name ='employee';"); //查询employee表是否存在
if(!rsExist.next())
{
statement.executeUpdate( "create table employee(name varchar(20), salary int);" );//创建一个表,两列
statement.executeUpdate( "insert into employee values('张三',8000);" ); //插入数据
statement.executeUpdate( "insert into employee values('李四',7800);" );
statement.executeUpdate( "insert into employee values('王五',5800);" );
statement.executeUpdate( "insert into employee values('赵六',9100);" );
}
ResultSet rs = statement.executeQuery("select * from employee;"); //查询数据
while (rs.next()) { //将查询到的数据打印出来
System.out.print("name = " + rs.getString("name") + " "); //列属性一
System.out.println("salary = " + rs.getString("salary")); //列属性二
}
rs.close();
statement.close();
conn.close(); //结束数据库的连接
}
catch( Exception e )
{
e.printStackTrace ( );
}
}
}
sqliteadmin不支持utf编码,中文会显示乱码,可以使用另一个管理工具
http://licoolxue.iyunv.com/blog/1536201
相关工程代码见附件。
参考文档:
Java连接SQLite数据库详解http://blog.iyunv.com/space.php?uid=20384806&do=blog&id=1954139
java编写最简单的sqlite程序http://marshal.easymorse.com/archives/2399
sqlite数据库判断表是否存在得方法http://www.cppblog.com/woaidongmao/archive/2009/06/23/88353.aspx
本文原创,请尊重他人劳动成果,转载注明出处http://licoolxue.iyunv.com |
|
|