網(wǎng)站首頁 編程語言 正文
Qt 創(chuàng)建 SQlite數(shù)據(jù)庫
void Widget::initDB()
{
// 創(chuàng)建并打開數(shù)據(jù)庫
QSqlDatabase database;
database = QSqlDatabase::addDatabase("QSQLITE");
// qDebug() << QApplication::applicationDirPath(); // 獲取應(yīng)用程序當(dāng)前目錄
database.setDatabaseName("test.sqlite3");
if(!database.open())
{
qDebug() << "Error: Failed to connect database." << database.lastError();
}
else
{
qDebug() << "Succeed to connect database.";
}
// 創(chuàng)建表格
QSqlQuery sql_query = database.exec("DROP TABLE student");
// 先清空一下表,可按需添加此句
// sql_query.exec("DROP TABLE student");
// 創(chuàng)建表格student
if(!sql_query.exec("create table student(UserId int primary key, UserName text, PassWord text)"))
{
qDebug() << "Error: Fail to create table." << sql_query.lastError();
}
else
{
qDebug() << "Table created!";
}
// 填充表
if(!sql_query.exec("INSERT INTO student VALUES(1, 'AppleCai', '23')"))
{
qDebug() << "Error: Fail to create table." << sql_query.lastError();
}
else
{
qDebug() << "add one created!";
}
// 批量填充表
QStringList names;
names << "小A" << "小B" << "小C" << "小D" << "小E" << "小F" << "小G" << "小H" << "小I";
QStringList password;
password << "12" << "23" << "34" << "45" << "56" << "67" << "78" << "89" << "90";
// 綁定關(guān)鍵字后才能進行操作
sql_query.prepare("INSERT INTO student (UserId, UserName, PassWord) "
"VALUES (:UserId, :UserName, :PassWord)");
qint8 i = 0;
foreach (QString name, names) // 從names表里獲取每個名字
{
sql_query.bindValue(":UserId", i+2); // 向綁定值里加入名字
sql_query.bindValue(":UserName", name); // 成績
sql_query.bindValue(":PassWord", password[i]); // 班級
if(!sql_query.exec())
{
qDebug() << "Error: Fail." << sql_query.lastError();
}
i++;
}
// 讀取sqlite
studentInfo tmp;
QVector<studentInfo> infoVect; // 數(shù)據(jù)庫緩存
sql_query.exec("SELECT * FROM student WHERE UserId >= 5 AND UserId <= 9;");
while (sql_query.next())
{
tmp.UserId = sql_query.value(0).toInt();
tmp.UserName = sql_query.value(1).toString();
tmp.Password = sql_query.value(2).toString();
qDebug() << tmp.UserId << tmp.UserName << tmp.Password;
infoVect.push_back(tmp);
}
qDebug("done");
// 更改表中數(shù)據(jù)
sql_query.prepare("UPDATE student SET PassWord = 'admin' WHERE UserName = 'AppleCai'");
if(!sql_query.exec())
{
qDebug() << "Error: Fail." << sql_query.lastError();
}
// 刪除表中數(shù)據(jù)
sql_query.prepare("DELETE FROM student WHERE UserName = '小H'");
if(!sql_query.exec())
{
qDebug() << "Error: Fail." << sql_query.lastError();
}
}
以下是個人代碼備份
這個代碼是在qt寫的,包含了數(shù)據(jù)庫的創(chuàng)建和寫入,但是我在項目準(zhǔn)備直接在dataGrip把數(shù)據(jù)一鍵導(dǎo)入創(chuàng)建好數(shù)據(jù)庫之后再用qt里面的sql語句讀,所以就不需要這一部分了
#include "sqlitedatabase.h"
SqliteDatabase::SqliteDatabase()
{
qDebug() << "hhh";
// initPickNameDB();
}
void SqliteDatabase::initPickNameDB()
{
// 創(chuàng)建并打開數(shù)據(jù)庫
QSqlDatabase database;
database = QSqlDatabase::addDatabase("QSQLITE");
// qDebug() << QApplication::applicationDirPath();
database.setDatabaseName(QApplication::applicationDirPath() + "/CONFIG/" + "PickNameDB.sqlite3");
if(!database.open())
{
qDebug() << "Error: Failed to connect database." << database.lastError();
}
else
{
qDebug() << "Succeed to connect database.";
}
// 創(chuàng)建表格 先清空一下表
QSqlQuery sql_query = database.exec("DROP TABLE department");
sql_query = database.exec("DROP TABLE person");
if(!sql_query.exec("create table department (Id int primary key not null, "
"DeptName vchar(50) not null )"))
{
qDebug() << "Error: Fail to create department table." << sql_query.lastError();
}
else
{
qDebug() << "Department table created!";
}
if(!sql_query.exec("create table person (Id int primary key not null , "
"DeptID integer not null , "
"PerName vchar(50) not null, "
"foreign key(DeptID) references department (Id))"))
{
qDebug() << "Error: Fail to create person table." << sql_query.lastError();
}
// 填充表
// sql_query.exec("insert into department (id, name) values (1, '辦領(lǐng)導(dǎo)')");
// sql_query.exec("insert into department (id, name) values (2, '綜合處')");
// sql_query.exec("insert into department (id, name) values (3, '政策法規(guī)處')");
// sql_query.exec("insert into department (id, name) values (4, '機構(gòu)改革處')");
// sql_query.exec("insert into department (id, name) values (5, '黨群政法行政機構(gòu)編制管理處')");
// sql_query.exec("insert into department (id, name) values (6, '政府行政機構(gòu)編制管理處')");
// sql_query.exec("insert into department (id, name) values (7, '市縣行政機構(gòu)編制管理處')");
// sql_query.exec("insert into department (id, name) values (8, '事業(yè)機構(gòu)編制管理處')");
// sql_query.exec("insert into department (id, name) values (9, '事業(yè)單位登記管理處')");
// sql_query.exec("insert into department (id, name) values (10, '機構(gòu)編制監(jiān)督檢查處')");
// sql_query.exec("insert into department (id, name) values (11, '人事處')");
// sql_query.exec("insert into department (id, name) values (12, '機關(guān)黨委')");
// sql_query.exec("insert into department (id, name) values (13, '省機構(gòu)編制電子政務(wù)中心')");
// sql_query.exec("insert into department (id, name) values (14, '省機構(gòu)編制研究中心')");
// 批量填充表
QStringList deptNames;
deptNames << "辦領(lǐng)導(dǎo)" << "綜合處" << "政策法規(guī)處" << "機構(gòu)改革處"
<< "黨群政法行政機構(gòu)編制管理處" << "政府行政機構(gòu)編制管理處"
<< "市縣行政機構(gòu)編制管理處" << "事業(yè)機構(gòu)編制管理處" << "事業(yè)單位登記管理處"
<< "機構(gòu)編制監(jiān)督檢查處" << "人事處" << "機關(guān)黨委"
<< "省機構(gòu)編制電子政務(wù)中心" << "省機構(gòu)編制研究中心";
// 綁定關(guān)鍵字后才能進行操作
sql_query.prepare("INSERT INTO department (Id, DeptName) "
"VALUES (:Id, :DeptName)");
qint8 i = 0;
foreach (QString deptName, deptNames)
{
sql_query.bindValue(":Id", i + 1);
sql_query.bindValue(":DeptName", deptName);
if(!sql_query.exec())
{
qDebug() << "Error: Fail." << sql_query.lastError();
}
i++;
}
// 讀取sqlite
department dept;
QVector<department> tmpDept; // 數(shù)據(jù)庫緩存
sql_query.exec("SELECT * FROM ");
}
原文鏈接:https://blog.csdn.net/weixin_43232564/article/details/123724923
相關(guān)推薦
- 2022-06-13 python語法?之垃圾回收機制_python
- 2023-02-06 Go語言基礎(chǔ)學(xué)習(xí)之指針詳解_Golang
- 2022-06-21 C++分析講解類的靜態(tài)成員函數(shù)如何使用_C 語言
- 2022-07-09 Android開發(fā)Dart?Constructors構(gòu)造函數(shù)使用技巧整理_Android
- 2022-09-08 返回最大值的index?pytorch方式_python
- 2022-12-24 C語言中的逗號運算符詳解_C 語言
- 2022-10-29 C#?CLR學(xué)習(xí)?C++使用namespace實例詳解_C 語言
- 2023-02-28 ts之定義對象高級使用 Record
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支