Qt Creator 链接数据库mysql 的demo

                                                                        Qt Creator  链接数据库mysql 的demo

 

环境:ubuntu 10.10    Qt Creator      mysql5      qt4   以及相关的lib(这个问题困扰了不少家伙,我想如果用ubnuntu,这个问题应该不大)

本文假设你已经配置好了的情况下;

 

 

用向导建立一个 基于对话框的qt gui application

 

 

dialog 界面设计包括:

      一个textEdit(QTextEdit),用来显示信息,两个button(QPushButton),一个叫做 connect,一个叫做 close。

 

下面是头文件dialog.h

 

#ifndef DIALOG_H
#define DIALOG_H

#include <QDialog>
#include "QtSql"
#include "QSqlDatabase"
namespace Ui {
    class Dialog;
}

class Dialog : public QDialog
{
    Q_OBJECT

public:
    explicit Dialog(QWidget *parent = 0);
    ~Dialog();

private:
    Ui::Dialog *ui;
    QSqlDatabase db ;   //数据库链接

private slots:
    void on_close_clicked();
    void on_connect_clicked();
};

#endif // DIALOG_H

 

 

 

下面是dialog.cpp

#include "dialog.h"
#include "ui_dialog.h"
#include "QtSql"
#include "QString"

Dialog::Dialog(QWidget *parent) :
    QDialog(parent),
    ui(new Ui::Dialog)
{
    ui->setupUi(this);
    this->db= QSqlDatabase::addDatabase("QMYSQL");  //设置类型为QMYSQL 或者其它
    db.setDatabaseName("sgm");
    db.setHostName("127.0.0.1");
    db.setUserName("root");
    db.setPassword("123");
    ui->textEdit->setEnabled(false);
}

Dialog::~Dialog()
{
    delete ui;
}


void Dialog::on_connect_clicked()
{
    bool success = db.open() ;
    QString string  ;
    if(success)
    {
        string =QObject::tr("链接成功/t");

    }
    else
        {
            string =QObject::tr("失败/n");
        }
    ui->textEdit->setText(string);
}

void Dialog::on_close_clicked()
{
    db.close();
    QString string  ;
    string = QObject::tr("已经关闭/n");
    ui->textEdit->setText(string);
}

 

 


下面是main.cpp

#include <QtGui/QApplication>
#include "dialog.h"

int main(int argc, char *argv[])
{

    //设置编码格式,解决qt 中文乱码
    QTextCodec::setCodecForTr(QTextCodec::codecForName("UTF-8"));
    QTextCodec::setCodecForCStrings(QTextCodec::codecForName("UTF-8"));
    QTextCodec::setCodecForCStrings(QTextCodec::codecForName("UTF-8"));
    QApplication a(argc, argv);
    Dialog w;
    w.show();

    return a.exec();
}

 

 

下面附上 pro文件:

#-------------------------------------------------
#
# Project created by QtCreator 2010-11-30T17:03:34
#
#-------------------------------------------------

QT       += core gui sql

TARGET = connect
TEMPLATE = app


SOURCES += main.cpp/
        dialog.cpp

HEADERS  += dialog.h

FORMS    += dialog.ui

 

 

注意QT一行要加上 sql

 


当然我愿意不厌其烦的把最后一个dialog.ui文件贴出来,这样你所需要做的就只是拷贝了(不过要是你自己写,我会很欣慰):

 

 

 

我做demo一定要足够简单,所以上面仅仅显示了链接成功字样。

 

附上dialog.ui:

<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>Dialog</class>
 <widget class="QDialog" name="Dialog">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>400</width>
    <height>300</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>Dialog</string>
  </property>
  <widget class="QPushButton" name="connect">
   <property name="geometry">
    <rect>
     <x>40</x>
     <y>200</y>
     <width>98</width>
     <height>27</height>
    </rect>
   </property>
   <property name="text">
    <string>connect</string>
   </property>
  </widget>
  <widget class="QPushButton" name="close">
   <property name="geometry">
    <rect>
     <x>200</x>
     <y>200</y>
     <width>98</width>
     <height>27</height>
    </rect>
   </property>
   <property name="text">
    <string>close</string>
   </property>
  </widget>
  <widget class="QTextEdit" name="textEdit">
   <property name="geometry">
    <rect>
     <x>60</x>
     <y>40</y>
     <width>211</width>
     <height>121</height>
    </rect>
   </property>
  </widget>
 </widget>
 <layoutdefault spacing="6" margin="11"/>
 <resources/>
 <connections/>
</ui>

 

 

自己写完有个疑问:

事件一般都要有个connect吧,可是为什么这里没有connect呢?

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值