java sqlite util 工具类,测试类

准备工作:下载sqlite-jdbc的jar包

可以从maven 仓库下载:

https://mvnrepository.com/artifact/org.xerial/sqlite-jdbc/3.19.3

java操作sqlite数据库简单的工具类:

import java.lang.reflect.Method;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Component;

@Component
public class SqliteUtil {

	private static final String CLASS_NAME = "org.sqlite.JDBC";
	private static final String DB_URL_PREFIX = "jdbc:sqlite:d:/sqlite/";

	/**
	 * 获取数据库连接
	 * 
	 * @param dbname
	 *            数据库名称
	 * @return conn
	 * @throws ClassNotFoundException
	 */
	public static Connection getConnection(String dbname) throws SQLException, ClassNotFoundException {
		if (StringUtils.isBlank(dbname)) {
			return null;
		}
		Class.forName(CLASS_NAME);
		if (!dbname.endsWith(".db")) {
			dbname = dbname + ".db";
		}
		return DriverManager.getConnection(DB_URL_PREFIX + dbname);
	}

	/**
	 * 获取一个数据连接声明
	 * 
	 * @param conn
	 *            数据库连接
	 * @return statement
	 * @throws SQLException
	 */
	private Statement getStatement(Connection conn) throws SQLException {
		if (null == conn) {
			return null;
		}
		return conn.createStatement();
	}

	/**
	 * 根据数据库名称获取数据库连接声明
	 * 
	 * @param dbname
	 *            数据库名称
	 * @return statement
	 * @throws SQLException
	 * @throws ClassNotFoundException
	 */
	public Statement getStatementByDBName(String dbname) throws SQLException, ClassNotFoundException {
		if (StringUtils.isBlank(dbname)) {
			return null;
		}
		return getStatement(getConnection(dbname));
	}

	/**
	 * 创建sqlite数据库
	 * 
	 * @param dbname
	 *            数据库名称
	 * @return 0:失败;1:成功
	 * @throws SQLException
	 * @throws ClassNotFoundException
	 */
	public int createDatabase(String dbname) throws ClassNotFoundException, SQLException {
		Statement statement = getStatementByDBName(dbname);
		if (null != statement) {
			return 1;
		}
		return 0;
	}

	/**
	 * 关闭声明
	 * 
	 * @param statement
	 * @throws SQLException
	 */
	public static void closeStatement(Statement statement) throws SQLException {
		if (null != statement && !statement.isClosed()) {
			Connection conn = statement.getConnection();
			statement.close();
			closeConnection(conn);
		}
	}

	/**
	 * 关闭声明
	 * 
	 * @param statement
	 * @throws SQLException
	 */
	public static void closeConnection(Connection conn) throws SQLException {
		if (null != conn && !conn.isClosed()) {
			conn.close();
		}
	}

	/**
	 * 创建数据库表
	 * 
	 * @param dbname
	 *            数据库名称
	 * @param sql
	 *            创建语句
	 * @return 0:创建失败;1:创建成功
	 * @throws ClassNotFoundException
	 * @throws SQLException
	 */
	public int createTables(String dbname, String sql) throws ClassNotFoundException, SQLException {
		if (StringUtils.isBlank(sql)) {
			return 0;
		}
		Statement statement = getStatementByDBName(dbname);
		if (null != statement) {
			try {

				statement.executeUpdate(sql);

			} catch (Exception e) {

				System.err.println(e.getMessage());

			} finally {

				closeStatement(statement);

			}

			return 1;
		}
		return 0;
	}

	/**
	 * 插入数据
	 * 
	 * @param dbname
	 *            数据库名称
	 * @param sql
	 *            insert语句
	 * @return 0:插入失败;1:插入成功
	 * @throws ClassNotFoundException
	 * @throws SQLException
	 */
	public int insert(String dbname, String sql) throws ClassNotFoundException, SQLException {
		if (StringUtils.isBlank(sql)) {
			return 0;
		}
		Statement statement = getStatementByDBName(dbname);
		if (null != statement) {
			statement.executeUpdate(sql);
			closeStatement(statement);
			return 1;
		}
		return 0;
	}

