poco 连接mysql_[Poco]数据库操作简介

POCO Data User Guide

按Poco的文档,本文缩写、改编、注释POCO Data User Guide的内容,介绍Poco的数据库操作。原文见http://pocoproject.org/docs/00200-DataUserManual.html。

先介绍一个简单例子,无须解释,其意自明。

#include"Poco/Data/Common.h"#include"Poco/Data/SQLite/Connector.h"#includeusingnamespacePoco::Data;voidinit()

{

SQLite::Connector::registerConnector();

}voidshutdown()

{

SQLite::Connector::unregisterConnector();

}intmain(intargc,char*argv[])

{

init();

Session ses("SQLite","sample.db");intcount=0;

ses<

std::cout<

shutdown();

}

Session

表示与数据库的连接,每个Session有两个要素,一是Poco表示数据库种类的类型标识,二是连接每种数据库所需的一个字符串。注意,实际的软件中这两个参数一般不会硬编码在代码中。

以SQLite为例

Session ses("SQLite","sample.db");

Session ses(SessionFactory::instance()::create("SQLite","sample.db"));

读取和写入数据:占位符placeholder,use(),into()

写入操作中使用placeholder和use()

std::stringaName("Peter");

ses<

读取操作中使用placeholder和into()

std::stringaName;

ses<

也可以同时使用use()和into()

std::stringaName;

std::stringmatch("Peter")

ses<

poco_assert (aName==match);

一般情况下,数据表有多列,用如下形式

std::stringfirstName("Peter";

std::stringlastName("Junior");intage=0;

ses<

注意,placeholder与use或into的顺序是一一对应的。

Statement用于表示SQL语句

原型

templateStatement Session::operator<

两种赋值方式,第一种方式会立即执行语句

std::stringaName("Peter");

Statement stmt=( ses<

第二种赋值方式可以把语句保存起来,稍后再执行

std::stringaName("Peter");

Statement stmt=( ses<

stmt.execute();

poco_a

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值