Java操作SQLite实现增删改查

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class TestSQLite {
    public static void main(String[] args) {
        new TestSQLite().save();
        new TestSQLite().del();
        new TestSQLite().update();
        new TestSQLite().queryByName();
        new TestSQLite().queryAll();
        new TestSQLite().createTable();
    }

    protected static Connection connect = null;
    protected static Statement stmt = null;
    static {
        try {
            Class.forName("org.sqlite.JDBC");
            connect = DriverManager.getConnection("jdbc:sqlite:test.db");
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        System.out.println("Opened database successfully");
    }

    public void createTable() {
        try {
            connect.setAutoCommit(false);

            stmt = connect.createStatement();

            String sql = "create table user(id int,name text,sex text)";

            stmt.executeUpdate(sql);
            System.out.println("create data success");

            // 提交
            connect.commit();

            // 关闭Statement
            stmt.close();
            connect.close();

        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public void save() {
        try {
            connect.setAutoCommit(false);

            stmt = connect.createStatement();

            String sql = "insert into test_t(id,value)values(2,'tom')";

            // 执行
            int count = stmt.executeUpdate(sql);
            if (count > 0) {
                System.out.println("insert data success");
            } else {
                System.out.println("insert data fail");
            }

            // 提交
            connect.commit();

            sql = "select * from test_t";

            ResultSet result = stmt.executeQuery(sql);
            while (result.next()) {
                System.out.println(result.getInt("id"));
                System.out.println(result.getString("value"));
            }

            result.close();

            // 关闭Statement
            stmt.close();
            // 关闭Connection
            connect.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public void queryAll() {
        try {
            connect.setAutoCommit(false);
            stmt = connect.createStatement();

            String sql = "select * from test_t";

            ResultSet result = stmt.executeQuery(sql);
            while (result.next()) {
                System.out.println(result.getInt("id"));
                System.out.println(result.getString("value"));
            }

            result.close();
            stmt.close();
            connect.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public void queryByName() {
        try {
            connect.setAutoCommit(false);
            stmt = connect.createStatement();

            String sql = "select * from test_t where value = 'tom'";

            ResultSet result = stmt.executeQuery(sql);
            while (result.next()) {
                System.out.println(result.getInt("id"));
                System.out.println(result.getString("value"));
            }

            result.close();
            stmt.close();
            connect.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public void update() {
        try {
            connect.setAutoCommit(false);
            stmt = connect.createStatement();

            String sql = "update  test_t  set value = 'xiaoli' where id = 3";
            int count = stmt.executeUpdate(sql);

            if (count > 0) {
                System.out.println("update data success");
            } else {
                System.out.println("update data fail");
            }
            connect.commit();

            String querySql = "select * from test_t";
            ResultSet result = stmt.executeQuery(querySql);
            while (result.next()) {
                System.out.println(result.getInt("id"));
                System.out.println(result.getString("value"));
            }

            result.close();
            stmt.close();
            connect.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public void del() {
        try {
            connect.setAutoCommit(false);
            stmt = connect.createStatement();

            String sql = "delete from test_t where id = 2";
            int count = stmt.executeUpdate(sql);

            if (count > 0) {
                System.out.println("delete data success");
            } else {
                System.out.println("delete data fail");
            }

            connect.commit();

            String querySql = "select * from test_t";
            ResultSet result = stmt.executeQuery(querySql);
            while (result.next()) {
                System.out.println(result.getInt("id"));
                System.out.println(result.getString("value"));
            }

            result.close();
            stmt.close();
            connect.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以帮你解答这个问题。在 Android 中实现SQLite 数据库的增删改查,需要通过 SQLiteOpenHelper 类来创建和管理数据库。下面是一个示例: 1. 创建 SQLiteOpenHelper 类 ```java public class DBHelper extends SQLiteOpenHelper { private static final String DATABASE_NAME = "mydatabase.db"; private static final int DATABASE_VERSION = 1; public DBHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { String sql = "CREATE TABLE mytable (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER)"; db.execSQL(sql); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String sql = "DROP TABLE IF EXISTS mytable"; db.execSQL(sql); onCreate(db); } } ``` 2. 增加数据 ```java DBHelper dbHelper = new DBHelper(context); SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("name", "张三"); values.put("age", 18); long id = db.insert("mytable", null, values); ``` 3. 删除数据 ```java DBHelper dbHelper = new DBHelper(context); SQLiteDatabase db = dbHelper.getWritableDatabase(); String whereClause = "name=?"; String[] whereArgs = new String[]{"张三"}; int count = db.delete("mytable", whereClause, whereArgs); ``` 4. 修改数据 ```java DBHelper dbHelper = new DBHelper(context); SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("age", 20); String whereClause = "name=?"; String[] whereArgs = new String[]{"张三"}; int count = db.update("mytable", values, whereClause, whereArgs); ``` 5. 查询数据 ```java DBHelper dbHelper = new DBHelper(context); SQLiteDatabase db = dbHelper.getReadableDatabase(); String[] columns = new String[]{"name", "age"}; String selection = "name=?"; String[] selectionArgs = new String[]{"张三"}; String groupBy = null; String having = null; String orderBy = null; String limit = null; Cursor cursor = db.query("mytable", columns, selection, selectionArgs, groupBy, having, orderBy, limit); while (cursor.moveToNext()) { String name = cursor.getString(cursor.getColumnIndex("name")); int age = cursor.getInt(cursor.getColumnIndex("age")); } ``` 以上就是 Android 实现SQLite 数据库增删改查的示例代码,你可以根据自己的需求进行修改。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值