QSqlDatabase QSqlDatabase::addDatabase(const QString & type, const QString & connectionName = QLatin1String( defaultConnection ))
QDB2 |
IBM Db |
QIBASE | Borland InterBase |
QMYSQL | MYSQL |
QOCI | 甲骨文公司 |
QODBC | ODBC(包括微軟公司的Server服務器) |
QPSQL | PostgreSQL的7.3版以及更高版 |
QSQLITE | QLite第三版 |
QSQLITE2 | QLIte2第二版 |
QTDS | sybase自適應服務器 |
- DNS字符串
QString dsn = "DRIVER={SQL SERVER};SERVER=58.67.161.109;DATABASE=RDBS;UID=RDBS_USER;PWD=RDBS_USER_7010387;";
//還要注意這里的用戶名要有創建表的權限,不然創建下面的表student會不成功。
db.setDatabaseName(dsn); //數據庫名 db.setUserName("RDBS_USER");//登錄名,我再dsn里設置UID和PWD后,就不需要設置了
if(!db.open ())
{
QSqlError error = db.lastError();
return false;
}
- 手動設置ODBC數據源
控制面板->系統和安全->管理工具->數據源(ODBC)
代碼:
QSqlDatabase db=QSqlDatabase::addDatabase("QODBC");
db.setDatabaseName("testdsn");
db.setUserName("sa");
db.setPassword("scada");
三、下面是ODBC和OLEDB的連接字符串寫法:
1、ODBC連接字符串
//適合數據庫類型 連接方式
access
"Driver={microsoft access driver(*.mdb)};dbq=*.mdb;uid=admin;pwd=pass;"
dBase
"Driver={microsoft dbase driver(*.dbf)};driverid=277;dbq=------------;"
oracle
"Driver={microsoft odbc for oracle};server=oraclesever.world;uid=admin;pwd=pass;"
MSSQL server
"Driver={sql server};server=servername;database=dbname;uid=sa;pwd=pass;"
MS text
"Driver={microsoft text driver(*.txt; *.csv)};dbq=-----;extensions=asc,csv,tab,txt;Persist SecurityInfo=false;"
Visual Foxpro
"Driver={microsoft Visual Foxpro driver};sourcetype=DBC;sourceDB=*.dbc;Exclusive=No;"
MySQL
"Driver={mysql};database=yourdatabase;uid=username;pwd=yourpassword;option=16386;"
SQLite
"Driver={SQLite3 ODBC Driver};Database=D:\SQLite\*.db"
PostgreSQL
"Driver={PostgreSQL ANSI};server=127.0.0.1;uid=admin;pwd=pass;database=databaseName"