lesson14-数据库结构设计

简介: 一、概述 1、数据库概述 数据库也是应用程序的重要部分,一个完整的应用程序几乎都包含数据库 当前主流的数据库有DB2、MYSQL、OCI、ODBC、SQLITE、TDS、Oracle Sqlite是一款轻型的数据库,它的设计目标是嵌入式,方便我们使用   2、数据库操作语句 下载安装数据库 tar -xzvf .
一、概述
1、数据库概述
数据库也是应用程序的重要部分,一个完整的应用程序几乎都包含数据库
当前主流的数据库有DB2、MYSQL、OCI、ODBC、SQLITE、TDS、Oracle
Sqlite是一款轻型的数据库,它的设计目标是嵌入式,方便我们使用
 
2、数据库操作语句
下载安装数据库
tar -xzvf
./configure
make
make install

SELECT * FROM menu WHERE id>20
INSERT INTO menu VALUES(102, HELLO)
DELETE FROM menu WHERE name="wj"
UPDATE menu SET name="weijie" 


二、QSql
1、连接数据库
Qt中使用数据库模块,首先要在工程文件.pro中添加;
QT+=sql

使用QSqlDatabase类的addDatabase方法来连接数据库
QSqlDatabase db = QSqlDatabase::addDatabase("sqlite3", "wj");
第一个参数是驱动名,也就是我们的数据库类型;第二个参数是连接名

//设置数据库名
db.setDatabaseName("wj78080458");
//设置登录名和密码
db.setUserName("admin");
db.setPassword("123456");
//打开数据库
db.open(); 

2、操作
在QSql中的QSqlQuery类提供了一个执行sql语句的接口
QSqlQuery query;
query.exec(sql语句);

当执行完exec语句后,就会返回结果。当执行完查询语句时,记录会返回到第一条的前面,使用next函数可以移动记录指针,第一次调用的时候记录会移动到第一条,以后每次调用都会向后移动一步。
query.next();

使用value(int)函数可以取出每个字段的信息,它会返回一个QVariant类型的数据

可以使用isActive函数来检测执行的错误
if(!query.isActive())
  qDebug()

3、使用数据库模型
Qt提供了3个访问数据库的模型类
QSqlQueryModel基于任意sql语句的只读模型
QSqlTableModel基于表的读写模型
QSqlRelationalTableModel增加外键支持

QSqlQueryModel model;
model.setQuery("sql语句");
int num = model.record(2).value(No);
int num = model.data(model.index(2,4));


三、实例
connect.h

点击(此处)折叠或打开

  1. #ifndef CONNECTION_H
  2. #define CONNECTION_H

  3. #include QtSql>
  4. #include QSqlDatabase>

  5. static bool createConnection()
  6. {
  7.     QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
  8.     db.setDatabaseName("wj78080458");
  9.     if(!db.open())
  10.         return false;

  11.     QSqlQuery query;
  12.     query.exec("create table person(id int primary key, firstname varchar(20), lastname varchar(20))");
  13.     query.exec("insert into person values(101, 'wj', 'weijie')");
  14.     query.exec("insert into person values(102, 'dd', 'dddddd')");
  15.     query.exec("insert into person values(103, 'tl', 'tangliang')");
  16.     return true;
  17. }

  18. #endif
main.cpp

点击(此处)折叠或打开

  1. #include QCoreApplication>
  2. #include QtSql>

  3. int main(int argc, char *argv[])
  4. {
  5.     QCoreApplication app(argc, argv);

  6.     QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE","wj");
  7.     db.setDatabaseName("12345678");
  8.     db.setUserName("admin");
  9.     db.setPassword("admin");
  10.     if(!db.open())
  11.         qDebug()"open error";

  12.     QSqlQuery query(db);
  13.     query.exec("create table person(id int primary key, name varchar(30), sex varchar(8))");
  14.     query.exec("insert into person values(101, 'weijie', 'man')");
  15.     query.exec("insert into person values(103, 'wj', 'woman')");

  16.     query.exec("select * from person");
  17.     query.first();
  18.     qDebug()query.value(0);
  19.     qDebug()query.value(1);
  20.     qDebug()query.value(2);
  21.     query.next();
  22.     qDebug()query.value(0);
  23.     qDebug()query.value(1);
  24.     qDebug()query.value(2);

  25.     return 0;
  26. }



.lasterror().text();
相关文章
|
7月前
|
数据库
Google Earth Engine(GEE)——全球树木异体测量和树冠结构(Tallo)数据库
Google Earth Engine(GEE)——全球树木异体测量和树冠结构(Tallo)数据库
82 1
|
7月前
|
数据库
生成数据库结构文档
生成数据库结构文档
|
5月前
|
Oracle 关系型数据库 数据库连接
|
6月前
|
存储 关系型数据库 MySQL
|
6月前
|
SQL 运维 数据管理
数据管理DMS产品使用合集之如何修改在结构设计中的基准数据库
阿里云数据管理DMS提供了全面的数据管理、数据库运维、数据安全、数据迁移与同步等功能,助力企业高效、安全地进行数据库管理和运维工作。以下是DMS产品使用合集的详细介绍。
140 4
|
6月前
|
存储 关系型数据库 MySQL
MySQL数据库——InnoDB引擎-逻辑存储结构(表空间、段、区、页、行)
MySQL数据库——InnoDB引擎-逻辑存储结构(表空间、段、区、页、行)
128 7
|
6月前
|
存储 缓存 监控
如何设计数据库结构?
如何设计数据库结构?【6月更文挑战第9天】
61 3
|
6月前
|
缓存 关系型数据库 MySQL
MySQL数据库——InnoDB引擎-架构-内存结构(Buffer Pool、Change Buffer、Adaptive Hash Index、Log Buffer)
MySQL数据库——InnoDB引擎-架构-内存结构(Buffer Pool、Change Buffer、Adaptive Hash Index、Log Buffer)
101 3
|
6月前
|
存储 关系型数据库 MySQL
MySQL数据库——索引(2)-B+Tree、Hash结构,索引分类(聚集索引、二级索引)
MySQL数据库——索引(2)-B+Tree、Hash结构,索引分类(聚集索引、二级索引)
90 1
|
6月前
|
SQL 关系型数据库 数据建模
Dify数据库结构导出到PowerDesigner
Dify是开源大语言模型应用开发平台,助力快速构建生成式AI应用。PowerDesigner是SAP的企业级建模工具,用于数据建模、业务流程建模和企业架构规划。通过PostgreSQL的`pg_dump`导出表结构到SQL文件,然后在PowerDesigner中导入生成物理数据模型,从而实现Dify数据库结构到PowerDesigner的迁移。
180 1