如何用Qt连接数据库并导入文件?

如何用Qt连接数据库并导入文件?,第1张

可以使用QT自带的数据库完成 *** 作,以下是参考代码:

QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE")   //添加数据库

db.setDatabaseName("note.db")    //创建一个note.db的文件存储数据

db.open()  //开启数据库

query = QSqlQuery(db) //获得访问数据库的query

query.exec(XXX)  //执行指令(XXX为SQL指令)

db.close()  //关闭数据库

一般而言会将db变量作为全局变量或者数据成员,当需要访问的时候就获取一个query就可以了。

要实现所提到的功能,要好好看看QString、QStringList,这两玩意主要是临时存放数据、分割数据等作用,另外,要看QFile、QDir、QFileInfo、QTextStream,这四个主要用来读取文本数据。看看QVector或者QList等来存放读出来的数据。

另外,要实现这玩意,SQL的语句不要求精通,但是基本的Create、Insert、Select、Delete等 *** 作要准确无误。否则出错了QT是看不出来的。QT不会检测SQL的准确性的。

1:windows 下登陆mysql 命令行,(1)进入cmd (2) cdmysql 安装路径/mysqlserver5.6/bin

(3) 使用命令mysql -u root -p 然后根据提示输入密码 进入命令行

select user() //显示当前用户

2: 在同一台电脑上利用Qt 访问数据库

(1)显示当前电脑上安装的数据库驱动

QStringList drivers = QSqlDatabase::drivers()

foreach(QString driver, drivers)

qDebug() <<"/t" <<driver

(2)QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL")/对 QMYSQL进行 *** 作,本函数

有第二个参数 连接名

db.setHostName("localhost")//或127.0.0.1 本主机

db.setPort(3306)

db.setDatabaseName("example")//对数据库example进行 *** 作

db.setUserName("wangxuetao") //wangxuetao是一个对example数据库有 *** 作权限的账户

db.setPassword("3791948")

于是mysql中增加一个账户可使用

Grant all previliges on *.* to ‘wangxuetao’@’localhost’ identified by

‘3791948’ with grant option

Flush privileges//更新

(3)db.open() 函数可由于检测数据库是否连接成功

cout<DBConnection()

2. m_sqlquery = new QSqlQuery("",m_sqldb)//statement 1:connect db with sql

query

3. if(result == R_OK)

