
可以使用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)
}
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)