代码拉取完成,页面将自动刷新
同步操作将从 htfy96/NanoSQL 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include "nanosql.hpp"
using namespace std;
Sql s("123.db");
char op[1000];
int cb(void *notUsed, int argc, char **argv, char **colName)
{
cout<<argc<<" col is selected"<<endl;
for (int i=0;i<argc;++i)
cout<<colName[i]<<":"<<argv[i]<<endl;
return 0;
}
int main()
{
s.exec("drop table t");
s.exec("create table t \
(id integer PRIMARY KEY AUTOINCREMENT, \
name varchar(100) \
)");
cout<<s.lasterr<<endl;
cout<<"begin inserting 1000000 row"<<endl;
s.begin_tran();
for (int i=1;i<=1000000;++i)
{
sprintf(op,"insert into t (name) VALUES ('%x')",rand() );
if (i%10000==0) cout<<i/10000<<"% "<<flush;
s.exec(op);
}
s.end_tran();
cout<<"finished"<<endl;
cout<<s.lasterr<<endl;
s.get_table("select * from t order by name DESC limit 3");
s.exec("select * from t order by id DESC limit 2",cb);
for (int i=1;i<=s.raw_result.col;++i)
cout<<s.colName(i)<<" |";
cout<<endl;
for (int i=1;i<=s.raw_result.row;++i)
{
for (int j=1;j<=s.raw_result.col;++j)
cout<<s.result(i,j)<<",";
cout<<endl;
}
return 0;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。