打开MySQL数据库时应用程序崩溃

时间:2013-01-24 11:52:55

标签: mysql qt qt5

我在Windows 7×64上使用Qt 5.0.0(个人编译 - MinGW x64)。我在配置中添加了MySQL支持,并在系统上安装了MySQL。 MySQL库,头文件在应用程序中可见。

程序在打开数据库时崩溃。我这样打开数据库:

QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
db.setDatabaseName("My DB name");
db.setUserName("root");
db.setPassword("My password");
db.setHostName("localhost");
db.setPort(3306);
try{
db.open(); // <=== Crashes without throwing an exception
}
catch(std::exception e)
{
    std::cout << e.what() << std::endl;
}

备注:

qDebug() << QSqlDatabase::drivers();

打印

("QMYSQL3", "QMYSQL", "QODBC3", "QODBC", "QSQLITE")

操作系统生成的问题签名如下所示:

Problem Event Name: APPCRASH
Application Name: CMS.exe
Application Version: 0.0.0.0
Application Timestamp: 51010cdd
Fault Module Name: Qt5Sql.dll
Fault Module Version: 5.0.0.0
Fault Module Timestamp: 50f6b734
Exception Code: c0000005
Exception Offset: 00000000000df950
OS Version: 6.1.7600.2.0.0.256.1
Locale ID: 1033
Additional Information 1: db69
Additional Information 2: db697f824a06df6631cf05ed1f197e16
Additional Information 3: 1d76
Additional Information 4: 1d7605bf295c1c2cfcbfc6bfcec7c569

我用这种方式使用gendef和dlltool生成.a文件:

gendef libmysql.dll
dlltool --input-def libmysql.def --dllname libmysql.dll --output-lib libmysql.a

Qt配置为-qt-sql-mysql而不是-plugin-sql-mysql。 (有什么区别?)

1 个答案:

答案 0 :(得分:1)

由于你的程序在没有捕获异常的情况下崩溃(我注意到你已经写成了一个全能),我倾向于认为崩溃发生在try块之前。

尝试在try-catch中包装'db'的声明及其属性的设置(即使只是暂时的)。