XML文件连接数据库

1、XML读取操作

QString DBHelper::readXmlfile(const QString &filePath, const QString& valueName)
{
    //打开或创建文件
    QFile file(filePath);
    if (file.open(QIODevice::ReadOnly | QIODevice::Text))
    {
        //构建QXmlStreamReader对象
        QXmlStreamReader reader(&file);
        while (!reader.atEnd())
        {
            if (reader.name() == valueName)
            {
                return reader.readElementText();
            }
            else
            {
                reader.readNext();
            }
        }
        file.close();
    }
    else
    {
        return "配置文件打开失败!";
    }
    return "nullptr";
}

2、数据库连接操作

bool DBHelper::ConnDB()
{
//    db = QSqlDatabase::addDatabase("QMYSQL");
//    db.setHostName("127.0.0.1");
//    db.setPort(3306);
//    db.setDatabaseName("planedb");
//    db.setUserName("root");
//    db.setPassword("123456");

    db = QSqlDatabase::addDatabase("QMYSQL");
    QString filePath = "D:\\baby\\qtTest\\plane";
    QString hostName = "hostName";
    QString port = "port";
    QString datebase = "datebase";
    QString username = "username";
    QString passWord = "passWord";
    if(readXmlfile(filePath, hostName) == "false")
    {
        qDebug() << QStringLiteral("XML文件打开失败!");
        return false;
    }

    db.setHostName(readXmlfile(filePath, hostName));
    db.setPort(readXmlfile(filePath, port).toInt());
    db.setDatabaseName(readXmlfile(filePath, datebase));
    db.setUserName(readXmlfile(filePath, username));
    db.setPassword(readXmlfile(filePath, passWord));

    return db.open();
}

3、开始连接数据库

bool dbhlper = m_pDBHelper->ConnDB();
    if(!dbhlper)
    {
        QMessageBox::warning(this, "connectDB", "error", QMessageBox::Ok);
        return;
    }

    QMessageBox::warning(this, "connectDB", "success", QMessageBox::Ok);

4、补充xml文件详情

<?xml version="1.0" encoding="UTF-8"?>
<paras>
	<DataBaseConfig>
		<hostName>127.0.0.1</hostName>
		<port>3306</port>
		<datebase>planedb</datebase>
		<username>root</username>
		<passWord>123456</passWord>
	</DataBaseConfig>
</paras>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值