C++07:使用OTL操作MySQL數(shù)據(jù)庫
C++07:使用OTL操作MySQL數(shù)據(jù)庫
2009-10-29 14:46一、編寫代碼
注:以下代碼來自O(shè)TL示例,略有改動
#include <iostream> using namespace std; #include <cstdio> #include <cstring> #include <cstdlib> #define OTL_ODBC // Compile OTL 4.0/ODBC // The following #define is required with MyODBC 3.51.11 and higher #define OTL_ODBC_SELECT_STM_EXECUTE_BEFORE_DESCRIBE #define OTL_ODBC_UNIX // uncomment this line if UnixODBC is used #include <otlv4.h> // include the OTL 4.0 header file otl_connect db; // connect object void insert() // insert rows into table { otl_stream o(1, // buffer size should be == 1 always on INSERT "insert into test_tab values " " (:f1<int>,:f2<char[31]>), " " (:f12<int>,:f22<char[31]>), " " (:f13<int>,:f23<char[31]>), " " (:f14<int>,:f24<char[31]>), " " (:f15<int>,:f25<char[31]>) ", // INSERT statement. Multiple sets of values can be used // to work around the lack of the bulk interface db // connect object ); // If the number of rows to be inserted is not known in advance, // another stream with the same INSERT can be opened otl_stream o2(1, // buffer size should be == 1 always on INSERT "insert into test_tab values " " (:f1<int>,:f2<char[31]>)", db // connect object ); char tmp[32]; int i; for (i = 1; i <= 100; ++i) { sprintf(tmp, "Name%d", i); o << i << tmp; } for (i = 101; i <= 103; ++i) { sprintf(tmp, "Name%d", i); o2 << i << tmp; } } void update(const int af1) // insert rows into table { otl_stream o(1, // buffer size should be == 1 always on UPDATE "UPDATE test_tab " " SET f2=:f2<char[31]> " " WHERE f1=:f1<int>", // UPDATE statement db // connect object ); o << "Name changed" << af1; o << otl_null() << af1 + 1; // set f2 to NULL } void select(const int af1) { otl_stream i(50, // buffer size may be > 1 "select * from test_tab " "where f1>=:f11<int> " " and f1<=:f12<int>*2", // SELECT statement db // connect object ); // create select stream int f1; char f2[31]; i << af1 << af1; // :f11 = af1, :f12 = af1 while (!i.eof()) { // while not end-of-data i >> f1; cout << "f1=" << f1 << ", f2="; i >> f2; if (i.is_null()) cout << "NULL"; else cout << f2; cout << endl; } } int main() { otl_connect::otl_initialize(); // initialize ODBC environment try { // db.rlogon("UID=xuanyuan;PWD=xuanyuan;DSN=examples"); // connect to ODBC db.rlogon("xuanyuan/xuanyuan@examples"); // connect to ODBC, alternative format of connect string otl_cursor::direct_exec(db, "use examples"); // 此行在原示例代碼中沒有,必須使用use xxx切換數(shù)據(jù)庫 otl_cursor::direct_exec(db, "drop table test_tab", otl_exception::disabled // disable OTL exceptions ); // drop table otl_cursor::direct_exec(db, "create table test_tab(f1 int, f2 varchar(30)) type=innoDB"); // create table insert(); // insert records into the table update(10); // update records in the table select(8); // select records from the table } catch (otl_exception& p) { // intercept OTL exceptions cerr << p.msg << endl; // print out error message cerr << p.stm_text << endl; // print out SQL that caused the error cerr << p.sqlstate << endl; // print out SQLSTATE message cerr << p.var_info << endl; // print out the variable that caused the error } db.logoff(); // disconnect from ODBC return 0; }二、編譯代碼
g++ -o"otl_test2" otl_test2.cpp -lmyodbc3三、運(yùn)行程序 otl_test
$ ./otl_test2結(jié)果如下:
f1=8, f2=Name8 f1=9, f2=Name9 f1=10, f2=Name changed f1=11, f2=NULL f1=12, f2=Name12 f1=13, f2=Name13 f1=14, f2=Name14 f1=15, f2=Name15 f1=16, f2=Name16四、關(guān)于OTL更多的信息
請?jiān)L問OTL的主頁: http://otl.sourceforge.net/
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
