欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Qt使用SQLite數(shù)據(jù)庫(kù)存儲(chǔ)管理圖片文件

 更新時(shí)間:2023年04月14日 10:50:30   作者:歐特克_Glodon  
這篇文章主要為大家詳細(xì)介紹了Qt如何使用SQLite數(shù)據(jù)庫(kù)實(shí)現(xiàn)存儲(chǔ)管理圖片文件的功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下

1、效果演示

1)增刪改查效果

2)數(shù)據(jù)庫(kù)內(nèi)容

2、創(chuàng)建數(shù)據(jù)庫(kù)及表格

2.1 創(chuàng)建數(shù)據(jù)庫(kù)

首先在.pro文件添加對(duì)sql的支持:QT += core gui sql

QString g_connectName = "mySQL_connection";

bool MainWindow::createDatabase()
{
    //檢測(cè)已連接的方式 - 自定義連接名
    if(QSqlDatabase::contains(g_connectName))
    {
        m_Projdb = QSqlDatabase::database(g_connectName);
    }
    else
    {
        m_Projdb = QSqlDatabase::addDatabase("QSQLITE",g_connectName);

        //設(shè)置數(shù)據(jù)庫(kù)路徑
        QString sDir = QApplication::applicationDirPath();
        QString sDataPath = sDir + "/mySql.db";
        m_Projdb.setDatabaseName(sDataPath);
    }

    //打開數(shù)據(jù)庫(kù)
    if(!m_Projdb.open())
    {
        QMessageBox::information(this,"提示","數(shù)據(jù)庫(kù)創(chuàng)建失敗,無法打開!");
        return false;
    }

	// 創(chuàng)建表格
    createImageTable();

    //關(guān)閉數(shù)據(jù)庫(kù)
    m_Projdb.close();

    return true;
}

2.2 創(chuàng)建數(shù)據(jù)庫(kù)表格

bool MainWindow::createImageTable()
{
     …………………………
     
    //如果不存在則創(chuàng)建my_table表,id自增,name唯一
    const QString cmdSql = R"(
                           CREATE TABLE IF NOT EXISTS image_table (
                           id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
                           imagename TEXT NOT NULL,
                           type CHAR(50) NOT NULL,
                           notes TEXT,
                           imagedata BLOB NOT NULL
                           );)";

    //QSqlQuery構(gòu)造前,需要db已打開并連接;未指定db或者db無效時(shí)使用默認(rèn)連接進(jìn)行操作
    QSqlQuery myQuery(m_Projdb);

    if(!myQuery.exec(cmdSql))
    {
        QString sError = myQuery.lastError().text();
        sError = "數(shù)據(jù)庫(kù)表格插入數(shù)據(jù)失敗:" + sError;
        QMessageBox::information(this,"提示",sError);
        m_Projdb.close();
        return false;
    }

     …………………………
     

    return true;
}

3、增刪改查

3.1 增加記錄

void MainWindow::on_pushBtn_add_clicked()
{
    QString strImag = ui->lineEdit_file->text();
    QFileInfo fileInfo(strImag);
    ………………
    QString sName = fileInfo.fileName();
    QString sType = fileInfo.suffix();
    QString strNote = ui->plainTextEdit_add->toPlainText();

    if(ImageFileExist(sName))
    {
        QMessageBox::information(this,"提示","圖片文件已經(jīng)存在!");
        return;
    }

	//將數(shù)據(jù)轉(zhuǎn)換為QByteArray類型存儲(chǔ)到數(shù)據(jù)庫(kù)中
    QFile* pFile = new QFile(strImag);
    pFile->open(QIODevice::ReadOnly);
    
    QByteArray imageData = pFile->readAll();
    pFile->fileName();
    pFile->close();
    if(!m_Projdb.open())
    {
        QMessageBox::information(this,"提示","數(shù)據(jù)庫(kù)無法打開!");
        return;
    }
    //QSqlQuery構(gòu)造前,需要db已打開并連接;未指定db或者db無效時(shí)使用默認(rèn)連接進(jìn)行操作
    QSqlQuery myQuery(m_Projdb);
    QString cmdSql = "insert into image_table(imagename,type,notes,imagedata) values( '%1','%2','%3',:imagedata)";
    cmdSql = QString(cmdSql).arg(sName).arg(sType).arg(strNote);
    qDebug() << cmdSql;
    myQuery.prepare(cmdSql);
    myQuery.bindValue(":imagedata",imageData);
    if(!myQuery.exec())
    {
        QString sError = myQuery.lastError().text();
        sError = "數(shù)據(jù)庫(kù)表格插入數(shù)據(jù)失敗:" + sError;
        QMessageBox::information(this,"提示",sError);
        m_Projdb.close();
        return;
    }

    QMessageBox::information(this,"提示","添加成功!");

    m_Projdb.close();

    // 刷新界面
    …………………………
}

