Ubuntu 15 下 Qt 配置mysql链接及基本操作

来源:互联网 发布:长绸扇子淘宝 编辑:程序博客网 时间:2024/04/30 15:11

最近需要在Linux下做一个unix网络编程项目,选择了Ubuntu 最新版本15.04 :
开发环境:Qt 5
数据库: MySQL

安装Qt 和 MySQL

简要介绍一下软件的安装!

  1. 安装Qt命令sudo apt-get install qtcreator
  2. 安装MySQL,我是采用的软件中心选择的开发工具 包括 服务器、客户端、工作台三个软件;然后,在命令行配置root账户密码即可!
    默认的MySQL安装之后根用户是没有密码的,所以首先用根用户进入:

$mysql -u root

在这里之所以用-u root是因为我现在是一般用户(firehare),如果不加-u root的话,mysql会以为是firehare在登录。注意,我在这里没有进入根用户模式,因为没必要。一般来说,对mysql中的数据库进行操作,根本没必要进入根用户模式,只有在设置时才有这种可能。

进入mysql之后,最要紧的就是要设置Mysql中的root用户密码了,否则,Mysql服务无安全可言了。

mysql> GRANT ALL PRIVILEGES ON *.* TO root@localhost IDENTIFIED BY "123456";

注意,我这儿用的是123456做为root用户的密码,但是该密码是不安全的,请大家最好使用大小写字母与数字混合的密码,且不少于8位。

这样的话,就设置好了MySQL中的root用户密码了,然后就用root用户建立你所需要的数据库。

安装MySQL驱动

新建项目

在Qt中新建一个控制台项目,在main.cpp内添加代码:

#include <QCoreApplication>#include <QtSql/QSqlDatabase>#include <QtSql/QSqlDriver>#include <QtSql/QSqlQuery>#include <QDebug>int main(int argc, char *argv[]){    QCoreApplication a(argc, argv);    qDebug()<<"available drivers:";    QStringList drivers = QSqlDatabase::drivers();    foreach(QString driver, drivers)    qDebug()<<driver;    QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL");    db.setHostName("localhost");    db.setPort(3306);    db.setDatabaseName("EasyChat");    db.setUserName("root");    db.setPassword("123456");    if(!db.open()){        qDebug()<<"Unable to open database";    }else{        qDebug()<<"Database connection established";    }    return a.exec();}

另外,在.pro文件中添加:

QT       += sql

基本操作

插入语句

//用户注册对应的,插入用户数据int insert(const User &user){    //执行sql语句    QSqlQuery query;    QString sql = QObject::tr("insert into User(userId,nickname,password,state,registerTime)values('%1','%2','%3','%4','%5')").arg(user.userId)           .arg(user.nickname)           .arg(user.password)           .arg(user.state)           .arg(user.registerTime);    qDebug()<<sql;    bool ret = query.exec(sql);    qDebug()<<"插入操作结果ret = "<<ret;    if(ret)        return SUCCESS;    else        return FAILED;}

查询操作

这里写代码片
0 0