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();
相关文章
|
2月前
|
关系型数据库 MySQL 数据库
MySQL技能完整学习列表——1、数据库基础概念——2、数据库管理系统(DBMS)——3、数据模型(Data Model)
MySQL技能完整学习列表——1、数据库基础概念——2、数据库管理系统(DBMS)——3、数据模型(Data Model)
26 0
|
12月前
|
消息中间件 JavaScript 小程序
干掉 powerdesigner,设计数据库表用它就够了!
干掉 powerdesigner,设计数据库表用它就够了!
|
SQL 关系型数据库 MySQL
Python编程:MySQLdb模块对数据库的基本增删改查操作
Python编程:MySQLdb模块对数据库的基本增删改查操作
101 1
|
SQL 关系型数据库 MySQL
软件开发入门教程网之MySQL 删除数据表
软件开发入门教程网之MySQL 删除数据表
|
Oracle 关系型数据库 MySQL
系统设计与数据库原理 作业四 Data Modelling using PowerDesigner
系统设计与数据库原理 作业四 Data Modelling using PowerDesigner
86 0
系统设计与数据库原理 作业四 Data Modelling using PowerDesigner
|
SQL 关系型数据库 MySQL
软件测试mysql面试题:为什么要使用视图?什么是视图?
软件测试mysql面试题:为什么要使用视图?什么是视图?
89 0
|
存储 关系型数据库 MySQL
Mysql数据目录(1)---数据库结构(二十四)
Mysql数据目录(1)---数据库结构(二十四)
|
关系型数据库 MySQL 测试技术
软件测试mysql面试题:如何重命名表?
软件测试mysql面试题:如何重命名表?
57 0
|
关系型数据库 MySQL 数据库
《MySQL数据操作与查询》- 返校复习课练习题,创建数据库user_system,创建数据表user及user_ext
《MySQL数据操作与查询》- 返校复习课练习题,创建数据库user_system,创建数据表user及user_ext
196 0
《MySQL数据操作与查询》- 返校复习课练习题,创建数据库user_system,创建数据表user及user_ext