	/**
	 * 修改数据
	 * 
	 * @param dbname
	 *            数据库名称
	 * @param sql
	 *            update语句
	 * @return 0:插入失败;1:插入成功
	 * @throws ClassNotFoundException
	 * @throws SQLException
	 */
	public int update(String dbname, String sql) throws ClassNotFoundException, SQLException {
		if (StringUtils.isBlank(sql)) {
			return 0;
		}
		Statement statement = getStatementByDBName(dbname);
		if (null != statement) {
			statement.executeUpdate(sql);
			closeStatement(statement);
			return 1;
		}
		return 0;
	}

	/**
	 * 批量插入数据
	 * 
	 * @param dbname
	 *            数据库名称
	 * @param sql
	 *            insert语句
	 * @return 0:插入失败;1:插入成功
	 * @throws ClassNotFoundException
	 * @throws SQLException
	 */
	public int insertBatch(String dbname, List<String> sqls) throws ClassNotFoundException, SQLException {
		if (null == sqls || sqls.isEmpty()) {
			return 0;
		}
		Connection conn = getConnection(dbname);

		if (null == conn) {
			return 0;
		}

		conn.setAutoCommit(false);
		Statement statement = getStatement(conn);

		if (null == statement) {
			closeConnection(conn);
			return 0;
		}

		for (String sql : sqls) {
			if (StringUtils.isNotBlank(sql)) {
				statement.executeUpdate(sql);
			}
		}
		closeStatement(statement);
		conn.commit();
		closeConnection(conn);
		return 1;
	}

	/**
	 * 更新和删除
	 * 
	 * @param dbname
	 *            数据库名称
	 * @param sql
	 * @param parameters
	 * @return
	 * @throws SQLException
	 * @throws ClassNotFoundException
	 */
	public static int update(String dbname, String sql, Object[] parameters)
			throws ClassNotFoundException, SQLException {
		return execute(dbname, sql, parameters, 0);
	}

	/**
	 * 添加
	 * 
	 * @param dbname
	 *            数据库名称
	 * @param sql
	 * @param parameters
	 * @return
	 * @throws SQLException
	 * @throws ClassNotFoundException
	 */
	public static int insert(String dbname, String sql, Object[] parameters)
			throws ClassNotFoundException, SQLException {
		return execute(dbname, sql, parameters, 1);
	}

	/**
	 * 执行增删改
	 * 
	 * @param dbname
	 *            数据库名称
	 * @param sql
	 * @param parameters
	 * @param type
	 *            0为删改,1为增加
	 * @return
	 * @throws SQLException
	 * @throws ClassNotFoundException
	 */
	private static int execute(String dbname, String sql, Object[] parameters, int type)
			throws SQLException, ClassNotFoundException {
		Connection conn = getConnection(dbname);
		PreparedStatement ps = null;
		int count = 0;
		if (conn != null) {
			try {

				ps = conn.prepareStatement(sql);
				if (null == ps) {
					closeConnection(conn);
					return count;
				}
				for (int i = type + 1; i <= parameters.length + type; i++) {
					ps.setObject(i, parameters[i - (1 + type)]);
				}
				count = ps.executeUpdate();
			} catch (Exception e) {
				System.err.println(e.getMessage());
			} finally {
				closeStatement(ps);
			}
		}
		return count;
	}