3.2 刪除記錄

void MainWindow::on_pushBtn_del_clicked()
{
    …………………………
    //QSqlQuery構(gòu)造前,需要db已打開并連接;未指定db或者db無效時(shí)使用默認(rèn)連接進(jìn)行操作
    QSqlQuery myQuery(m_Projdb);
    QString cmdSql = "DELETE from image_table where imagename = '%1'";
    cmdSql = QString(cmdSql).arg(sFileName);

    qDebug() << cmdSql;

    if(!myQuery.exec(cmdSql))
    {
        QString sError = myQuery.lastError().text();
        sError = "數(shù)據(jù)庫(kù)表格刪除數(shù)據(jù)失敗:" + sError;
        QMessageBox::information(this,"提示",sError);
        m_Projdb.close();
        return;
    }
    …………………………
    // 刷新界面
    ………………………………
}

3.3 修改記錄

void MainWindow::on_pushBtn_modify_clicked()
{
    ……………………
    
    QString sNote = dlg.GetNoteString();
    QSqlQuery myQuery(m_Projdb);
    QString cmdSql = "UPDATE image_table SET notes = '%2' where imagename = '%1'";
    cmdSql = QString(cmdSql).arg(sFileName).arg(sNote);

    …………………………

    // 刷新界面
    …………………………
}

3.4 查找記錄

void MainWindow::on_pushBtn_preview_clicked()
{
     ………………………………
    //QSqlQuery構(gòu)造前,需要db已打開并連接;未指定db或者db無效時(shí)使用默認(rèn)連接進(jìn)行操作
    QSqlQuery myQuery(m_Projdb);
    QString cmdSql = "select * from image_table where imagename = '%1'";
    cmdSql = QString(cmdSql).arg(sFileName);

    qDebug() << cmdSql;

    if(!myQuery.exec(cmdSql))
    {
        QString sError = myQuery.lastError().text();
        sError = "數(shù)據(jù)庫(kù)表格查詢數(shù)據(jù)失敗:" + sError;
        QMessageBox::information(this,"提示",sError);
        m_Projdb.close();
        return;
    }

    while (myQuery.next())
    {
        QString strFileName = myQuery.value(1).toString();
        QString strFileType = myQuery.value(2).toString();
        QString strNote = myQuery.value(3).toString();

        QByteArray bytes = myQuery.value(4).toByteArray();
        QBuffer buffer(&bytes);
        buffer.open(QIODevice::ReadOnly);
        QImageReader reader(&buffer,strFileType.toLatin1());
        QImage img = reader.read();
        img.save(strFileName);
        break;
    }

    m_Projdb.close();
}

3.5 遍歷表格記錄

bool MainWindow::GetAllImageRecord()
{
     ………………………………
    
    // 查詢表格數(shù)據(jù)
    const QString cmdSql = R"(SELECT * FROM image_table;)";

    //QSqlQuery構(gòu)造前,需要db已打開并連接;未指定db或者db無效時(shí)使用默認(rèn)連接進(jìn)行操作
    QSqlQuery myQuery(m_Projdb);
    if(!myQuery.exec(cmdSql))
    {
        QString sError = myQuery.lastError().text();
        sError = "數(shù)據(jù)庫(kù)表格插入數(shù)據(jù)失敗:" + sError;
        QMessageBox::information(this,"提示",sError);
        m_Projdb.close();
        return false;
    }

    while (myQuery.next())
    {
        QString sFileName, sFileType,sNotes;

        for (int i = 0; i < myQuery.record().count(); i++)
        {
            QString strFieldName = myQuery.record().fieldName(i);
            QVariant value = myQuery.record().value(i);
            if(strFieldName == "imagename")
            {
                QString strValue = value.toString();
                sFileName = strValue;
            }
            if(strFieldName == "type")
            {
                QString strValue = value.toString();
                sFileType = strValue;
            }
            if(strFieldName == "notes")
            {
                QString strValue = value.toString();
                sNotes = strValue;
            }
        }

		if (!sFileName.isEmpty() && !sFileType.isEmpty())
		{
			FileInfo fileInfo;
			fileInfo.sName = sFileName;
			fileInfo.sType = sFileType;
            fileInfo.sNotes = sNotes;
			m_vecImageFile.push_back(fileInfo);
		}
    }

   …………………………
   
}

