注重体验与质量的电子书资源下载网站
分类于: 编程语言 计算机基础 云计算&大数据
简介
PostgreSQL服务器编程: 数据库技术丛书 豆 0.0分
资源最后更新于 2020-03-29 03:32:35
作者:〔美〕克洛斯(Hannu Krosing) 等
译者:戚长松
出版社:出版社机械工业出版社
出版日期:2014-10
ISBN:9787111480570
文件格式: pdf
标签: 计算机 程序设计 数据库 数据库技术丛书 关系数据库系统
简介· · · · · ·
本书由资深PostgreSQL专家撰写,系统讲解PostgreSQL服务器编程的方方面面,书中通过丰富的实例,循序渐进阐释PostgreSQL开发和扩展的相关概念及各种实用技术,包含大量实用技巧和窍门,为快速掌握PostgreSQL服务器编程提供系统实践指南。全书共10章:第1章介绍PostgreSQL服务器编程的性能;第2章从PostgreSQL的商业与技术优势等角度讨论PostgreSQL的开发环境;第3章介绍pupgsql函数,涵盖其基础结构和关键组成部分;第4章介绍返回结构化数据的功能,并展示如何将复杂数据返回给一个应用程序;第5章通过一些相关案例探究pl/pgsql触发器函数;第6章展示如何对服务器端程序进行调试;第7章介绍如何使用python进行服务器端开发;第8章深入探讨如何使用原生的c代码进行PostgreSQL扩展;第9章主要阐述如伺通过puproxy扩展数据库;第10章讨论PostgreSQL扩展程序网络架构,包括如何将代码模块发布到开源社区。作者:Hannu Kosing,Skype公司第一位数据库管理员与数据库架构师。2006年离开Skype之后,他成为2ndQuadrant公司的首席PostgreSQL咨询顾问,足迹遍布全球各地。Hannu自1995年开始使用PostgreSQL,有近20年的PostgreSQL实战经验。Jim Mlodgenski,OpenSCG公司CTO,OpenSCG是一家专注于开源技术的专业服务公司。他还曾是StormDB的CEO,StormDB是一家致力于水平扩展的云数据库公司。在加入StormDB之前,Jim是Cirrus Technology、EnterpriseDB和Fusion Technology等公司的资深研发工程师。Jim非常拥护PostgreSQL,他是美国PostgreSQL协会的董事会成员,同时也是纽约PostgreSQL用户组和费城PostgreSQL用户组的重要成员。Kirk Roybal,从1998年开始就活跃于PostgreSQL社区。他帮助建立了休斯敦、达拉斯、伯明顿等地区的PostgreSQL用户组。他在报告系统、商业智能、数据仓库、应用程序开发等领域均提供了优秀的PostgreSQL解决方案。译者:戚长松,拥有浙江大学机械工程硕士学位,专注于企业数据库开发与基于数据库的应用程序设计,拥有近10年的数据库开发经验及5年的PostgreSQL实战经验,擅长基于PostgreSQL平台进行数据仓库建模与数据挖掘。
目录
前言
第1章 PostgreSQL服务器简介
1.1 为什么在服务器中进行程序设计
1.2 关于本书的代码示例
1.3 超越简单函数
1.4 使用触发器管理相关数据
1.5 审核更改
1.6 数据清洗
1.7 定制排序方法
1.8 程序设计最佳实践
1.8.1 KISS——尽量简单(keep it simple stupid)
1.8.2 DRY——不要写重复的代码(don’t repeat yourself)
1.8.3 YAGNI——你并不需要它(you ain’t gonna need it)
1.8.4 SOA——服务导向架构(service-oriented architecture)
1.8.5 类型的扩展
1.9 关于缓存
1.10 总结——为什么在服务器中进行程序设计
1.10.1 性能
1.10.2 易于维护
1.10.3 保证安全的简单方法
1.11 小结
第2章 服务器程序设计环境
2.1 购置成本
2.2 开发者的可用性
2.3 许可证书
2.4 可预测性
2.5 社区
2.6 过程化语言
2.6.1 平台兼容性
2.6.2 应用程序设计
2.6.3 更多基础
2.7 小结
第3章 第一个PL/pgSQL函数
3.1 为什么是PL/pgSQL
3.2 PL/pgSQL函数的结构
3.3 条件表达式
3.3.1 通过计数器循环
3.3.2 对查询结果进行循环
3.3.3 PERFORM与SELECT
3.4 返回记录
3.5 处理函数结果
3.6 结论
第4章 返回结构化数据
4.1 集合与数组
4.2 返回集合
4.3 使用返回集合的函数
4.4 基于视图的函数
4.5 OUT参数与记录集
4.5.1 OUT参数
4.5.2 返回记录集
4.5.3 使用RETURNS TABLE
4.5.4 不返回预定义结构
4.5.5 返回SETOF ANY
4.5.6 可变参数列表
4.6 RETURN SETOF变量总结
4.7 返回游标
4.7.1 对从另一个函数中返回的游标进行迭代处理
4.7.2 函数返回游标(多个游标)的小结
4.8 处理结构化数据的其他方法
4.8.1 现代复杂数据类型——XML和JSON
4.8.2 XML数据类型和从函数中返回XML数据
4.8.3 以JSON格式返回数据
4.9 小结
第5章 PL/pgSQL触发器函数
5.1 创建触发器函数
5.2 简单的“嘿,我被调用了”触发器
5.3 审核触发器
5.4 无效的DELETE
5.5 无效的TRUNCATE
5.6 修改NEW记录
5.7 不可改变的字段触发器
5.8 当触发器被调用时的控制策略
5.8.1 有条件的触发器
5.8.2 在特定字段变化的触发器
5.9 可视化
5.10 传递给PL/pgSQL TRIGGER函数的变量
5.11 小结
第6章 PL/pgSQL调试
6.1 使用RAISE NOTICE进行“手动”调试
6.1.1 抛出异常
6.1.2 文件日志
6.2 可视化调试
6.2.1 安装调试器
6.2.2 安装pgAdmin3
6.2.3 使用调试器
6.3 小结
第7章 使用无限制的开发语言
7.1 不受信任的语言是否比受信任的语言差
7.2 不受信任的语言是否会拖垮数据库
7.3 为什么不受信任
7.4 PL/Python快速介绍
7.4.1 最小的PL/Python函数
7.4.2 数据类型转换
7.4.3 使用PL/Python编写简单函数
7.4.4 在数据库中运行查询
7.4.5 使用PL/Python编写触发器函数
7.4.6 构建查询
7.4.7 处理异常
7.4.8 Python中的原子性
7.4.9 PL/Python调试
7.5 跳出“SQL数据库服务器”的限制进行思考
7.5.1 在保存图像时生成缩略图
7.5.2 发送一封电子邮件
7.6 小结
第8章 使用C编写高级函数
8.1 最简单的C函数——返回(a+b)
8.1.1 add_func.c
8.1.2 Makefile
8.1.3 创建add(int,int)函数
8.1.4 add_func.sql.in
8.1.5 关于写C函数的总结
8.2 为add(int,int)添加功能
8.2.1 NULL参数的智能处理
8.2.2 与任何数量的参数一起运作
8.3 C函数编写的基础指南
8.4 来自C函数的错误报告
8.4.1 并非错误的“错误”状态
8.4.2 消息何时被发送到客户端
8.5 运行查询与调用PostgreSQL函数
8.5.1 使用SPI的示例C函数
8.5.2 数据更改的可见性
8.5.3 SPI_*函数的更多相关信息
8.6 将记录集作为参数或返回值处理
8.6.1 返回复杂类型的单个元组
8.6.2 从参数元组中提取字段
8.6.3 构建一个返回元组
8.6.4 插曲——什么是Datum
8.6.5 返回一个记录集
8.7 快速获取数据库变更
8.8 在提交/回滚时处理情况
8.9 在后端间进行同步
8.10 C语言的额外资源
8.11 小结
第9章 使用PL/Proxy扩展数据库
9.1 简单的单服务器通话
9.2 处理跨多数据库的成功分表
9.2.1 什么扩展计划有用和什么时候有用
9.2.2 跨多服务器的数据分区
9.2.3 PL/Proxy——分区语言
9.2.4 从单数据库移动数据到分区的数据库
9.3 小结
第10章 发布自己的PostgreSQL扩展程序
10.1 什么时候创建扩展程序
10.2 未封装的扩展程序
10.3 扩展程序版本
10.4 .control文件
10.5 构建扩展程序
10.6 安装扩展程序
10.7 发布扩展程序
10.7.1 关于PostgreSQL Extension Network的简介
10.7.2 注册以发布扩展程序
10.7.3 创建扩展项目的简单方法
10.7.4 提供扩展程序的相关元数据
10.7.5 编写扩展代码
10.7.6 创建程序包
10.7.7 向PGXN提交程序包
10.8 安装PGXN上的扩展程序
10.9 小结