https://www.ancii.com/amh64d6g4/

来源:https://www.cnblogs.com/ccky/archive/2020/05/28/12980136.html
-Advertisement-
Play Games

(1):C#讀取DB文件 第一步 下載DLL文件並安裝 DLL下載地址https://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki 選用版本sqlite-netFx46-setup-bundle-x64-2015-1.0 ...


(1):C#讀取DB文件

第一步 下載DLL文件並安裝

DLL下載地址https://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki

選用版本sqlite-netFx46-setup-bundle-x64-2015-1.0.112.0.exe,適用框架.NET Framework 4.6(可以根據自己的需要選用)。

下載後,系統預設安裝在C:\Program Files\System.Data.SQLite路徑下,拷貝System.Data.SQLite.dll文件到工程文件目錄下X:/Project/bin/debug。

在解決方案資源管理器中,選擇“引用”,右鍵後選擇“添加引用”。

如圖1,在引用管理器側邊欄選擇“瀏覽”後,再點擊“瀏覽”按鈕,安裝之前保存在工程文件目錄下的System.Data.SQLite.dll,點擊“確定”後完成。

【WinForm】雜記(1):C#讀取DB文件

在程式中添加引用, 完成第一步

using System.Data.SQLite;

 

第二步 獲取數據

public DataTable GetDataTable(string strSQL, string path){
    DataTable dt = null;
    try {
        SQLiteConnection conn = new SQLiteConnection(path);
        SQLiteCommand cmd = new SQLiteCommand();
        cmd.CommandText = strSQL;
        cmd.Connection = conn;
        SQLiteDataAdapter dao = new SQLiteDataAdapter(cmd);
        dt = new DataTable();
        dao.Fill(dt);
        return dt;
    }
    catch{
        MessageBox.Show("There is no such a datatable");
    }
    return dt;
}

其中strSQL是獲取db文件中數據表的指令

string sSQL = "SELECT * FROM item_compound;";

這裡的數據表名為"item_compound"。

文件路Path為

public static string DBPath = string.Format(@"Data Source={0}",
                    Application.StartupPath + @"\CCUS_supstr_temp.db");//the path of .db file

這裡的db文件名為“CCUS_supstr_temp.db”。

第三步 測試代碼

private void FrmConvert_Load(object sender, EventArgs e){
    string sSQL = "SELECT * FROM item_compound;";
    DataTable dbt = GetDataTable(sSQL, DBPath);
    this.dataGridView1.DataSource = dbt;
}

結果如圖2

【WinForm】雜記(1):C#讀取DB文件

 

 

 

 

2):C#操作SQLite資料庫(總結)

操作功能列表:

  • 功能1:讀取所有表名/索引/視圖
  • 功能2:讀取表數據

功能1:讀取所有表名/索引/視圖

每一個 SQLite 資料庫都有一個叫sqlit_master的表, 裡面存儲著資料庫的數據結構(表結構、視圖結構、索引結構等)。故通過讀取sqlit_master便可以獲取所有的表格信息。

獲取表名

SELECT name FROM sqlite_master WHERE TYPE=‘table‘ ORDER BY name

獲取索引

SELECT name FROM sqlite_master WHERE TYPE=‘index‘ ORDER BY name  

獲取視圖

SELECT name FROM sqlite_master WHERE TYPE=‘view‘ ORDER BY name

以獲取表名為例,完整代碼為

public DataSet GetTableNames(string path) {
    string strSQL = "SELECT name FROM sqlite_master WHERE TYPE=‘table‘ ORDER BY name";
    DataSet ds = null;
    try {
        SQLiteConnection conn = new SQLiteConnection(path);
        SQLiteCommand cmd = new SQLiteCommand(strSQL, conn);
        SQLiteDataAdapter reciever = new SQLiteDataAdapter(cmd);
        ds = new DataSet();
        reciever.Fill(ds);
        return ds;
    } catch {
        MessageBox.Show("There is no data table");
    }
    return ds;
}16 DataSet dbnames = GetTableNames(DBPath);

註意此時返回的ds包含的元素數量只有一個,所有表名以列向量的形式存儲在一張表中(即ds唯一的元素)。

