SQLite 數據庫訪問


SQLite是一個很輕量的數據庫。詳細介紹我就不多說了,這個東西應該在嵌入式里面用得比較多。根據我看到的資料(幾個月以前看的),現在安卓應用應該也會用這個,HTML5 也支持sqlite。

SQLite也支持 SQL 語句。它的每一個數據庫都是一個后綴為db的文件

我手里有一個這樣的文件,里面已經有一些數據了。

怎么訪問這個數據?

1. 最簡單的在 windows 平台下下載一個 SQLiteSpy 程序 

  a. File->Open Database, 選擇要打開的 .db 文件

可以看到

執行一條簡單的sql

2. 使用 Java JDBC 訪問 SQLite 數據庫

需要添加驅動依賴

<!-- https://mvnrepository.com/artifact/org.xerial/sqlite-jdbc -->
    <dependency>
        <groupId>org.xerial</groupId>
        <artifactId>sqlite-jdbc</artifactId>
        <version>3.23.1</version>
    </dependency>

java代碼

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

public class App {
    
    public static void main(String[] args) {
        String url = "jdbc:sqlite:sqlDb.db";
        Connection conn = null;
        PreparedStatement pStatement = null;
        ResultSet resultSet = null;
        
        
        try {
            Class.forName("org.sqlite.JDBC");
            conn = DriverManager.getConnection(url);
            pStatement = conn.prepareStatement("select * from `AccLvl`");
            resultSet = pStatement.executeQuery();
            while(resultSet.next()) {
                System.out.println("AccLvlNum:" + resultSet.getInt("AccLvlNum") + " " + "timeZoneTableId: " + resultSet.getInt("timeZoneTableId") + " " + "lastModified: " + resultSet.getTimestamp("lastModified"));
            }
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }finally {
            
            try {
                if(resultSet != null) {
                    resultSet.close();
                }
                if(pStatement != null) {
                    pStatement.close();
                }
                if(conn != null) {
                    conn.close();
                }
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }

}

程序執行結果

AccLvlNum:0 timeZoneTableId: 0 lastModified: 1970-01-19 01:55:17.192
AccLvlNum:1 timeZoneTableId: 1 lastModified: 1970-01-19 01:55:17.192
AccLvlNum:2 timeZoneTableId: 2 lastModified: 1970-01-19 01:55:17.192
AccLvlNum:3 timeZoneTableId: 3 lastModified: 1970-01-19 01:55:17.192
AccLvlNum:4 timeZoneTableId: 4 lastModified: 1970-01-19 01:55:17.193
AccLvlNum:5 timeZoneTableId: 5 lastModified: 1970-01-19 01:55:17.193
AccLvlNum:6 timeZoneTableId: 6 lastModified: 1970-01-19 01:55:17.193
AccLvlNum:7 timeZoneTableId: 7 lastModified: 1970-01-19 01:55:17.193
AccLvlNum:8 timeZoneTableId: 8 lastModified: 1970-01-19 01:55:17.193
AccLvlNum:9 timeZoneTableId: 9 lastModified: 1970-01-19 01:55:17.194
AccLvlNum:10 timeZoneTableId: 10 lastModified: 1970-01-19 01:55:17.194
AccLvlNum:11 timeZoneTableId: 11 lastModified: 1970-01-19 01:55:17.194
AccLvlNum:12 timeZoneTableId: 12 lastModified: 1970-01-19 01:55:17.194
AccLvlNum:13 timeZoneTableId: 13 lastModified: 1970-01-19 01:55:17.194
AccLvlNum:14 timeZoneTableId: 14 lastModified: 1970-01-19 01:55:17.194
AccLvlNum:15 timeZoneTableId: 15 lastModified: 1970-01-19 01:55:17.195
AccLvlNum:16 timeZoneTableId: 16 lastModified: 1970-01-19 01:55:17.195
AccLvlNum:17 timeZoneTableId: 17 lastModified: 1970-01-19 01:55:17.195

 

3. linux 訪問(Ubuntu)

首先安裝 sqlite3

sudo apt-get install sqlite3

然后創建一個數據庫,之前說了sqlite 的數據庫就是一個 db 文件。 然后就可以進行數據庫操作了,大體語法跟mysql是一樣的,有細微的區別

vmware@ubuntu:~/frank$ sqlite3 test.db
SQLite version 3.11.0 2016-02-15 17:29:24
Enter ".help" for usage hints.
sqlite> .table
sqlite> create table t_user(
   ...> id integer primary key autoincrement,
   ...> name varchar(20) not null,
   ...> password varchar(20) not null
   ...> );
sqlite> insert into t_user(name, password) values ('jordan','1234'),('kobe', '3456'),('james', '7890');
sqlite> select * from t_user;
1|jordan|1234
2|kobe|3456
3|james|7890
sqlite> select * from t_user where name='kobe';
2|kobe|3456
sqlite> 

用到的sql

.table
create table t_user(
id integer primary key autoincrement,
name varchar(20) not null,
password varchar(20) not null
);
insert into t_user(name, password) values ('jordan','1234'),('kobe', '3456'),('james', '7890');
select * from t_user
select * from t_user where name='kobe';

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM