作者:奋斗ing丶孩子
转自:http://blog.sina.com.cn/s/blog_a6fb6cc90101gx30.html
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
代码如下:
//添加数据库驱动、设置数据库名称、数据库登录用户名、密码QSqlDatabase database =QSqlDatabase::addDatabase("QSQLITE");
//打开数据库if(!database.open()){
QString create_sql = "create table student (id int primarykey, name varchar(30), age int)";QString select_max_sql = "select max(id) from student";QString insert_sql = "insert into student values (?, ?,?)";QString update_sql = "update student set name = :name where id= :id";QString select_sql = "select id, name from student";QString select_all_sql = "select * from student";QString delete_sql = "delete from student where id = ?";QString clear_sql = "delete from student";
sql_query.prepare(create_sql);if(!sql_query.exec()){qDebug()<<sql_query.lastError();}else{qDebug()<<"table created!";}
//查询最大idint max_id = 0;sql_query.prepare(select_max_sql);if(!sql_query.exec()){qDebug()<<sql_query.lastError();}else{while(sql_query.next()){max_id = sql_query.value(0).toInt();qDebug()<<QString("max id:%1").arg(max_id);}}//插入数据sql_query.prepare(insert_sql);sql_query.addBindValue(max_id+1);sql_query.addBindValue("name");sql_query.addBindValue(25);if(!sql_query.exec()){qDebug()<<sql_query.lastError();}else{qDebug()<<"inserted!";}
//更新数据sql_query.prepare(update_sql);sql_query.bindValue(":name", "Qt");sql_query.bindValue(":id", 1);if(!sql_query.exec()){qDebug()<<sql_query.lastError();}else{qDebug()<<"updated!";}
//查询部分数据if(!sql_query.exec(select_sql)){qDebug()<<sql_query.lastError();}else{while(sql_query.next()){int id = sql_query.value("id").toInt();QString name = sql_query.value("name").toString();
qDebug()<<QString("id:%1
//查询所有数据sql_query.prepare(select_all_sql);if(!sql_query.exec()){qDebug()<<sql_query.lastError();}else{while(sql_query.next()){int id = sql_query.value(0).toInt();QString name = sql_query.value(1).toString();int age = sql_query.value(2).toInt();
qDebug()<<QString("id:%1
//删除数据sql_query.prepare(delete_sql);sql_query.addBindValue(max_id);if(!sql_query.exec()){qDebug()<<sql_query.lastError();}else{qDebug()<<"deleted!";}
//清空表sql_query.prepare(clear_sql);if(!sql_query.exec()){qDebug()<<sql_query.lastError();}else{qDebug()<<"cleared";}}
//关闭数据库database.close();
//删除数据库QFile::remove("database.db");
可以通过一些工具对SQLite进行管理,如下:
SQLite的管理管理工具挺多的,这里简单介绍几款:
- SQLiteManager:开放源代码的SQLite管理工具,用来管理本地电脑上的SQLite数据库,可以独立运行(以XULRunner方式),也可以作为Firefox、Thunderbird、Seamonkey、Songbird、Komodo、Gecko等的插件。
- SQLiteAdministrator:一个用来管理SQLite数据库文件的图形化工具,可进行创建、设计和管理操作。提供代码编辑器具有自动完成和语法着色,支持中文,适合初学者。
- SQLite Databasebrowser:一个SQLite数据库的轻量级GUI客户端,基于Qt库开发,界面清洁,操作简单,主要是为非技术用户创建、修改和编辑SQLite数据库的工具,使用向导方式实现。
更多关于SQLite的介绍与使用,请参考:
注: