热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java项目中通过JDBC实现sqlite数据库的增删改查操作

关于java项目中sqlite数据库的使用案例少之又少,查阅资料最多只是怎么连接并没有对对象的操作..实现对其数据的增删给查操作,为此,结合JDBC技术写的通过JDBC访问操作sq

关于java项目中sqlite数据库的使用案例少之又少,查阅资料 最多只是怎么连接 并没有对对象的操作..实现对其数据的增删给查操作,为此,结合JDBC技术写的通过JDBC访问操作sqlite数据库.不喜勿喷!!!

转载请注明出处——————Annhoa

 DBConnection.java

Java代码 

《java 项目中通过JDBC 实现sqlite数据库的增删改查操作》

package com.darkblue.dynem.util.sqlitedb;  

import java.sql.Connection;  

import java.sql.DriverManager;  

import java.sql.PreparedStatement;  

import java.sql.ResultSet;  

import java.sql.SQLException;  

import java.sql.Statement;  

import java.util.ArrayList;  

import java.util.List;  

import java.util.logging.Logger;  

import com.darkblue.dynem.util.filehelp.FileBean;  

/**

 * @author Annhoa

 * @date 2017/07/26

 * @since JDBC connection of sqlite 

 * @version 1.0

 * 

 */  

public class DBConnection {  

private static final Logger log = Logger.getLogger(DBConnection.class.toString());  

private static Connection conn;  

private static Statement stat;  

private static PreparedStatement prep;  

private static ResultSet rst;  

/**

     * 连接到数据库

     * @param创建表sql

     */  

public DBConnection(String jdbc,String sql){  

try {  

Class.forName(“org.sqlite.JDBC”);  

            cOnn=DriverManager.getConnection(jdbc);  

            stat=conn.createStatement();  

log.info(“连接到Sqlite”);  

//sql创建表语句  

            stat.executeUpdate(sql);  

log.info(“创建Sqlite表”);  

}catch (Exception e) {  

            e.printStackTrace();  

        }  

    }  

/**

     * 通用增删改

     * */  

public static int executeUpdate(String sql,Object[] obs){  

try {  

            prep=conn.prepareStatement(sql);  

if(obs!=null&&obs.length>0){  

for (int i = 0; i < obs.length; i++) {  

prep.setObject(i+1, obs[i]);  

                }  

            }  

int row=prep.executeUpdate();  

if(row>0){  

//  conn.commit(); //oracle数据库用到      

return row;  

            }  

}catch (SQLException e) {  

            e.printStackTrace();  

        }  

return -1;  

    }  

/**

     * 通用查询

     * */  

public static ResultSet executeQuery(String sql,Object[] obs){  

try {  

            prep=conn.prepareStatement(sql);  

if(obs!=null&&obs.length>0){  

for (int i = 0; i < obs.length; i++) {  

prep.setObject(i+1, obs[i]);  

                }  

            }  

            rst = prep.executeQuery();  

}catch (SQLException e) {  

            e.printStackTrace();  

        }  

return rst;  

    }  

}  

FileBeanDBHelper.java

Java代码 

《java 项目中通过JDBC 实现sqlite数据库的增删改查操作》

package com.darkblue.dynem.util.sqlitedb;  

import java.sql.ResultSet;  

import java.sql.SQLException;  

import java.util.ArrayList;  

import java.util.List;  

import com.darkblue.dynem.util.filehelp.FileBean;  

