最近在考量数据库的选型,考虑后期把数据切换到postgresql ,postgresql源码用c实现,代码很精炼完美,值得学习下

首先去pgsql官网下载最新的源码 ,然后还需要perl,bison

先安装ActiverPerl-5.22.1.2201x64.msi 默认装在c盘,一路点next安装。

我是将Perl是安装到了C盘,则在系统环境变量中添加Perl的C盘路径位置。

打开postgresql9.5.2 文件夹,找到MKVcbuild.pm文件(如下图所示),用文本编辑器打开,修改其中my $vsVersion = DetermineVisualStudioVersion()该行,变为my $vsVersion = “12.0.0”,VS2013 对应的version版本是12.0

反键编辑

打开cmd或用vs2013自带的x64 cmd命令工具打开, 切换到源码msvc目录

MSVC目录下,输入perl build.pl DEBUG  然后开始编译代码,这里需要5-6分钟,速度根据跟人的电脑配置来定

生成源码完成后最后如图所示

接着在命令编辑器中继续输入perl install.pl path,例如:

perl install.pl D:\pgbin

生成后的效果如图

这里很关键 如果没有下面的操作 你就需要去源码里面去掉管理员权限的判断,如果用超级管理员运行 会报错

我们用cmd命令添加一个 postgres用户

net user postgres postgres /add

打开运行输入 runas /user:postgres cmd.exe

此时会以postgres权限打开cmd [一定要按此操作]

我们先直接打开cmd 初始化数据库DB,注意下图是没有用postgres用户打开的cmd 也能初始化,但是接下来的连接等就会有问题了,不稳定

用postgres用户打开cmd

postgres.exe -D DB 这里就启动了一个server实例,开始监听所有的链接

这里就开始监听了

输入postgres.exe -D DB   (注意-D中的D一定要大写),这里不一定是DB,你也可以自己定

以上几次测试

下面我 输入 postgres.exe -D pgsql 

我这里用的数据库pgsql

到这里pgsql服务器算是启动好了。

然后我们用navcat 连接一下试试,建一个数据库

打开源码项目,这里加载会要几分钟时间

backend\executor\execMain.c ,依次打上断点

最后我们这里打开 psql源码, 打开pquery.c,里面设置好断点

启动调试,进断点了。

今天还有点晚了,接下来有时间再分享源码结构的学习

关于源码的说明有专门的网站 http://doxygen.postgresql.org/

接下来就可以开始postgresql的源码学习之旅了,你就可以通过navcat建表,删表,插入数据,update,多种操作,尽情的揉虐 pgsql源码了。希望此文能给大家学习pgsql一些帮助,这款数据库真的很优秀,如果你去用了会有一种相见恨晚的感觉

