设为首页 收藏本站
查看: 1073|回复: 0

[经验分享] postgresql使用手记

[复制链接]

尚未签到

发表于 2016-11-21 08:50:36 | 显示全部楼层 |阅读模式
  项目要用到数据库,本来打算用资料更多,名声更好的mysql的。卸载了自带的版本装了MariaDB 10.0,然后发现没有成熟的C++库可用(只有一个提交不久的libmariadb++),于是想回滚到原来的mysql5.5,但是悲剧的事情发生了…回滚出问题了。用的系统是Linux Mint14,不管是purge还是remove,然后重装MySQL的时候都会卡死…
  于是我直接放弃了MySQL,用上了据说国内很少用,但是企业中用的不少的PostGreSQL。 安装过程不说了,用源里面的资源就行,我现在的版本是9.2。
  C++库是libpqxx3-dev,官网有4.0.1的版本,我自己装了一下,链接的时候有些问题1,推荐还是用源里面的版本。貌似必须装到/usr/下,直接用sudo make install 装到/usr/local下的话,下面的例子可能通不过…
  PostGreSQL和MySQL的管理方式差得挺远,命令上也没啥相似的(除了SQL语句)。常用的几条命令包括:

createdb                                --直接在shell里面输入,而不是连接到数据库后
createuser
psql -d database_name -U username -p    --连接数据库
\password                               --连接后,修改密码
\l                                      --列出所有数据库,也可以直接psql -l
\d table_name                           --描述表格,相当于MySQL中的describe
\?                                      --其他命令的帮助
  容易看出这货很有微软风格…此外,这货还有个GUI的管理程序,挺好用的,名字叫pgadmin,也可以从源里面装。注意要使用这货还要装postgresql-contrib这个包,不然会提示没有装管理工具。
  我粗略看了一下pqxx的指引文件,作者封装的比较好了。比较有特色的是实现了数据库的事务功能,也就是所谓的原子操作,有点类似C++中的异常安全。但是作者没给出相关的例子,example里面只有简单的过程式编程的例子,如下:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37


#include <iostream>
#include <pqxx/pqxx>
using namespace std;
int main()
{
try
{
pqxx::connection conn("dbname=test user=xiaoming");
if(conn.is_open())
{
cout<<"Connect successful!"<<endl;
cout<<conn.options()<<endl;
}
else
{
cout<<"something wrong ..oops"<<endl;
return 1;
}
pqxx::work w(conn);
pqxx::result r=w.exec("SELECT * FORM TEST");
w.commit();
for(auto iter=r.begin();iter!=r.end();++r)
{
for(auto seg=iter->begin();seg!=iter->end();++seg)
cout<<seg->c_str()<<'\t';
cout<<endl;
}
}
catch(exception &e)
{
cout<<e.what()<<endl;
return 1;
}
return 0;
}
  g++的编译选项:-lpq -lpqxx -std=c++11
  别的都容易理解,注意pqxx::result是一个容器,重载了[]操作符,返回一个tuple类,这个tuple不是C++11标准库里面那个,而是作者自己写的。所以他的表现形式和std::tuple差别挺大的,倒是有点像std::map,可以直接通过重载的[]根据列名访问表格的数据,当然用下标指定第几列也是可以的。如果用迭代器访问,最好使用C++11的语法,不然就typedef吧,超级长的类型名。返回的数据类型是pqxx::field。这个类里面有很多实用函数,如上面的c_str(),也可以用as<string>()来获得。
  上面这种过程式编程方法也是可行的,自己写个类打个包就能搞了。不过作者给了一种更好的方案,也就是上面提到的事务,使用这种方式,能够更安全简介。我自己写了一段示例代码,作为测试程序:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54


#include <iostream>
#include <exception>
#include <functional>
#include <pqxx/pqxx>
#include <pqxx/transaction>
#include <pqxx/transactor>
using namespace std;
class Trans:public pqxx::transactor<>{
public:
Trans(){}
Trans(const string query):
query_(query){}
void operator()(transaction<> &t){
results_=t.exec(query_);
}
void on_commit(){
cout<<"query successful!"<<endl;
for(auto iter=results_.begin();iter!=results_.end();++iter){
for(auto seg=iter->begin();seg!=iter->end();++seg){
cout<<seg->as<string>()<<'\t';
}
cout<<endl;
}
}
void on_doubt(){
cout<<"doubt query"<<endl;
}
void on_abort(const string msg){
cout<<"query failed: "
<<msg<<endl;
}
private:
string query_;
pqxx::result results_;
};
int main(){
pqxx::connection conn("dbname=test user=terran");
if(conn.is_open()){
cout<<"Connect successful!"<<endl;
cout<<conn.options()<<endl;
}else{
cout<<"something wrong ...oops"<<endl;
return 1;
}
Trans t("SELECT * FROM test_table");
conn.perform(t);
return 0;
}
  事务的大概用法如上所示,先继承pqxx::transactor<>类(这是个模板,有默认参数),然后实现三个on_函数,把命令放在重载的函数调用操作符里面。调用方只需要简单的.perform就可以了。如果执行成功,会调用on_commit,失败会调用on_abort,提交了但是不能确定是不是成功(一般就是失去连接了),调用on_doubt。
  大概就是以上内容吧,pqxx库的实现还是蛮复杂的,其他的还要细看。


  •   我在编译的时候会提示找不到PQxx的定义,然后编译器提示找不到libpq-fe.h文件,推测是由于安装到/usr/include/postgresql而不是/usr/include的原因。如果有人知道怎么解决,请留言告知,多谢。↩


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-303204-1-1.html 上篇帖子: PostgreSQL操作问题(转载) 下篇帖子: PostgreSQL配置优化
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表