qtp與資料庫連接
--1 右鍵表所在的資料庫名--2 選擇任務--3 選擇生成腳本--4 選擇設置腳本編寫選項--5 保存到文件--高級--倒數第二行要編寫腳本的數據的類型--選擇架構和數據--6 保存
⑵ QT中怎樣連接MYsql資料庫,遠程連接資料庫等
1: windows 下登陸mysql 命令行,(1)進入cmd (2) cd mysql 安裝路徑/mysqlserver5.6/bin
(3) 使用命令mysql -u root -p 然後根據提示輸入密碼 進入命令行
select user(); //顯示當前用戶
2: 在同一台電腦上利用Qt 訪問資料庫
(1)顯示當前電腦上安裝的資料庫驅動
QStringList drivers = QSqlDatabase::drivers();
foreach(QString driver, drivers)
qDebug() <<"/t" << driver;
(2)QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL");/對 QMYSQL進行操作,本函數
有第二個參數 連接名
db.setHostName("localhost");//或127.0.0.1 本主機
db.setPort(3306);
db.setDatabaseName("example"); //對資料庫example進行操作
db.setUserName("wangxuetao"); //wangxuetao是一個對example資料庫有操作許可權的賬戶
db.setPassword("3791948");
於是mysql中增加一個賬戶可使用
Grant all previliges on *.* to 『wangxuetao』@』localhost』 identified by
『3791948』 with grant option;
Flush privileges; //更新
(3)db.open() 函數可由於檢測資料庫是否連接成功
cout<DBConnection();
2. m_sqlquery = new QSqlQuery("",m_sqldb);//statement 1:connect db with sql
query
3. if(result == R_OK)
4. {
5. result = m_sqlquery->exec("INSERT INTO children(fname,age) VALUES('A
nn2',13)");
6. if(!result)
7. qDebug()<<" [OK] "<<"EXEC successed";
8. m_sqlquery->exec("SELECT * FROM children c LIMIT 0,1000");
9. while(m_sqlquery->next())
10. {
11. qDebug()<value(0).toString()<value(1).
toString();
12. }
13. }
⑶ 如何用Qt連接資料庫並導入文件
可以使用QT自帶的資料庫完成操作,以下是參考代碼:
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE"); //添加資料庫
db.setDatabaseName("note.db"); //創建一個note.db的文件存儲數據
db.open(); //開啟資料庫
query = QSqlQuery(db); //獲得訪問資料庫的query
query.exec(XXX); //執行指令(XXX為SQL指令)
db.close(); //關閉資料庫
一般而言會將db變數作為全局變數或者數據成員,當需要訪問的時候就獲取一個query就可以了。
要實現所提到的功能,要好好看看QString、QStringList,這兩玩意主要是臨時存放數據、分割數據等作用,另外,要看QFile、QDir、QFileInfo、QTextStream,這四個主要用來讀取文本數據。看看QVector或者QList等來存放讀出來的數據。
另外,要實現這玩意,SQL的語句不要求精通,但是基本的Create、Insert、Select、Delete等操作要准確無誤。否則出錯了QT是看不出來的。QT不會檢測SQL的准確性的。
⑷ QTP連接oracle資料庫進行查詢時報錯:在執行命令過程中,發生了一個或多個錯誤。
如果資料庫鏈接正確,那麼就是你的sql語句有問題,或者資料庫里沒數據。沒獲取到結果集,也就是說你的結果集是個空的!
⑸ 怎樣在Qt下連接讀寫sqlite資料庫
這里以學生信息的錄入與讀取來作為演示,主要目的是演示資料庫的操作,至於數據的顯示等不在演示範圍內,請您自行研究。
首先,在Qt中建立一個圖形界面的程序項目。
然後,我們在命令行下用sqlite命令創建了資料庫 C:\StudentInfo\sutdentdata.db,並且建立了一個資料庫表student,該表有四個欄位ID、Name、Sex、Age,未向表中添加任何數據。
關於sqlite的簡單使用,可以參考我們的另一篇經驗。
2SQLite的簡單使用方法
在讀寫SQLite資料庫中,我們最主要用到的是QSqlDatabase類及QSqlQuery類,前者負責創建資料庫連接並打開資料庫,後者負責執行查詢操作。實際上前者也可以進行查詢操作並將結果返回給QSqlQuery對象,但是Qt並不建議這么做。
在幹活前,依然是先看看Assitant,這是培養獨立解決問題的一個好習慣。
好,下面給 錄入 按鈕的點擊事件編寫代碼。關於如何給按鈕的某一事件進行編碼,可以參考我們另一篇經驗。
首先在.pro文件中加上sql,然後別忘了#include <QSqlDatabase>以及#include <QSqlQuery>。
好了,下面在錄入按鈕的槽中加入如下代碼:
QSqlDatabase mydb=QSqlDatabase::addDatabase("QSQLITE","wconntosqlite");
mydb.setDatabaseName("c:\\StudentInfo\\studentdata.db");
if(mydb.open())
{
QSqlQuery query(mydb);
QString sqlstr="insert into student (ID,Name,Sex,Age) values ('"
+ui->le_id->text()+"','"
+ui->le_name->text()+"','"
+ui->le_sex->text()+"',"
+ui->le_age->text()+")";
bool isok=query.exec(sqlstr);
if(isok)
qDebug()<<"數據寫入成功";
}
上面我們先調用了QSqlDatabase的靜態函數addDatabase創建了一個名為wconntosqlite的連接。然後給其傳遞資料庫名稱。
如果資料庫打開成功,就創建一個關聯的QSqlQuery對象,最後由QSqlQuery來執行插入數據工作。
特別注意:QSqlQuery對象的創建必須在mydb open成功以後才行,否則會出錯。
我們來看看效果如何。
4c++怎麼做界面
我們接著來寫查詢按鈕的代碼,輸入以下代碼:
QSqlDatabase mydb=QSqlDatabase::addDatabase("QSQLITE","rconntosqlite");
mydb.setDatabaseName("c:\\StudentInfo\\studentdata.db");
if(mydb.open())
{
QSqlQuery query(mydb);
QString sqlstr="select * from student";
bool isok=query.exec(sqlstr);
if(isok)
qDebug()<<"數據讀取成功";
query.first();
QString result="學號:"+query.value(0).toString()+" "
+"姓名:"+query.value(1).toString()+" "
+"性別:"+query.value(2).toString()+" "
+"年齡:"+query.value(3).toString();
ui->lbl_query->setText(result);
}
與寫入數據基本差不多,這里需要特別注意的是query.first();。看看Assistant怎麼說的就知道了。原來,query對象在執行完查詢語句後,query的位置被置於一個不可用的位置,如果想從query中獲取數據,需要設置query到一個可用的記錄中才行。方法有好幾種,這里我們用了first()成員函數。
好,來看看運行結果。
可以看到軟體讀取的數據與控制台窗口的數據是一致的。
我們來總結下Qt操作SQLite資料庫的五步走法決:
第一步,建立一個連接:QSqlDatabase db=QSqlDatabase::addDatabase("QSQLITE");
第二步,關聯資料庫文件:db.setDatabaseName("這里你的資料庫文件路徑")
第三步,打開資料庫:db.open()
第四步,如果資料庫打開成功,就建立一個相關聯的QSqlQuery對象:QSqlQuery query(db)
第五步,執行SQL語句:query.exec("你的SQL語句字元串")
⑹ QTP連接oracle資料庫進行查詢時報錯:在執行命令過程中,發生了一個或多個錯誤。
// Rs.Open strsql,Cnn,1,3 '(執行到此處報錯)
Cnn,1,3 有問題。因為第一個數字(1)是代表游標在數據集內游動的方式;第二個數字代表以什麼方式進行資料庫訪問。
綜上所述:你應給把Cnn,1,3 換成:Cnn,3,1;3代表是動態游標;1代表對資料庫是只讀方式;
你再試試,應該可以的;不行咱們再交流。
⑺ qtp連接oracle資料庫報錯:由於系統錯誤 1114: 動態鏈接庫(DLL)初始化常式失敗
問題解決了嗎?
⑻ qtp連oracle資料庫,提示「[Microsoft][ODBC 驅動程序管理器] 未發現數據源名稱並且未指定默認驅動程序」
qtp連oracle資料庫,提示「[Microsoft][ODBC 驅動程序管理器] 未發現數據源名稱並且未指定默認驅動程序」
第一,QTP本身自帶有個連接資料庫的小工具,你用小工具確保連接字元串正確。PS:網上有些文件可能給的連接字元串不正確。
第二,在第一步的基礎上連接資料庫成功後,第二步請用Command對象查詢數據。
如果使用Record或者Connection去查詢可能會導致多次查詢後,Session達到最大沒有釋放,或者受到資料庫Server限制短時間內多次訪問阻止的配置。
⑼ QTP如何連接/查詢資料庫
你要鏈接資料庫有2種方法,第一種是利用QTP自帶的內置鏈接,比如設置資料庫檢查點時新增數據源,或者利用已存在的數據源,然後輸入sql查詢語句;第二種第一部也是新增一個數據源,然後在QTP中寫入如下,第二種靈活性高,難度也高,第一種靈活性差,幾乎沒難度
Dim adoconnts
Dim connectionstr
connectionstr="Provider=OraOLEDB.Oracle.1;Password=ngtest;Persist Security Info=True;User ID=ngserver;Data Source=10.60.60.10"
sqlstr="select * from bs_gps_device"
VERSION, SIM_NO, OWNER, GPS_STATE)values ('2', '3', null, '3', '3', '12345678903', null, 5);"
Set adoconnts= CreateObject("ADODB.Connection") '
adoconnts.Open connectionstr
Set adorst=adoconnts.Execute(sqlstr)
'adoconnts.Execute adorst1
While not adorst.EOF
msgbox adorst.Fields.Item("id").Value '返回結果集
adorst.MoveNext
Wend
adoconnts.Close'關閉結果集
set adoconnts=nothing
至於數據源怎麼搞,得自己查