4. {

5. result = m_sqlquery->exec("INSERT INTO children(fname,age) VALUES('A

nn2',13)")

6. if(!result)

7. qDebug()<<" [OK] "<<"EXEC successed"

8. m_sqlquery->exec("SELECT * FROM children c LIMIT 0,1000")

9. while(m_sqlquery->next())

10. {

11. qDebug()<value(0).toString()<value(1).

toString()

12. }

13. }

这里有一个,记得给分哟!

#include <stdio.h>

#include <string.h>

#include <stdlib.h>

#define NAME_MAX 100//书的名字的最长字数

#define WRITER_MAX 100//作者名字的最长

#define PUB_MAX 100//出版单位最长名字

#define TIME 100//出版时间

typedef struct books

{

intloading

char name[NAME_MAX]

char writer[WRITER_MAX]

intidentify

char pub[PUB_MAX]

char time[TIME]

intprice

struct books * next

}book

//头结点不存储信息

void Init(book * head)

{

head->next=NULL

}

//打印一些欢迎词之类的。。。。。

void welcome()

{

printf("******欢迎使用@@@@图书馆,哈哈*********\n")

printf("\n\n")

printf("1:图书信息录入功能\n")

printf("2:图书信息浏览功能,显示该书的所有信息\n")

printf("3:图书信息查询功能:按书名查询与按作者名查询\n")

printf("4:图书信息的修改和删除,可对相应数据进行修改和删除\n")

}

//显示一本书的信息

void print_the_book(book * p1)

{

printf("loading number:%d \n",p1->loading)

printf("name: ")

puts(p1->name)

printf(" \n")

printf("writer: ")

puts(p1->writer)

printf(" \n")

printf("identify:%d ***\n",p1->identify)

printf(" \n")

printf("pub: ")

puts(p1->pub)

printf(" \n")

printf("time: ")

puts(p1->time)

printf(" \n")

printf("price:%d ***\n",p1->price)

}

int chongfu(book * head,book * p)

{

book * p1=head->next

int a=0

while(p1!=NULL)

{

if(strcmp(p1->name,p->name)==0)

{

if(strcmp(p1->writer,p->writer)==0)

{

a=1

break

}

}

else

p1=p1->next

}

return a

}

//录入一些信息。。。。

void luru(book * head)

{

book * p1=head

book * p2

//寻找NULL前的那个点

while(p1->next!=NULL)

{

p1=p1->next

}

int a

do

{

p2=(book *)malloc(sizeof(book))

printf("输入书本信息\n")

printf("登录号\n")

fflush(stdin)

scanf("%d",&p2->loading)

printf("书名\n")

fflush(stdin)

gets(p2->name)

fflush(stdin)

printf("作者\n")

gets(p2->writer)

fflush(stdin)

printf("分类号\n")

scanf("%d",&p2->identify)

fflush(stdin)

printf("出版社\n")

gets(p2->pub)

fflush(stdin)

printf("出版时间\n")

gets(p2->time)

fflush(stdin)

printf("价格\n")

scanf("%d",&p2->price)

p2->next=NULL

fflush(stdin)

//加入链表

if(chongfu(head,p2))

printf("录入信息重复\n")

else

{

p1->next=p2

p1=p2

}

printf("还想继续录入信息吗?\n(1:继续 0:停止)\n")

scanf("%d",&a)

}while(a==1)

}

void liulan(book * head)

{

book * p1=head->next

int i=1

while(p1!=NULL)

{

printf("*********第%d本书***********\n",i++)

print_the_book(p1)

p1=p1->next

}

}

//查询。。。。

void chaxun(book * head)

{

printf("按书名查询还是按作者名查询?\n(1:按书名查询 0:按作者名查询)\n")

book * p=head->next

int a

scanf("%d",&a)

int num=0

char cha[NAME_MAX]

switch(a)

{

case 1:

printf("输入书名:\n")

gets(cha)

while(p!=NULL)

{

if(strcmp(p->name,cha)==0)

{

num++

print_the_book(p)

}

p=p->next

}

break

case 2:

printf("输入作者名:\n")

gets(cha)

while(p!=NULL)

{

if(strcmp(p->writer,cha)==0)

{

num++

print_the_book(p)

}

p=p->next

}

}

if(num==0)

printf("无符合书本\n")

}

//修改信息

void xiugai(book * head)

{

printf("输入需要修改书本的名称和作者:\n")

char name_book[NAME_MAX]

char writer_book[WRITER_MAX]

printf("书本名称:")

gets(name_book)

gets(writer_book)

book * p1=head->next

int a=0

while(p1!=NULL)

{

if(strcmp(p1->name,name_book)==0)

{

if(strcmp(p1->writer,writer_book)==0)

{

a=1

break

}

}

}

if(a==0)

printf("没有这本书。。。\n")

else

{

print_the_book(p1)

printf("输入新信息\n")

scanf("%d",&p1->loading)

gets(p1->name)

gets(p1->writer)

scanf("%d",&p1->identify)

gets(p1->pub)

gets(p1->time)

scanf("%d",&p1->price)

}

}

void main()

{

book * head

head=(book *)malloc(sizeof(book))

Init(head)

int contin=1

while(contin)

{

welcome()

printf("想进行哪项 *** 作?\n")

int a

scanf("%d",&a)

switch(a)

{

case 1:

luru(head)

break

case 2:

liulan(head)

break

case 3:

chaxun(head)

break

case 4:

xiugai(head)

}

printf("继续使用图书馆还是退出?\n(1:continue 0:exit)\n")

scanf("%d",&contin)

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9522608.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-29
下一篇2023-04-29

发表评论

登录后才能评论

评论列表(0条)

    保存