|
static bool sqlConnection(const QString& HostName,
const QString& DatabaseName,
const QString& UserName,
const QString& Password)
{
QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");
db.setHostName(HostName);
db.setDatabaseName(DatabaseName);
db.setUserName(UserName);
db.setPassword(Password);
if(!db.open())
{
QMessageBox::critical(0, QObject::tr("Error"),
QObject::tr("The database reported an error: %1").arg(db.lastError().text()));
return false;
}
//在Qt数据库连接后,运行"SET NAMES 'UTF8'"语句或"SET NAMES 'GBK'"。
//db.exec("SET NAMES 'UTF8'");
return true;
}
//多个数据库连接
static bool sqlConnections()
{
// 创建一个名为odbc的连接
QSqlDatabase *odbc = QSqlDatabase::addDatabase( "QODBC", "ODBC" );
if ( ! defaultDB ) {
qWarning( "Failed to connect to odbc driver" );
return FALSE;
}
odbc->setDatabaseName( DB_ODBC_DBNAME );
odbc->setUserName( DB_ODBC_USER );
odbc->setPassword( DB_ODBC_PASSWD );
odbc->setHostName( DB_ODBC_HOST );
if ( ! odbc->open() ) {
qWarning( "Failed to open sales database: " + odbc->lastError().driverText() );
qWarning( odbc->lastError().databaseText() );
return FALSE;
}
// 创建一个名为oracle的连接
QSqlDatabase *oracle = QSqlDatabase::addDatabase( "QOCI", "ORACLE" );
if ( ! oracle ) {
qWarning( "Failed to connect to oracle driver" );
return FALSE;
}
oracle->setDatabaseName( DB_ORACLE_DBNAME );
oracle->setUserName( DB_ORACLE_USER );
oracle->setPassword( DB_ORACLE_PASSWD );
oracle->setHostName( DB_ORACLE_HOST );
if ( ! oracle->open() ) {
qWarning( "Failed to open orders database: " + oracle->lastError().driverText() );
qWarning( oracle->lastError().databaseText() );
return FALSE;
}
return TRUE;
}
|
|
|