	/**
	 * 执行查询,并将值反射到bean
	 * 
	 * @param sql
	 * @param parameters
	 * @param clazz
	 * @return
	 * @throws SQLException
	 * @throws ClassNotFoundException
	 */
	public static <T> List<T> select(String dbname, String sql, Object[] parameters, Class<T> clazz)
			throws ClassNotFoundException, SQLException {
		List<T> list = new ArrayList<T>();
		Connection conn = getConnection(dbname);
		if (null == conn) {
			return null;
		}
		PreparedStatement ps = null;
		ResultSet rs = null;
		ps = conn.prepareStatement(sql);
		if (parameters != null && ps != null) {

			try {
				for (int i = 1; i <= parameters.length; i++) {
					ps.setObject(i, parameters[i - 1]);
				}
				// 执行查询方法
				rs = ps.executeQuery();
				ResultSetMetaData rsmd = rs.getMetaData();
				List<String> columnList = new ArrayList<String>();
				for (int i = 0; i < rsmd.getColumnCount(); i++) {
					columnList.add(rsmd.getColumnName(i + 1));
				}
				// 循环遍历记录
				while (rs.next()) {
					// 创建封装记录的对象
					T obj = clazz.newInstance();
					// 遍历一个记录中的所有列
					for (int i = 0; i < columnList.size(); i++) {
						// 获取列名
						String column = columnList.get(i);
						// 根据列名创建set方法
						String setMethd = "set" + column.substring(0, 1).toUpperCase() + column.substring(1);
						// 获取clazz中所有方法对应的Method对象
						Method[] ms = clazz.getMethods();
						// 循环遍历ms
						for (int j = 0; j < ms.length; j++) {
							// 获取每一个method对象
							Method m = ms[j];
							// 判断m中对应的方法名和数据库中列名创建的set方法名是否形同
							if (m.getName().equals(setMethd)) {
								// 反调set方法封装数据
								m.invoke(obj, rs.getObject(column));// 获取rs中对应的值,封装到obj中
								break; // 提高效率
							}
						}
					}
					list.add(obj);
				}

			} catch (Exception e) {
				System.err.println(e.getMessage());
			} finally {
				closeStatement(ps);
			}
		} else {
			closeConnection(conn);
		}
		return list;
	}

	/**
	 * 执行查询,并将值反射到map
	 * 
	 * @param sql
	 * @param parameters
	 * @return
	 * @throws SQLException
	 * @throws ClassNotFoundException
	 */
	public static List<Map<String, Object>> select(String dbname, String sql, Object[] parameters)
			throws ClassNotFoundException, SQLException {
		List<Map<String, Object>> list = new ArrayList<>();
		Connection conn = getConnection(dbname);
		if (null == conn) {
			return null;
		}
		PreparedStatement ps = null;
		ResultSet rs = null;
		ps = conn.prepareStatement(sql);
		if (ps != null) {

			try {
				if (parameters != null) {
					for (int i = 1; i <= parameters.length; i++) {
						ps.setObject(i, parameters[i - 1]);
					}
				}
				// 执行查询方法
				rs = ps.executeQuery();
				ResultSetMetaData rsmd = rs.getMetaData();
				List<String> columnList = new ArrayList<String>();
				for (int i = 0; i < rsmd.getColumnCount(); i++) {
					columnList.add(rsmd.getColumnName(i + 1));
				}
				// 循环遍历记录
				while (rs.next()) {
					Map<String, Object> obj = new HashMap<>();
					// 遍历一个记录中的所有列
					for (int i = 0; i < columnList.size(); i++) {
						// 获取列名
						String column = columnList.get(i);
						obj.put(column, rs.getObject(column));
					}
					list.add(obj);
				}

			} catch (Exception e) {
				System.err.println(e.getMessage());
			} finally {
				closeStatement(ps);
			}
		} else {
			closeConnection(conn);
		}
		return list;
	}
}

sqlite 测试类


import java.io.IOException;
import java.sql.SQLException;

public class Test {

	public static void main(String[] args) throws ClassNotFoundException, SQLException {
		SqliteUtil sqlite = new SqliteUtil();

		String sql = "";

		// 创建表
		sql = "CREATE TABLE COMPANY " + "(ID INT PRIMARY KEY     NOT NULL," + " NAME           TEXT    NOT NULL, "
				+ " AGE            INT     NOT NULL, " + " ADDRESS        CHAR(50), " + " SALARY         REAL)";

		//sqlite.createTables("hahaha", sql);

		// 插入数据
		sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) " + "VALUES (1, 'Paul', 32, 'California', 20000.00 );";

		//sqlite.insert("hahaha", sql);

		// 修改数据
		sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1;";

		// sqlite.update("hahaha", sql);

		// 查询数据
		sql = "SELECT * FROM COMPANY;";
		// sqlite.select("hahaha", sql, null);

	}
}

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Qt提供了一批SQLite工具类,允许我们使用SQLite数据库。这些工具类可以方便我们完成SQLite数据库的操作,其功能包括SQLite数据库的创建和删除、表的创建和删除、向表中插入数据、查询和更新数据等。 Qt提供了许多与SQLite相关的类,其中包括QSqlDatabase、 QSqlQuery、QSqlTableModel和QSqlRecord等。其中,使用QSqlDatabase可以连接到SQLite数据库,并创建、打开、关闭和删除数据库。而使用QSqlQuery类,我们可以执行SQL语句,例如插入、删除、更新和查询等,还可以调用其API来获取结果中的数据。 另外,QSqlTableModel类允许我们使用Qt的Model/View框架来管理数据库表,与之相关的还有QSqlRecord类,我们可以使用这个类来处理行中的数据。这种方式使得操作数据表变得十分方便,还能自动完成表中数据的排序和过滤等操作。 总之,Qt提供的SQLite工具类在使用SQLite数据库进行开发时非常有用。通过这些工具类,我们可以方便地管理SQLite数据库和表,完成多种操作,从而提高我们的代码效率和开发效率。 ### 回答2: SQLite是一个轻量级的关系型数据库,用于在嵌入式设备和移动设备中存储和管理数据。Qt是一个跨平台的应用程序开发框架,提供了许多工具类和API,可以用于开发各种类型的应用程序。Qt提供了许多与SQLite集成的工具类,以便在Qt应用程序中使用SQLite数据库。 Qt的SQLite工具类提供了一种简单、易于使用的方法来访问SQLite数据库。这些类可以帮助您轻松地执行各种操作,如打开和关闭数据库、执行查询和更新查询结果等。以下是一些常用的Qt SQLite工具类: 1. QSqlDatabase - 用于打开和关闭数据库连接的类。它提供了一种简单的方法来配置和连接到SQLite数据库。 2. QSqlQuery - 用于执行SQL查询并处理查询结果的类。它可以执行各种类型的SQL语句,如SELECT、INSERT、UPDATE、DELETE等。 3. QSqlTableModel - 用于管理表格的类。它可以连接到SQLite数据库中的数据表,并允许访问表格的数据、添加新数据、删除数据以及更新数据。 4. QSqlRelationalTableModel - 用于管理关系表格的类。它与QSqlTableModel类似,但可以处理两个或多个表之间的关系数据。 这些Qt SQLite工具类提供了一种简单、便捷的方法来访问和处理SQLite数据库。通过它们,可以轻松地执行各种操作,并快速地编写出高效、可靠的Qt应用程序。无论您是在嵌入式设备、移动设备还是桌面设备上开发应用程序,Qt的SQLite工具类都是非常有用的。 ### 回答3: Qt是一个跨平台应用程序开发框架,包括大量的类库和工具,其中也包括了对SQLite数据库的支持。Qt SQLite工具类就是一组对SQLite数据库进行操作的工具类,可以用来完成各种数据库操作。 使用Qt SQLite工具类可以方便地实现创建、打开、关闭、查询、修改、删除等常用操作。具体操作包括:初始化SQLite数据库并创建数据库文件,打开和关闭数据库文件,执行SQL语句,插入、更新和删除记录,查询记录集,事务处理等。 Qt SQLite工具类具有易用性、跨平台性、高效性、可维护性等优点。在开发过程中,多采用类和对象的方式进行编程,这样方便了代码的重用和维护。通过使用Qt SQLite工具类,开发者可以简化程序的开发、测试和维护工作,提高开发效率,减少开发成本。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值