数据库DBUtil类实现(C#_sqlite3/Java_mysql)(记录一)

JAVA实现Mysql.DBUtil

package server.mysql;

import java.sql.*;


public class DBUtil {

    //数据库连接
    private Connection dbConnect;
    //Query对象
    private Statement dbQuery;
    //Reader对象
    private ResultSet dbReader;

    public DBUtil(Connection connect) throws SQLException {
        this.dbConnect = connect;
        this.dbQuery = this.dbConnect.createStatement();
    }

    public void reset() throws SQLException {
        closeReader();
        closeQuery();
        this.dbConnect.setAutoCommit(true);
        this.dbQuery = this.dbConnect.createStatement();
    }

    public void close() {
        closeReader();
        closeQuery();

        //销毁Connection
        if (dbConnect != null) {
            try {
                dbConnect.close();
            } catch (SQLException e) {
                System.out.println(e.getMessage());
            }
        }
        dbConnect = null;
    }

    public void closeQuery() {
        //销毁Query
        if (dbQuery != null) {
            try {
                dbQuery.close();
            } catch (SQLException e) {
                System.out.println(e.getMessage());
            }
        }
        dbQuery = null;
    }

    public void closeReader() {
        //销毁Reader
        if (dbReader != null) {
            try {
                dbReader.close();
            } catch (SQLException e) {
                System.out.println(e.getMessage());
            }
        }
        dbReader = null;
    }

    //连接是否关闭
    public boolean isClosed() throws SQLException {
        return dbConnect == null || dbConnect.isClosed();
    }

    //创建一个新的Query对象
    public void createQuery() throws SQLException {
        closeReader();
        closeQuery();
        this.dbQuery = this.dbConnect.createStatement();
    }

    //设置自动事务
    public void setAutoCommit(boolean auto) throws SQLException {
        this.dbConnect.setAutoCommit(auto);
    }

    //提交事务
    public void commit() throws SQLException {
        dbConnect.commit();
    }

    //读取整张表全部数据
    public ResultSet readFullTable(String tableName) throws SQLException {
        String queryString = "SELECT * FROM " + tableName + " ;";
        return executeQuery(queryString);
    }

    //读取表全字段,从第start开始 读取rows条数据
    public ResultSet readFullTable(String tableName, int start, int rows) throws SQLException {
        String queryString = "SELECT * FROM " + tableName + " LIMIT " + start + "," + rows + " ;";
        return executeQuery(queryString);
    }

    //读取表全字段,且符合条件的数据纪录
    public ResultSet readFullTable(String tableName, String[] colNames, String[] operations, String[] colValues) throws SQLException {
        String queryString = "SELECT * FROM " + colNames[0] + " " + operations[0] + " " + colValues[0];
        for (int i = 1; i < colNames.length; i++) {
            queryString += " AND " + colNames[i] + " " + operations[i] + " " + colValues[0] + " ";
        }
        queryString += " ;";
        return executeQuery(queryString);
    }

    //读取表中符合条件的数据纪录的指定字段
    public ResultSet readTable(String tableName, String[] items, String[] colNames, String[] operations, String[] colValues) throws SQLException {
        String queryString = "SELECT " + items[0];
        for (int i = 1; i < items.length; i++) {
            queryString += ", " + items[i];
        }
        queryString += " FROM " + tableName + " WHERE " + colNames[0] + " " + operations[0] + " " + colValues[0];
        for (int i = 1; i < colNames.length; i++) {
            queryString += " AND " + colNames[i] + " " + operations[i] + " " + colValues[0] + " ";
        }
        queryString += " ;";
        return executeQuery(queryString);
    }

    //插入数据(返回插入次数)
    public int insertValues(String tableName, String[] values) throws SQLException {
        //获取数据表中字段数目
        int fieldCount = getFieldCount(tableName);
        //当插入的数据长度不等于字段数目时引发异常
        if (values.length != fieldCount) {
            throw new SQLException("values.Length!=fieldCount");
        }
        String queryString = "INSERT INTO " + tableName + " VALUES (" + values[0];
        for (int i = 1; i < values.length; i++) {
            queryString += ", " + values[i];
        }
        queryString += " ) ;";
        return executeUpdate(queryString);
    }

    //更新指定数据(返回更新次数<如没有与限定条件匹配的数据纪录,则返回0>)
    public int updateValues(String tableName, String[] colNames, String[] colValues, String key, String operation, String value) throws SQLException {
        //当字段名称和字段数值不对应时引发异常
        if (colNames.length != colValues.length) {
            throw new SQLException("colNames.Length!=colValues.Length");
        }

        String queryString = "UPDATE " + tableName + " SET " + colNames[0] + "=" + colValues[0];
        for (int i = 1; i < colValues.length; i++) {
            queryString += ", " + colNames[i] + "=" + colValues[i];
        }
        queryString += " WHERE " + key + operation + value + " ;";
        return executeUpdate(queryString);
    }

    //删除指定数据(返回删除多少条数据)
    public int deleteValuesOR(String tableName, String[] colNames, String[] operations, String[] colValues) throws SQLException {
        //当字段名称和字段数值不对应时引发异常
        if (colNames.length != colValues.length || operations.length != colNames.length || operations.length != colValues.length) {
            throw new SQLException("colNames.Length!=colValues.Length || operations.Length!=colNames.Length || operations.Length!=colValues.Length");
        }

        String queryString = "DELETE FROM " + tableName + " WHERE " + colNames[0] + operations[0] + colValues[0];
        for (int i = 1; i < colValues.length; i++) {
            queryString += "OR " + colNames[i] + operations[0] + colValues[i];
        }
        queryString += " ;";
        return executeUpdate(queryString);
    }

    public int deleteValuesAND(String tableName, String[] colNames, String[] operations, String[] colValues) throws SQLException {
        //当字段名称和字段数值不对应时引发异常
        if (colNames.length != colValues.length || operations.length != colNames.length || operations.length != colValues.length) {
            throw new SQLException("colNames.Length!=colValues.Length || operations.Length!=colNames.Length || operations.Length!=colValues.Length");
        }

        String queryString = "DELETE FROM " + tableName + " WHERE " + colNames[0] + operations[0] + colValues[0];
        for (int i = 1; i < colValues.length; i++) {
            queryString += " AND " + colNames[i] + operations[i] + colValues[i];
        }
        queryString += " ;";
        return executeUpdate(queryString);
    }

    //创建数据表
    public ResultSet createTable(String tableName, String[] colNames, String[] colTypes) throws SQLException {
        String queryString = "CREATE TABLE " + tableName + "( " + colNames[0] + " " + colTypes[0];
        for (int i = 1; i < colNames.length; i++) {
            queryString += ", " + colNames[i] + " " + colTypes[i];
        }
        queryString += "  ) ;";
        return executeQuery(queryString);
    }

    //获取table字段数量
    public int getFieldCount(String tableName) throws SQLException {
        Statement query = dbConnect.createStatement();
        ResultSet reader = query.executeQuery("SELECT * FROM " + tableName + " LIMIT 0,0 ;");
        int fieldCount = reader.getMetaData().getColumnCount();
        query.close();
        reader.close();
        return fieldCount;
    }

    //在dbCommand上添加数据
    public void addParameter(String key, byte[] value) throws SQLException {
        throw new SQLException("DBUtil Exception: Unrealized method");
    }

    //执行SQL查询命令
    public ResultSet executeQuery(String queryString) throws SQLException {
        //System.out.println(queryString);
        dbReader = dbQuery.executeQuery(queryString);
        return dbReader;
    }

    //执行SQL更改命令(返回执行次数)
    public int executeUpdate(String queryString) throws SQLException {
        //System.out.println(queryString);
        int ret = dbQuery.executeUpdate(queryString);
        return ret;
    }
}

 

 

C# 实现Sqlite3.DBUtil(关键词:Unity/XLua/Sqlite3)

using System;
using UnityEngine;
using Mono.Data.Sqlite;
using System.IO;

public class SQLiteSamples
{
    private static bool isAndroid = Application.platform == RuntimePlatform.Android;

    //数据库连接
    private SqliteConnection dbConnection = null;
    //SQL命令定义
    private SqliteCommand dbCommand = null;
    //数据读取定义
    private SqliteDataReader dataReader = null;

    //实例化连接对象
    public SQLiteSamples(string connectionString)
    {
        if (isAndroid)
        {
            //在(Unity 2018.2.18f1版本,安卓也是"data source="并不是"URL=file:")
            //connectionString = "URL=file:" + connectionString;
        }
        connectionString = "data source=" + connectionString;
        //构造数据库连接
        dbConnection = new SqliteConnection(connectionString);
        //打开数据库
        dbConnection.Open();
        //建立Command连接
        dbCommand = dbConnection.CreateCommand();
    }
    public SQLiteSamples(string dataSource, string connectionString)
    {
        connectionString = dataSource + connectionString;
        //构造数据库连接
        dbConnection = new SqliteConnection(connectionString);
        //打开数据库
        dbConnection.Open();
        //建立Command连接
        dbCommand = dbConnection.CreateCommand();
    }
    //销毁数据库连接
    public void Close()
    {
        //销毁Reader
        if (dataReader != null)
        {
            dataReader.Close();
        }
        dataReader = null;

        //销毁Command
        if (dbCommand != null)
        {
            dbCommand.Cancel();
        }
        dbCommand = null;

        //销毁Connection
        if (dbConnection != null)
        {
            dbConnection.Close();
        }
        dbConnection = null;
    }
    //创建新的Command对象
    public void CreateCommand()
    {
        //销毁Reader
        if (dataReader != null)
        {
            dataReader.Close();
        }
        dataReader = null;
        //销毁Command
        if (dbCommand != null)
        {
            dbCommand.Cancel();
        }
        dbCommand = dbConnection.CreateCommand();
    }

    //读取整张表全部数据
    public SqliteDataReader ReadFullTable(string tableName)
    {
        string queryString = "SELECT * FROM " + tableName;
        return ExecuteQuery(queryString);
    }
    //读取表全字段,从第start开始 读取rows条数据
    public SqliteDataReader ReadFullTable(string tableName, int start, int rows)
    {
        string queryString = "SELECT * FROM " + tableName + " LIMIT " + start + "," + rows;
        return ExecuteQuery(queryString);
    }
    //读取表中符合条件的数据纪录的指定字段
    public SqliteDataReader ReadTable(string tableName, string[] items, string[] colNames, string[] operations, string[] colValues)
    {
        string queryString = "SELECT " + items[0];
        for (int i = 1; i < items.Length; i++)
        {
            queryString += ", " + items[i];
        }
        queryString += " FROM " + tableName + " WHERE " + colNames[0] + " " + operations[0] + " " + colValues[0];
        for (int i = 1; i < colNames.Length; i++)
        {
            queryString += " AND " + colNames[i] + " " + operations[i] + " " + colValues[0] + " ";
        }
        return ExecuteQuery(queryString);
    }
    //插入数据(返回插入次数)
    public int InsertValues(string tableName, string[] values)
    {
        //获取数据表中字段数目
        int fieldCount = GetFieldCount(tableName);
        //当插入的数据长度不等于字段数目时引发异常
        if (values.Length != fieldCount)
        {
            throw new SqliteException("values.Length!=fieldCount");
        }
        string queryString = "INSERT INTO " + tableName + " VALUES (" + values[0];
        for (int i = 1; i < values.Length; i++)
        {
            queryString += ", " + values[i];
        }
        queryString += " )";
        return ExecuteUpdate(queryString);
    }
    //更新指定数据(返回更新次数<如没有与限定条件匹配的数据纪录,则返回0>)
    public int UpdateValues(string tableName, string[] colNames, string[] colValues, string key, string operation, string value)
    {
        //当字段名称和字段数值不对应时引发异常
        if (colNames.Length != colValues.Length)
        {
            throw new SqliteException("colNames.Length!=colValues.Length");
        }

        string queryString = "UPDATE " + tableName + " SET " + colNames[0] + "=" + colValues[0];
        for (int i = 1; i < colValues.Length; i++)
        {
            queryString += ", " + colNames[i] + "=" + colValues[i];
        }
        queryString += " WHERE " + key + operation + value;
        return ExecuteUpdate(queryString);
    }
    //删除指定数据(返回删除多少条数据)
    public int DeleteValuesOR(string tableName, string[] colNames, string[] operations, string[] colValues)
    {
        //当字段名称和字段数值不对应时引发异常
        if (colNames.Length != colValues.Length || operations.Length != colNames.Length || operations.Length != colValues.Length)
        {
            throw new SqliteException("colNames.Length!=colValues.Length || operations.Length!=colNames.Length || operations.Length!=colValues.Length");
        }

        string queryString = "DELETE FROM " + tableName + " WHERE " + colNames[0] + operations[0] + colValues[0];
        for (int i = 1; i < colValues.Length; i++)
        {
            queryString += "OR " + colNames[i] + operations[0] + colValues[i];
        }
        return ExecuteUpdate(queryString);
    }
    public int DeleteValuesAND(string tableName, string[] colNames, string[] operations, string[] colValues)
    {
        //当字段名称和字段数值不对应时引发异常
        if (colNames.Length != colValues.Length || operations.Length != colNames.Length || operations.Length != colValues.Length)
        {
            throw new SqliteException("colNames.Length!=colValues.Length || operations.Length!=colNames.Length || operations.Length!=colValues.Length");
        }

        string queryString = "DELETE FROM " + tableName + " WHERE " + colNames[0] + operations[0] + colValues[0];
        for (int i = 1; i < colValues.Length; i++)
        {
            queryString += " AND " + colNames[i] + operations[i] + colValues[i];
        }
        return ExecuteUpdate(queryString);
    }

    //创建数据表
    public SqliteDataReader CreateTable(string tableName, string[] colNames, string[] colTypes)
    {
        string queryString = "CREATE TABLE " + tableName + "( " + colNames[0] + " " + colTypes[0];
        for (int i = 1; i < colNames.Length; i++)
        {
            queryString += ", " + colNames[i] + " " + colTypes[i];
        }
        queryString += "  ) ";
        return ExecuteQuery(queryString);
    }


    //获取fieldCount
    public int GetFieldCount(string tableName)
    {
        var dbCommand = dbConnection.CreateCommand();
        dbCommand.CommandText = "SELECT * FROM " + tableName + " LIMIT 0,0";
        var reader = dbCommand.ExecuteReader();
        int fieldCount = reader.FieldCount;
        //Close
        dbCommand.Cancel();
        reader.Close();
        return fieldCount;
    }
    //在dbCommand上添加数据
    public void AddParameter(string key, byte[] value)
    {
        dbCommand.Parameters.Add(key, System.Data.DbType.Binary).Value = value;
    }

    //执行SQL查询命令
    public SqliteDataReader ExecuteQuery(string queryString)
    {
        Debug.Log(queryString);
        dbCommand.CommandText = queryString;
        dataReader = dbCommand.ExecuteReader();
        return dataReader;
    }

    //执行SQL更改命令(返回执行次数)
    public int ExecuteUpdate(string queryString)
    {
        Debug.Log(queryString);
        dbCommand.CommandText = queryString;
        var ret = dbCommand.ExecuteNonQuery();
        return ret;
    }

    //创建数据库文件
    public static bool Create(string fileFullName, bool deleteOld = false)
    {
        //删除旧文件
        if (deleteOld && File.Exists(fileFullName))
        {
            File.Delete(fileFullName);
        }
        if (!File.Exists(fileFullName))
        {
            //创建文件夹
            var dir = Path.GetDirectoryName(fileFullName);
            if (!Directory.Exists(dir))
            {
                Directory.CreateDirectory(dir);
            }
            //创建数据库文件
            SqliteConnection.CreateFile(fileFullName);
            return true;
        }
        return false;
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值