hsqldb实例代码 博客分类: 数据库 hsqldbjava嵌入式数据库
package com.dmmap.adaptor.dao;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.hsqldb.server.Server;
/**
* 便利单机法度应用HSQL的对象类,包含启动,封闭,连接。数据库默认不加密,用户为sa 密码空
*/
public class HsqlUtil {
public static final int PORT = 9002;
public static final String DB_NAME = "adaptor"; //数据库文件名,同时也是本类中的数据库名
public static final String DB_PATH = "./WebContent/database/";
public static final String USER_NAME = "sa";
public static final String PASSWORD = "";
public static final int SERVER_MODE = 0;
public static final int STAND_ALONE_MODE = 1; //In-Process
public static int mode = SERVER_MODE; //记录当前用什么模式,开辟时用Server,公布时用standalone
/**
* 启动数据库办事
*/
public static boolean startHSQL() {
if (mode == SERVER_MODE) {
Server server = new Server();//它可是hsqldb.jar里面的类啊。
server.setDatabaseName(0, DB_NAME);
server.setDatabasePath(0, DB_PATH + DB_NAME);
server.setPort(PORT);
server.setSilent(true);
server.start(); //主动多线程运行
System.out.println("hsqldb started...");
} else if (mode == STAND_ALONE_MODE) {
//standalone模式,打开连接就同时启动数据库,所以这里可以什么都不做
}
try {
Thread.sleep(800); // 守候Server启动
} catch (InterruptedException e) {
}
return true;
}
/**
* 封闭数据库办事
*/
public static boolean stopHSQL() {
try {
Statement statement = getConnection().createStatement();
statement.executeUpdate("SHUTDOWN;");
return true;
} catch (SQLException ex) {
Logger.getLogger(HsqlUtil.class.getName()).log(Level.SEVERE, null, ex);
return false;
}
}
/**
* 获取连接
*/
public static Connection getConnection() {
Connection conn = null;
try {
Class.forName("org.hsqldb.jdbcDriver");
if (mode == SERVER_MODE) {
conn = DriverManager.getConnection("jdbc:hsqldb:hsql://localhost:" + PORT + "/" + DB_NAME, USER_NAME, PASSWORD);
} else if (mode == STAND_ALONE_MODE) {
conn = DriverManager.getConnection("jdbc:hsqldb:file:" + DB_PATH + DB_NAME, USER_NAME, PASSWORD);
System.out.println(DB_PATH+DB_NAME);
}
} catch (ClassNotFoundException ex) {
Logger.getLogger(HsqlUtil.class.getName()).log(Level.SEVERE, null, ex);
} catch (SQLException ex) {
Logger.getLogger(HsqlUtil.class.getName()).log(Level.SEVERE, null, ex);
}
return conn;
}
}
//public static List<SMS> getSMS()
//{
// List<SMS> list=new ArrayList<SMS>();
// HsqlUtil.mode = HsqlUtil.STAND_ALONE_MODE;
// HsqlUtil.startHSQL();
// Connection conn = HsqlUtil.getConnection();
// try {
// Statement statement =conn.createStatement();
// ResultSet rs=statement.executeQuery("select * from record");
// while(rs.next())
// {
// SMS sms=new SMS();
// sms.setId(rs.getString(1));
// sms.setMobliePhone(rs.getString(2));
// sms.setContnet(rs.getString(3));
// sms.setTime(rs.getString(4));
// list.add(sms);
// }
// statement.close();
// } catch (SQLException ex) {
// Logger.getLogger(HsqlUtil.class.getName()).log(Level.SEVERE, null, ex);
// }
// HsqlUtil.stopHSQL();
// return list;
//}
//public static void initDB()
//{
// HsqlUtil.mode = HsqlUtil.STAND_ALONE_MODE;
// HsqlUtil.startHSQL();
// Connection conn = HsqlUtil.getConnection();
// try {
// Statement statement =conn.createStatement();
// statement.executeUpdate("create table record(id varchar(64) not null primary key ," +
// "mobliePhone varchar(20),contnet varchar(20),time varchar(20))");
// statement.close();
// } catch (SQLException ex) {
// Logger.getLogger(HsqlUtil.class.getName()).log(Level.SEVERE, null, ex);
// }
// HsqlUtil.stopHSQL();
//}
//public static void dropDB()
//{
// HsqlUtil.mode = HsqlUtil.STAND_ALONE_MODE;
// HsqlUtil.startHSQL();
// Connection conn = HsqlUtil.getConnection();
// try {
// Statement statement =conn.createStatement();
// statement.executeUpdate("drop table record");
// statement.close();
// } catch (SQLException ex) {
// Logger.getLogger(HsqlUtil.class.getName()).log(Level.SEVERE, null, ex);
// }
// HsqlUtil.stopHSQL();
//}
上一篇: Derby中修改字段长度 Derby
下一篇: Java输入流与输出流
推荐阅读
-
hsqldb实例代码 博客分类: 数据库 hsqldbjava嵌入式数据库
-
H2嵌入式数据学习三步曲 博客分类: h2db嵌入式数据库 h2db嵌入式数据库
-
图形数据库--neo4j分享(嵌入式数据库) 博客分类: 数据库sql + nosql 图形数据库数据库neo4j嵌入式数据库
-
如何将HSQLDB数据库传输到客户端? 博客分类: iBatis HSQLDB
-
用NPOI把数据库内容导入到Excel中实例(NPOI版本2.0) 博客分类: asp.net开发
-
完整java开发中JDBC连接数据库代码和步骤 博客分类: JDBC jdbc
-
java: SQLite使用实例 博客分类: 7.数据库 javadbsqlitesqlite管理工具
-
数据库数据导入到excel,源代码 博客分类: java 数据库excel源代码
-
基于数据库的代码自动生成工具,生成JavaBean、生成数据库文档、生成前后端代码等(v6.9.0版) 博客分类: TableGo java数据库自动生成代码零代码编程软件框架
-
C++ 对象关系映射(ORM)介绍 博客分类: C/C++ C++ORM框架自动生成代码数据库