讀取表數量的代碼為

int tablecount = dbnames.Tables[0].Rows.Count;

讀取索引為X的表名

string tablename = dbnames.Table[0].Rows[X].ItemArray[0].ToString();//X starts from 0

 

功能2:讀取表數據

public DataTable GetDataTable(string strSQL, string path){
    DataTable dt = null;
    try {
        SQLiteConnection conn = new SQLiteConnection(path);
        SQLiteCommand cmd = new SQLiteCommand(strSQL,conn);
        SQLiteDataAdapter reciever = new SQLiteDataAdapter(cmd);
        dt = new DataTable();
        reciever.Fill(dt);
        return dt;
    } catch{
        MessageBox.Show("There is no such a datatable");
    }
    return dt;
}

  其中strSQL是獲取db文件中數據表的指令

string sSQL = "SELECT * FROM item_compound;";

這裡的數據表名為"item_compound"。

文件路Path為

public static string DBPath = string.Format(@"Data Source={0}",
                    Application.StartupPath + @"\CCUS_supstr_temp.db");//the path of .db file  

這裡的db文件名為“CCUS_supstr_temp.db”。

 

 

 

 

 

 

 

 

 

 

 

 

 

轉載自

https://www.ancii.com/ac9q53gmx/

 https://www.ancii.com/amh64d6g4/

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先在用戶表定義一個積分欄位; 然後創建一個等級表,主要欄位有等級名,上限積分和下限積分; 再根據用戶的行為進行積分累加; 最後根據判斷用戶積分在哪個等級範圍,從而得出用戶等級。 用戶表 CREATE TABLE `bbs`.`user`( `id` INT(10) UNSIGNED NOT NUL ...
  • Java多線程面試問題 1. 進程和線程之間有什麼不同? 一個進程是一個獨立(self contained)的運行環境,它可以被看作一個程式或者一個應用。而線程是在進程中執行的一個任務。Java運行環境是一個包含了不同的類和程式的單一進程。線程可以被稱為輕量級進程。線程需要較少的資源來創建和駐留在進 ...
  • 使用場景:新頭像替換舊的頭像 步驟: 1. 讀取資料庫頭像的URL地址 2. 獲取URL地址的有效欄位 3. file文件路徑設置 4. 刪除圖片文件 Thinkphp 代碼如下: <?php public function delPic(){ //獲取用戶id $uid = input('uid' ...
  • Java這門語言的發展是很有意思的,它不像Python, Ruby 等完全是開源社區驅動,也不像C#,VB.NET主要由微軟操刀。它是一個以Oracle(之前是Sun)為主,各大巨頭一起參與,一起制定標準的一門語言。 想對Java添加一點特性, 得走JCP流程,巨頭們要審查,看看對自己是否有利,然後 ...
  • Blazor編譯後的文件是靜態文件,所以我們只需要一個支持靜態頁面的web server即可。 根據不同項目,會用不同的容器編排,本文已無網關的情況下為例,一步一步展示如何打包進docker 需求 HTTPS 既然無網關,直接面向互聯網,所以HTTPS顯得尤為重要 HTTP/2 TLS3.0 既然都 ...
  • C#編碼轉換主要使用了Encoding.Convert方法,它需要原編碼字元串的位元組數組作為參數,返回目標編碼的位元組數組。Encoding對象可以從字元串獲取位元組數組,又能夠從位元組數組還原字元串,因此可以將其組合用來轉碼。 ...
  • k8s 和 Docker容器技術,當前非常流行的技術. 讓人日狗的是, 這套技術棧對CN的donet 程式員不怎麼友好。娓娓道來,1. 好多鏡像都是需要梯子才能訪問; 2. window程式員天生對命令行操作陌生。3. 好多資料都是linux 等等..... 下麵我們來一起安裝部署下。 一, 安裝環 ...
  • 0. 前言 在前一篇中我們講到了Dapper的應用,但是給我們的感覺Dapper不像個ORM更像一個IDbConnection的擴展。是的,沒錯。在實際開發中我們經常用Dapper作為對EF Core的補充。當然了Dapper並不僅僅只有這些,就讓我們通過這一篇文章去讓Dapper更像一個ORM吧。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...