關於c語言sqlite3blob的信息

本文目錄一覽:

sqlite3 blob數據讀取錯誤

sqlite3_bind_blob的第二個參數是從1開始的,所以content的索引為2,應該改為如下:

sqlite3_bind_blob(stmt1,2,buf,100,SQLITE_STATIC);

取數據也要改:

sendbuf= (char *)sqlite3_column_blob(stmt,1);

請教SQLite數據庫讀寫BLOB字段

SQLite中如何用api操作blob類型的字段

在實際的編程開發當中我們經常要處理一些大容量二進制數據的存儲,如圖片或者音樂等等。對於這些二進制數據(blob字段)我們不能像處理普通的文本那樣 簡單的插入或者查詢,為此SQLite提供了一組函數來處理這種BLOB字段類型。下面的代碼演示了如何使用這些API函數。

首先我們要建立一個數據庫:

sqlite3_exec(db, “CREATE TABLE list (fliename varchar(128) UNIQUE, fzip blob);”, 0, 0, zErrMsg);

//由於mmmm.rar是一個二進制文件,所以要在使用insert語句時先用?號代替

sqlite3_prepare(db, “insert into list values (‘mmmm.rar’,?);”, -1, stat, 0);

FILE *fp;

long filesize = 0;

char * ffile;

fp = fopen(“mmmm.rar”, “rb”);

if(fp != NULL)

{

//計算文件的大小

fseek(fp, 0, SEEK_END);

filesize = ftell(fp);

fseek(fp, 0, SEEK_SET);

//讀取文件

ffile = new char[filesize+1];

size_t sz = fread(ffile, sizeof(char), filesize+1, fp);

fclose(fp);

}

//將文件數據綁定到insert語句中,替換“?”部分

sqlite3_bind_blob(stat, 1, ffile, filesize, NULL);

使用jdbc連接sqlite3時,blob數據該怎麼存入取出

直接插入NSData類型char *buffer=new char[1024*1024]; //要放入的內容sqlite3_prepare( db, “insert into tb( ID, content) values( 10, ? )”, -1, stat, 0 );//準備插入數據sqlite3_bind_blob( stat, 1, buffer, strlen(buffer), NULL ); //把內容和字段綁定CLOB和BLOB類型被用來存放大對象。BOLB表示二進制大對象,這種數據類型通過用來保存圖片,圖象,視頻等。CLOB表示字符大對象,能夠存放大量基於字符的數據。

sqlite blob字段怎麼寫update

// 連接字符串 data source=d:\test.db3;password=1234

SQLiteConnectionStringBuilder connStr = new SQLiteConnectionStringBuilder();

connStr.DataSource = @”d:\test.db3″;

connStr.Password = “1234”;

conn = new SQLiteConnection(connStr.ToString());

conn.Open();

// 插入數據

string SQL = “INSERT INTO test(k) VALUES(:k)”;

SQLiteCommand cmd = conn.CreateCommand();

cmd.CommandText = SQL;

// 取圖標,準備插入到數據庫BLOB字段

FileStream picStream = File.OpenRead(@”d:\1.bmp”);

byte[] bArray = new byte[picStream.Length];

picStream.Read(bArray, 0, bArray.Length);

picStream.Close();

cmd.Parameters.Add(“k”, DbType.Binary).Value = bArray; // BLOB

cmd.ExecuteNonQuery();

//取出數據

cmd.CommandText = “SELECT k FROM test”;

System.Data.SQLite.SQLiteDataReader reader = cmd.ExecuteReader();

while (reader.Read())

{

MemoryStream streamImage = new MemoryStream(reader[“k”] as byte[]);

pictureBox1.Image = Image.FromStream(streamImage);

streamImage.Close(); // 關閉流

}

reader.close();

conn.close();

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/159403.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-19 18:59
下一篇 2024-11-19 18:59

相關推薦

  • AES加密解密算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演着非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29
  • Java 監控接口返回信息報錯信息怎麼處理

    本文將從多個方面對 Java 監控接口返回信息報錯信息的處理方法進行詳細的闡述,其中包括如何捕獲異常、如何使用日誌輸出錯誤信息、以及如何通過異常處理機制解決報錯問題等等。以下是詳細…

    編程 2025-04-29
  • Python語言由荷蘭人為中心的全能編程開發工程師

    Python語言是一種高級語言,很多編程開發工程師都喜歡使用Python語言進行開發。Python語言的創始人是荷蘭人Guido van Rossum,他在1989年聖誕節期間開始…

    編程 2025-04-28
  • Python語言設計基礎第2版PDF

    Python語言設計基礎第2版PDF是一本介紹Python編程語言的經典教材。本篇文章將從多個方面對該教材進行詳細的闡述和介紹。 一、基礎知識 本教材中介紹了Python編程語言的…

    編程 2025-04-28
  • Python語言實現人名最多數統計

    本文將從幾個方面詳細介紹Python語言實現人名最多數統計的方法和應用。 一、Python實現人名最多數統計的基礎 1、首先,我們需要了解Python語言的一些基礎知識,如列表、字…

    編程 2025-04-28
  • Python作為中心語言,在編程中取代C語言的優勢和挑戰

    Python一直以其簡單易懂的語法和高效的編碼環境而著名。然而,它最近的發展趨勢表明Python的使用範圍已經從腳本語言擴展到了從Web應用到機器學習等廣泛的開發領域。與此同時,C…

    編程 2025-04-28

發表回復

登錄後才能評論