public class FileBeanDBHelper {  

private ResultSet rst=null;  

private DBConnection sqliteHelper;  

/**

 * @author Annhoa

 * @date 2017/07/26

 * @since fileBean数据库操作 

 * @version 1.0

 * 

 */  

//关闭还未处理  

public FileBeanDBHelper(){  

String dbString =&#8221;jdbc:sqlite:test.db&#8221;;  

sqliteHelper =new DBConnection(dbString,&#8221;CREATE TABLE IF NOT EXISTS table0 &#8221;  

+&#8221;(id CHAR(20) PRIMARY KEY NOT NULL, filename CHAR(50) not null, &#8221;  

+&#8221;filesize LONG ,filepath CHAR(50), filesource CHAR(50))&#8221;);  

}  

public boolean save(FileBean fb) {  

String sql=&#8221;insert into table0 values(?,?,?,?,?)&#8221;;  

int row=DBConnection.executeUpdate(sql, new String[]{  

            fb.getId(),  

            fb.getFilename(),  

fb.getFilesize()+&#8221;&#8221;,  

            fb.getFilepath(),  

            fb.getFilesource()  

        });  

if(row>0){  

return true;  

        }  

return false;  

    }  

@SuppressWarnings(&#8220;static-access&#8221;)  

public boolean update(FileBean fb) {  

String sql=&#8221;update table0 set id=?,filename=?,filesize=?,filepath=?,filesource=?&#8221;;  

int row=sqliteHelper.executeUpdate(sql, new String[]{  

                fb.getId(),  

                fb.getFilename(),  

fb.getFilesize()+&#8221;&#8221;,  

                fb.getFilepath(),  

                fb.getFilesource()  

        });  

if(row>0){  

return true;  

        }  

return false;  

    }  

public boolean delById(String id) {  

String sql=&#8221;delete from table0 where id=?&#8221;;  

int row=sqliteHelper.executeUpdate(sql, new String[]{  

                id  

        });  

if(row>0){  

return true;  

        }  

return false;  

    }  

public FileBean findById(String id) {  

String sql=&#8221;select * from table0 where id=?&#8221;;  

rst=sqliteHelper.executeQuery(sql,new String[]{id});  

try {  

if(rst.next()){  

FileBean fb=new FileBean(rst.getString(1), rst.getString(2), rst.getLong(3), rst.getString(4), rst.getString(5));  

return fb;  

            }  

}catch (SQLException e) {  

            e.printStackTrace();  

        }  

return null;  

    }  

public List findAll(String filename) {  

String sql=&#8221;select * from table0 where 1=1&#8243;;  

if(filename!=null&&!filename.trim().equals(&#8220;&#8221;)){  

sql+=&#8221;  and filename='&#8221;+filename+&#8221;&#8216;&#8221;;  

        }  

sql+=&#8221; order by id&#8221;;  

rst=sqliteHelper.executeQuery(sql,null);  

List listfb=new ArrayList();  

try {  

while(rst.next()){  

FileBean fb=new FileBean(rst.getString(1), rst.getString(2), rst.getLong(3), rst.getString(4), rst.getString(5));  

                listfb.add(fb);  

            }  

}catch (SQLException e) {  

// TODO Auto-generated catch block  

            e.printStackTrace();  

        }  

return listfb;  

    }  

public static void main(String[] args) {  

FileBean fb=new FileBean();  

fb.setId(&#8220;3&#8221;);  

fb.setFilename(&#8220;xxxxx.txt&#8221;);  

fb.setFilepath(&#8220;C:/Users/Administrator/Desktop&#8221;);  

fb.setFilesize(323);  

fb.setFilesource(&#8220;&#8221;);  

boolean flag = new FileBeanDBHelper().save(fb);  

        System.out.println(flag);  

List list =new FileBeanDBHelper().findAll(null);System.out.println(list);  

    }  

}  

FileBean.java

Java代码 

package com.darkblue.dynem.util.filehelp;  

import java.io.Serializable;  

/**

 * 发送消息列表

 * Created by Administrator on 2016/8/12.

 */  

public class FileBean implements Serializable {  

public String id;  

public long filesize;//文件大小  

public String filename;//文件名字  

public String filepath;//文件路径  

public String filesource;//文件分享源  

//添加构造方法  

public FileBean(String id,String filename,long filesize,String filepath,String filesource){  

super();  

this.id = id;  

this.filename = filename;  

this.filesize = filesize;  

this.filepath = filepath;  

this.filesource = filesource;  

    }  

public String getFilesource() {  

return filesource;  

    }  

public void setFilesource(String filesource) {  

this.filesource = filesource;  

    }  

public long getFilesize() {  

return filesize;  

    }  

public void setFilesize(long filesize) {  

this.filesize = filesize;  

    }  

public String getId() {  

return id;  

    }  

public void setId(String id) {  

this.id = id;  

    }  

public String getFilename() {  

return filename;  

    }  

public void setFilename(String filename) {  

this.filename = filename;  

    }  

public String getFilepath() {  

return filepath;  

    }  

public void setFilepath(String filepath) {  

this.filepath = filepath;  

    }  

@Override  

public String toString() {  

return &#8220;FileBean{&#8221; +  

&#8220;id='&#8221; + id + &#8216;\&#8221; +  

&#8220;, filesize=&#8221; + filesize +  

&#8220;, filename='&#8221; + filename + &#8216;\&#8221; +  

&#8220;, filepath='&#8221; + filepath + &#8216;\&#8221; +  

&#8220;, filesource='&#8221; + filesource + &#8216;\&#8221; +  

&#8216;}&#8217;;  

    }  

public FileBean() {  

    }  

public String toJsonString() {  

return &#8220;{\&#8221;id\&#8221;:\&#8221;&#8221; + id + &#8220;\&#8221;,\&#8221;filename\&#8221;:\&#8221;&#8221; + filename + &#8220;\&#8221;,\&#8221;filepath\&#8221;:\&#8221;&#8221; + filepath + &#8220;\&#8221;,\&#8221;filesize\&#8221;:\&#8221;&#8221; + filesize + &#8220;\&#8221;,\&#8221;filesource\&#8221;:\&#8221;&#8221; + filesource + &#8220;\&#8221;}&#8221;;  

    }  

}  


推荐阅读
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
  • 多维数组的使用
    本文介绍了多维数组的概念和使用方法,以及二维数组的特点和操作方式。同时还介绍了如何获取数组的长度。 ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • Spring学习(4):Spring管理对象之间的关联关系
    本文是关于Spring学习的第四篇文章,讲述了Spring框架中管理对象之间的关联关系。文章介绍了MessageService类和MessagePrinter类的实现,并解释了它们之间的关联关系。通过学习本文,读者可以了解Spring框架中对象之间的关联关系的概念和实现方式。 ... [详细]
  • 数组的排序:数组本身有Arrays类中的sort()方法,这里写几种常见的排序方法。(1)冒泡排序法publicstaticvoidmain(String[]args ... [详细]
  • 面向对象之3:封装的总结及实现方法
    本文总结了面向对象中封装的概念和好处,以及在Java中如何实现封装。封装是将过程和数据用一个外壳隐藏起来,只能通过提供的接口进行访问。适当的封装可以提高程序的理解性和维护性,增强程序的安全性。在Java中,封装可以通过将属性私有化并使用权限修饰符来实现,同时可以通过方法来访问属性并加入限制条件。 ... [详细]
author-avatar
Maze-HYW_276
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有