到此這篇關(guān)于Qt使用SQLite數(shù)據(jù)庫(kù)存儲(chǔ)管理圖片文件的文章就介紹到這了,更多相關(guān)Qt SQLite管理圖片文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C/C++ Qt 基本文件讀寫的基本使用(2種實(shí)現(xiàn))

    C/C++ Qt 基本文件讀寫的基本使用(2種實(shí)現(xiàn))

    文件的讀寫是很多應(yīng)用程序具有的功能,本文主要介紹了兩種實(shí)現(xiàn)方法,第一種使用QFile類的IODevice讀寫功能直接讀寫,第二種是利用 QFile和QTextStream結(jié)合起來,用流的方式進(jìn)行文件讀寫
    2021-11-11
  • 利用Matlab復(fù)刻掃雷小游戲

    利用Matlab復(fù)刻掃雷小游戲

    windows自帶的游戲《掃雷》是陪伴了無數(shù)人的經(jīng)典游戲,本程序參考《掃雷》的規(guī)則進(jìn)行了簡(jiǎn)化,用Matlab實(shí)現(xiàn),感興趣的小伙伴可以學(xué)習(xí)一下
    2022-03-03
  • Matlab實(shí)現(xiàn)簡(jiǎn)易紀(jì)念碑谷游戲的示例代碼

    Matlab實(shí)現(xiàn)簡(jiǎn)易紀(jì)念碑谷游戲的示例代碼

    《紀(jì)念碑谷》是USTWO公司開發(fā)制作的解謎類手機(jī)游戲,在游戲中,通過探索隱藏小路、發(fā)現(xiàn)視力錯(cuò)覺以及躲避神秘的烏鴉人來幫助沉默公主艾達(dá)走出紀(jì)念碑迷陣。本文將用Matlab編寫簡(jiǎn)易版的紀(jì)念碑谷游戲,感興趣的可以了解一下
    2022-03-03
  • C/C++編譯器GCC下的常用編譯命令總結(jié)

    C/C++編譯器GCC下的常用編譯命令總結(jié)

    這篇文章主要介紹了C/C++編譯器GCC下的常用編譯命令總結(jié),本文的示例環(huán)境為L(zhǎng)inux系統(tǒng),需要的朋友可以參考下
    2015-08-08
  • C++泛型編程基本概念詳解

    C++泛型編程基本概念詳解

    這一篇介紹一下 C++ 編程中與面向?qū)ο蟛⒘械牧硪淮蠓种А盒途幊?,這一篇主要介紹函數(shù)模板、類模板和成員模板三大部分,需要的朋友可以參考下
    2021-08-08
  • c++11 新特性——智能指針使用詳解

    c++11 新特性——智能指針使用詳解

    這篇文章主要介紹了c++11 新特性——智能指針使用的相關(guān)資料,幫助大家更好的理解和使用c++,感興趣的朋友可以了解下
    2021-02-02
  • 一篇文章帶你了解C語(yǔ)言二分查找

    一篇文章帶你了解C語(yǔ)言二分查找

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言二分查找法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Qt定時(shí)器和隨機(jī)數(shù)詳解

    Qt定時(shí)器和隨機(jī)數(shù)詳解

    在前一篇中我們介紹了鍵盤和鼠標(biāo)事件,其實(shí)還有一個(gè)非常常用的事件,就是定時(shí)器事件,如果要對(duì)程序?qū)崿F(xiàn)時(shí)間上的控制,那么就要使用到定時(shí)器。而隨機(jī)數(shù)也是很常用的一個(gè)功能,在我們要想產(chǎn)生一個(gè)隨機(jī)的結(jié)果時(shí)就要使用到隨機(jī)數(shù)。本文我們就來簡(jiǎn)單介紹一下定時(shí)器和隨機(jī)數(shù)。
    2015-06-06
  • C語(yǔ)言實(shí)現(xiàn)俄羅斯方塊小游戲

    C語(yǔ)言實(shí)現(xiàn)俄羅斯方塊小游戲

    這篇文章主要為大家詳細(xì)介紹了Linux下C語(yǔ)言實(shí)現(xiàn)俄羅斯方塊小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • C++求1到n中1出現(xiàn)的次數(shù)以及數(shù)的二進(jìn)制表示中1的個(gè)數(shù)

    C++求1到n中1出現(xiàn)的次數(shù)以及數(shù)的二進(jìn)制表示中1的個(gè)數(shù)

    這篇文章主要介紹了C++求1到n中1出現(xiàn)的次數(shù)以及數(shù)的二進(jìn)制表示中1的個(gè)數(shù),兩道基礎(chǔ)的算法題目,文中也給出了解題思路,需要的朋友可以參考下
    2016-02-02

最新評(píng)論