25 Star 64 Fork 24

cxxjava/CxxDBC

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
sybase.cpp 12.26 KB
一键复制 编辑 原始数据 按行查看 历史
cxxjava 提交于 7年前 . release v0.3.0:
/*
* sybase.cpp
*
*/
#include "Edb.hh"
#define LOG(fmt,...) ESystem::out->printfln(fmt, ##__VA_ARGS__)
#define HOST "192.168.2.61"
#define PORT "5000"
#define DATABASE "master"
#define USERNAME "sa"
#define PASSWORD "password"
static void test_db_connect() {
EConnection conn;
//1.
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
ON_FINALLY_NOTHROW(
conn.close();
) {
EDatabaseMetaData* meta = conn.getMetaData();
LOG("name=%s", meta->getDatabaseProductName().c_str());
LOG("version=%s", meta->getDatabaseProductVersion().c_str());
}}
//2.
conn.connect("edbc:SYBASE://" HOST ":" PORT "/" DATABASE "?connectTimeout=10", USERNAME, PASSWORD);
ON_FINALLY_NOTHROW(
conn.close();
) {
EDatabaseMetaData* meta = conn.getMetaData();
LOG("name=%s", meta->getDatabaseProductName().c_str());
LOG("version=%s", meta->getDatabaseProductVersion().c_str());
}}
}
static void test_db_execute() {
EConnection conn;
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
ECommonStatement stmt(&conn);
EResultSet* rs;
//0.
try {
stmt.setSql("DROP TABLE sybase001").execute();
} catch (...) {
}
stmt.setSql("CREATE TABLE sybase001 ("
"a int NULL ,"
"b tinyint NULL ,"
"c binary (50) NULL ,"
"d bit NOT NULL ,"
"e text NULL,"
"f datetime NULL ,"
"g float NULL ,"
"h money NULL ,"
"i nchar (255) NULL ,"
"j timestamp NULL ,"
"k smallint NULL ,"
"l image NULL ,"
"m numeric(15,5) NULL)").execute();
//1.
stmt.clear();
char *zw = "0123456789中文";
stmt.setSql("insert into sybase001 (d,c,a,i,f,h,g,m,e) values(1,?,?,?,?,?,?,?,?)")
.bindBytes((byte*)"0x12345000", 8)
.bindInt(4)
.bindString("中文")
.bindString("2017-07-08")
.bindNumeric("8888.88")
.bindDouble(5.4433)
.bindNumeric("1.9998")
.bind(DB_dtCLob, zw, strlen(zw));
for (int i=0; i<100; i++) {
stmt.execute();
}
//2.
stmt.clear();
stmt.setSql("select * from sybase001").execute();
rs = stmt.getResultSet();
EResultSetMetaData* rsm = rs->getMetaData();
LOG(rsm->toString().c_str());
while (rs->next()) {
for (int i=1; i<=rs->getMetaData()->getColumnCount(); i++) {
LOG("%s:%s", rs->getMetaData()->getColumnLabel(i).c_str(), rs->isNull(i) ? "is null" : rs->getString(i).c_str());
}
}
rs->close();
//3.
stmt.clear();
stmt.setFetchSize(2);
stmt.setSql("select * from sybase001 where a=? or i=?")
.bindInt(4)
.bindString("1")
.execute();
rs = stmt.getResultSet();
while (rs != null) {
while (rs->next()) {
for (int i=1; i<=rs->getMetaData()->getColumnCount(); i++) {
LOG("%s:%s", rs->getMetaData()->getColumnLabel(i).c_str(), rs->isNull(i) ? "is null" : rs->getString(i).c_str());
}
}
rs = stmt.getResultSet(true);
}
if (rs != null) rs->close();
conn.close();
}
static void test_db_update() {
EConnection conn;
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
EUpdateStatement stmt(&conn);
stmt.setFailedResume(true);
stmt.setSql("insert into sybase001 (d,a,i,f) values (1, -2, '666', '2015-5-5')"); //1
stmt.addBatch("insert into sybase001 (d,a,i,f) values (?, ?, ?, ?)"); //2
stmt.bindBool(true);
stmt.bindInt(-1);
stmt.bindString("777");
stmt.bindString("2016-6-6");
stmt.addBatch("insert into sybase001 (d,a,i,f) values (0, ?, ?, ?)"); //3
stmt.bindInt(-3);
stmt.bindString("333");
stmt.bindString("2016-6-6");
for (int i = 0; i < 99; i++) {
stmt.addBatch();
if (i == 0) { //模拟错误
stmt.bindInt(i);
} else {
stmt.bindInt(i);
stmt.bindString("999");
stmt.bindString("2016-6-6");
}
}
stmt.addBatch("insert into sybase001 (d,a,i,f) values (0, -2, '666', '2015-5-5')"); //103
stmt.addBatch("insert into sybase001 (d,a,i,f) values (0, -2, '666', '2015-5-5')"); //104
stmt.execute();
LOG("failures=%d", stmt.getFailures());
LOG("first failed=%d", stmt.getFirstFailed());
LOG("sql 1 affected=%d", stmt.getUpdateCount(1));
LOG("sql 3 affected=%d", stmt.getUpdateCount(3));
LOG("sql 3 errmsg=%s", stmt.getUpdateMessage(3).c_str());
LOG("sql 4 affected=%d", stmt.getUpdateCount(4));
LOG("sql 4 errmsg=%s", stmt.getUpdateMessage(4).c_str());
LOG("sql 5 affected=%d", stmt.getUpdateCount(5));
LOG("sql 6 affected=%d", stmt.getUpdateCount(6));
LOG("sql 103 affected=%d", stmt.getUpdateCount(103));
LOG("sql 104 affected=%d", stmt.getUpdateCount(104));
conn.close();
}
static void test_db_commit() {
EConnection conn;
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
ECommonStatement stmt(&conn);
stmt.setSql("update sybase001 set i='xxxxxxxxxx' where a=1");
conn.setAutoCommit(false);
stmt.execute();
// conn.commit();
conn.rollback();
// conn.setAutoCommit(true);
stmt.execute();
conn.commit();
conn.close();
}
static void test_db_rollback() {
EConnection conn;
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
ECommonStatement stmt(&conn);
try {
stmt.setSql("drop table sybase002").execute();
} catch (...) {
}
stmt.setSql("create table sybase002 (a int)").execute();
conn.setAutoCommit(false);
ESavepoint sp1 = conn.setSavepoint();
stmt.setSql("insert into sybase002 values (1)").execute();
// conn.rollback();
// conn.setAutoCommit(true);
ESavepoint sp2 = conn.setSavepoint();
stmt.setSql("insert into sybase002 values (2)").execute();
conn.rollback(sp2);
conn.commit();
conn.close();
}
static void test_large_object() {
EConnection conn;
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
conn.setAutoCommit(false);
llong oid = conn.createLargeObject();
LOG("create oid=%ld", oid);
char *s = "12345678905567894598765679";
// EByteArrayInputStream bais(s, strlen(s));
EByteArrayOutputStream baos;
for (int i = 0; i< 10000000; i++) {
baos.write(s);
}
EByteArrayInputStream bais(baos.data(), baos.size());
llong written = conn.writeLargeObject(oid, &bais);
LOG("written=%ld", written);
EFileOutputStream fos("/tmp/lob.txt");
llong reading = conn.readLargeObject(oid, &fos);
LOG("reading=%ld", reading);
conn.commit();
conn.close();
}
static void test_create_table() {
EConnection conn;
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
EUpdateStatement stmt(&conn);
stmt.setFailedResume(true);
stmt.addBatch("dump tran master with truncate_only");
stmt.addBatch("drop table sybase001");
stmt.addBatch("CREATE TABLE sybase001 ("
"a int NULL ,"
"b tinyint NULL ,"
"c binary (50) NULL ,"
"d bit NOT NULL ,"
"e text NULL,"
"f datetime NULL ,"
"g float NULL ,"
"h money NULL ,"
"i nchar (255) NULL ,"
"j timestamp NULL ,"
"k smallint NULL ,"
"l image NULL ,"
"m numeric(15,5) NULL ,"
"n bigint NULL)");
stmt.execute();
conn.close();
}
static void test_sql_insert() {
EConnection conn;
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
//large lob
ECommonStatement st(&conn);
st.setSql("insert into sybase001 (d, e, l) values (1, ?, ?)");
EFileInputStream fis1("/tmp/a.csv");
EFileInputStream fis2("/tmp/a.csv");
st.bindAsciiStream(&fis1);
st.bindBinaryStream(&fis2);
st.execute();
//other
EUpdateStatement stmt(&conn);
stmt.addBatch("insert into sybase001 (a,b,c,d,e,f,g,h,i,j,k,l,m) "
"values (100000,20,0x616161616161,1,'中午的太阳火辣辣','2005-01-09 23:12:59',21212.4343,3333.01,"
"'舞起来',null,522,0x61616161616122,334343.2123)");
stmt.addBatch("insert into sybase001 (d,e,g) values (1,?,?)");
es_buffer_t *buffer = eso_buffer_make(100, 0);
for (int i = 0; i < 100; i++) {
eso_buffer_append(buffer, "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa11aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
50);
}
stmt.bind(DB_dtCLob, (char*)buffer->data, buffer->len);
eso_buffer_free(&buffer);
stmt.bindFloat(5.44454);
stmt.addBatch("insert into sybase001 (a,b,c,d,e,f,g,i) values (?,?,?,0,?,?,?,?)");
stmt.bindInt(55555);
stmt.bindShort(12);
stmt.bindBytes((byte *)"\1\2\3\4\0\9\8", 7);
stmt.bindString("计费地热 热");
stmt.bindDateTime("2005-01-09 23:12:59");
stmt.bindFloat(5.44454);
stmt.bindString("2222031");
stmt.setFailedResume(true);
stmt.execute();
LOG("err=%s, first failed sql index=%d, failures=%d", stmt.getErrorMessage().c_str(), stmt.getFirstFailed(), stmt.getFailures());
for (int i=1; i <= stmt.getSqlCount(); i++) {
LOG("sql#%d affected=%d, errmsg=%s", i, stmt.getUpdateCount(i), stmt.getUpdateMessage(i).c_str());
}
conn.close();
}
static void test_sql_query() {
EConnection conn;
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
ECommonStatement stmt(&conn);
stmt.setSql("select * from sybase001").execute();
EResultSet* rs = stmt.getResultSet();
while (rs->next()) {
for (int i=1; i<=rs->getMetaData()->getColumnCount(); i++) {
LOG("%s:%s", rs->getMetaData()->getColumnLabel(i).c_str(), rs->isNull(i) ? "is null" : rs->getString(i).c_str());
}
}
conn.close();
}
static void test_sql_update() {
EConnection conn;
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
EUpdateStatement stmt(&conn);
//1.
stmt.setSql("update sybase001 set n=?,k=?,a=?,d=?,g=?,m=?");
stmt.bindLong(ELLong::MAX_VALUE);
stmt.bindShort(EShort::MAX_VALUE);
stmt.bindInt(EInteger::MAX_VALUE);
stmt.bindBool(1);
stmt.bindFloat(8.8843);
stmt.bindNumeric("55555.5454");
stmt.execute();
//2. text: <=64k
stmt.addBatch("update sybase001 set e=?");
es_buffer_t *buffer = eso_buffer_make(100, 0);
for (int i = 0; i < 1000; i++) {
eso_buffer_append(buffer, "a中午的太aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa11aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
50);
}
stmt.bind(DB_dtCLob, (char*)buffer->data, buffer->len);
eso_buffer_free(&buffer);
//3. image: <=64k
stmt.addBatch("update sybase001 set l=?");
buffer = eso_buffer_make(100, 0);
for (int i = 0; i < 10; i++) {
eso_buffer_append(buffer, "\0\1\2\aaaaaaaaa中午的太aaaaaaaaaaaaaaaaaaaaaaaaaaa11aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
50);
}
stmt.bind(DB_dtBLob, (char*)buffer->data, buffer->len);
eso_buffer_free(&buffer);
stmt.execute();
LOG("sql 1 effected = %d", stmt.getUpdateCount(1));
LOG("sql 2 effected = %d", stmt.getUpdateCount(2));
LOG("sql 3 effected = %d", stmt.getUpdateCount(3));
conn.close();
}
static void test_sql_func() {
EConnection conn;
conn.connect(DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
//create
{
EUpdateStatement stmt(&conn);
stmt.setFailedResume(true);
stmt.addBatch("drop procedure sybase001func");
stmt.addBatch("create procedure sybase001func "
"@a int "
"as select * from sybase001 where a=@a "
"select a,b,c,d,e from sybase001");
stmt.execute();
}
//select
{
ECommonStatement stmt(&conn);
#if 0 //您不能使用绑定参数调用存储过程!
stmt.setSql("exec sybase001func @a=?");
stmt.bindInt(4);
#else
stmt.setSql("exec sybase001func @a=4");
#endif
stmt.execute();
EResultSet* rs = stmt.getResultSet();
while (rs != null) {
while (rs->next()) {
for (int i=1; i<=rs->getMetaData()->getColumnCount(); i++) {
LOG("%s:%s", rs->getMetaData()->getColumnLabel(i).c_str(), rs->isNull(i) ? "is null" : rs->getString(i).c_str());
}
}
rs = stmt.getResultSet(true);
}
if (rs != null) rs->close();
}
conn.close();
}
static void test_connect_pool() {
EConnectionPool pool(10, NULL, DATABASE, HOST, atoi(PORT), USERNAME, PASSWORD);
EArrayList<sp<EThread> > threads;
for (int i = 0; i < 20; i++) {
sp<EThread> ths = EThread::executeX([&]() {
sp<EConnection> conn;
for (int j = 0; j < 1000; j++) {
conn = pool.getConnection();
ES_ASSERT (conn != null);
sp<ECommonStatement> stmt = conn->createCommonStatement();
stmt->setSql("update sybase002 set a=1").execute();
EThread::sleep(100);
conn->close();
}
});
threads.add(ths);
}
for (int i=0; i<threads.size(); i++) {
threads[i]->join();
}
pool.close();
}
//=============================================================================
void test_db_sybase(void)
{
EConnection::setDefaultDBType("SYBASE");
// test_db_connect();
// test_db_update();
// test_db_commit();
// test_db_rollback();
// test_large_object();
// test_create_table();
// test_sql_insert();
// test_sql_query();
test_sql_query();
// test_sql_update();
// test_sql_func();
// test_connect_pool();
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/cxxjava/CxxDBC.git
git@gitee.com:cxxjava/CxxDBC.git
cxxjava
CxxDBC
CxxDBC
master

搜索帮助