调试postgresql9.5.2最新源码的更多相关文章

  1. Android最新源码4.3下载-教程 2013-11

    Android最新源码4.3下载-教程 有的下载会出现问题: 需要 修改manifest.xml中的fetch: "git://Android.git.linaro.org/"  ...

  2. 即时通信系统中如何实现:全局系统通知,并与Web后台集成?【低调赠送:QQ高仿版GGTalk 5.1 最新源码】

    像QQ这样的即时通信软件,时不时就会从桌面的右下角弹出一个小窗口,或是显示一个广告.或是一个新闻.或是一个公告等.在这里,我们将其统称为“全局系统通知”.很多使用GGTalk的朋友都建议我加上一个类似 ...

  3. LAMP最新源码一键安装脚本

    Linux+Apache+MySQL+PHP (脚本可以选择是否安装+Pureftpd+User manager for PureFTPd+phpMyAdmin+memcache),添加虚拟主机请执行 ...

  4. 在Ubuntu上下载、编译和安装Android最新源码

    看完了前面说的几本书之后,对Linux Kernel和Android有一定的认识了,是不是心里蠢蠢欲动,想小试牛刀自己编译一把Android源码了呢?一直习惯使用Windows系统,而Android源 ...

  5. Android事件传递机制详解及最新源码分析——ViewGroup篇

    版权声明:本文出自汪磊的博客,转载请务必注明出处. 在上一篇<Android事件传递机制详解及最新源码分析--View篇>中,详细讲解了View事件的传递机制,没掌握或者掌握不扎实的小伙伴 ...

  6. spark最新源码下载并导入到开发环境下助推高质量代码(Scala IDEA for Eclipse和IntelliJ IDEA皆适用)(以spark2.2.0源码包为例)(图文详解)

    不多说,直接上干货! 前言   其实啊,无论你是初学者还是具备了有一定spark编程经验,都需要对spark源码足够重视起来. 本人,肺腑之己见,想要成为大数据的大牛和顶尖专家,多结合源码和操练编程. ...

  7. 即时通信系统中实现全局系统通知,并与Web后台集成【附C#开源即时通讯系统(支持广域网)——QQ高仿版IM最新源码】

    像QQ这样的即时通信软件,时不时就会从桌面的右下角弹出一个小窗口,或是显示一个广告.或是一个新闻.或是一个公告等.在这里,我们将其统称为“全局系统通知”.很多使用C#开源即时通讯系统——GGTalk的 ...

  8. 使用 IntelliJ IDEA 导入 Spark 最新源码及编译 Spark 源代码(博主强烈推荐)

    前言   其实啊,无论你是初学者还是具备了有一定spark编程经验,都需要对spark源码足够重视起来. 本人,肺腑之己见,想要成为大数据的大牛和顶尖专家,多结合源码和操练编程. 准备工作 1.sca ...

  9. 如何做到在虚拟数据库和真实数据库之间自由切换?【低调赠送:QQ高仿版GG 4.4 最新源码】

    记得以前在公司上班时,有时候白天的活没干完,我就会把工作带回家晚上加班继续做.但是,我们开发用的数据库是部署在公司局网内部的一台服务器上的,在家里是肯定连不上这台机器的.在家里没有数据库,服务端就跑不 ...

随机推荐

  1. 精通 Oracle+Python,第 1 部分:查询最佳应践

    原文链接:http://www.oracle.com/technetwork/cn/articles/dsl/mastering-oracle-python-1391323-zhs.html 在 Py ...

  2. Python正则表达式学习

    1.Python的正则表达式需要用到re模块,有两个方法:match和search,match从第一个字符串开始匹配,search从任意字符串开始匹配,所以match比search严格. 如果匹配成功 ...

  3. vs2012生成的项目,如何在只装有VS2010的电脑上打开

    步骤: 1.用记事本打开Vs2012生成的项目解决方案文件(.sln文件)文件 2.修改前两行 Microsoft Visual Studio Solution File, Format Versio ...

  4. WPF拖动绘制

    using System; using System.Windows; using System.Windows.Controls; using System.Windows.Input; using ...

  5. STM32下载方法

    一.JLINK下载方法 1.硬件设置 Boot0,Boot1 = 0,*(测试通过) Boot0,Boot1 = 1,0或者0,1(未测试) 2.软件设置 MDK设置 ① 选择Project -> ...

  6. Java中double类型的数据精确到小数点后两位

    Java中double类型的数据精确到小数点后两位 多余位四舍五入,四种方法 一: double f = 111231.5585;BigDecimal b = new BigDecimal(f); d ...

  7. Servlet高级应用---Servlet与缓存

    一]设置缓存文件的有效日期        重点方法:            HttpServletRequest类:                    1>String getRequest ...

  8. Python模块subprocess小记

    转自:http://www.oschina.net/question/234345_52660 熟悉了Qt的QProcess以后,再回头来看python的subprocess总算不觉得像以前那么恐怖了 ...

  9. 【POJ 1741】 Tree (树的点分治)

    Tree   Description Give a tree with n vertices,each edge has a length(positive integer less than 100 ...

  10. 我新买的红米手机,新浪和360浏览器都能进,也能看电视,就是不能上手机QQ和微信

    1.请您在桌面下.点击手菜单键-全局搜索,输入网络助手,点击流量排行,点击批量联网控制,查看该软件下(不能上网的应用)wifi和流量2G/3G下方的选项是否都勾选的.如果没有勾选,请您勾选. 2:仍然 ...