PostgreSQL 12 文档: 部分 V. 服务器编程

本文涉及的产品
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
简介: 部分 V. 服务器编程这部分关于使用用户定义的函数、数据类型、触发器等扩展服务器功能。这些是高级主题,读者应该在理解了有关PostgreSQL的所有其他用户文档之后才阅读这些主题。这一部分的后面一些章节描述PostgreSQL发布中可用的服务器端编程语言,以及与服务器端编程语言相关的一般性问题。在深入研究服务器端编程语言的材料之前,请至少阅读第 37 章中前几节(覆盖函数)。

部分 V. 服务器编程

这部分关于使用用户定义的函数、数据类型、触发器等扩展服务器功能。这些是高级主题,读者应该在理解了有关PostgreSQL的所有其他用户文档之后才阅读这些主题。这一部分的后面一些章节描述PostgreSQL发布中可用的服务器端编程语言,以及与服务器端编程语言相关的一般性问题。在深入研究服务器端编程语言的材料之前,请至少阅读第 37 章中前几节(覆盖函数)。

目录

37. 扩展 SQL

37.1. 扩展性如何工作

37.2. PostgreSQL类型系统

37.3. 用户定义的函数

37.4. 用户定义的过程

37.5. 查询语言(SQL)函数

37.6. 函数重载

37.7. 函数易变性分类

37.8. 过程语言函数

37.9. 内部函数

37.10. C 语言函数

37.11. 函数优化信息

37.12. 用户定义的聚集

37.13. 用户定义的类型

37.14. 用户定义的操作符

37.15. 操作符优化信息

37.16. 索引的接口扩展

37.17. 打包相关对象到一个扩展中

37.18. 扩展的构建基础设施

38. 触发器

38.1. 触发器行为概述

38.2. 数据改变的可见性

38.3. 用 C 编写触发器函数

38.4. 一个完整的触发器实例

39. 事件触发器

39.1. 事件触发器行为总览

39.2. 事件触发器触发矩阵

39.3. 用 C 编写事件触发器函数

39.4. 一个完整的事件触发器例子

39.5. 一个表重写事件触发器例子

40. 规则系统

40.1. 查询树

40.2. 视图和规则系统

40.3. 物化视图

40.4. INSERT、UPDATE和DELETE上的规则

40.5. 规则和权限

40.6. 规则和命令状态

40.7. 规则 vs 触发器

41. 过程语言

41.1. 安装过程语言

42. PL/pgSQL - SQL过程语言

42.1. 综述

42.2. PL/pgSQL的结构

42.3. 声明

42.4. 表达式

42.5. 基本语句

42.6. 控制结构

42.7. 游标

42.8. 事务管理

42.9. 错误和消息

42.10. 触发器函数

42.11. PL/pgSQL的内部

42.12. PL/pgSQL开发提示

42.13. 从Oracle PL/SQL 移植

43. PL/Tcl - Tcl 过程语言

43.1. 概述

43.2. PL/Tcl 函数和参数

43.3. PL/Tcl 中的数据值

43.4. PL/Tcl 中的全局数据

43.5. 从 PL/Tcl 访问数据库

43.6. PL/Tcl 中的触发器函数

43.7. PL/Tcl 中的事件触发器函数

43.8. PL/Tcl 中的错误处理

43.9. PL/Tcl中的显式子事务

43.10. 事务管理

43.11. PL/Tcl配置

43.12. Tcl 过程名

44. PL/Perl - Perl 过程语言

44.1. PL/Perl 函数和参数

44.2. PL/Perl 中的数据值

44.3. 内建函数

44.4. PL/Perl 中的全局值

44.5. 可信的和不可信的 PL/Perl

44.6. PL/Perl 触发器

44.7. PL/Perl 事件触发器

44.8. PL/Perl 下面的东西

45. PL/Python - Python 过程语言

45.1. Python 2 vs. Python 3

45.2. PL/Python 函数

45.3. 数据值

45.4. 共享数据

45.5. 匿名代码块

45.6. 触发器函数

45.7. 数据库访问

45.8. 显式子事务

45.9. 事务管理

45.10. 实用函数

45.11. 环境变量

46. 服务器编程接口

46.1. 接口函数

46.2. 接口支持函数

46.3. 内存管理

46.4. 事务管理

46.5. 数据改变的可见性

46.6. 例子

47. 后台工作者进程

48. 逻辑解码

48.1. 逻辑解码的例子

48.2. 逻辑解码概念

48.3. 流复制协议接口

48.4. 逻辑解码的 SQL 接口

48.5. 与逻辑解码相关的系统目录

48.6. 逻辑解码输出插件

48.7. 逻辑解码输出写入器

48.8. 逻辑解码的同步复制支持

49. 复制进度追踪

相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
27天前
|
存储 关系型数据库 数据库
【赵渝强老师】PostgreSQL的服务器日志文件
本文介绍了PostgreSQL数据库的物理存储结构,重点讨论了服务器日志文件。通过`pg_ctl`命令启动PostgreSQL实例时,使用`-l`参数指定日志文件位置,记录数据库启动、运行及关闭过程中的关键信息。附有相关视频讲解和日志文件示例。
|
7月前
|
缓存 监控 Java
Java Socket编程最佳实践:优化客户端-服务器通信性能
【6月更文挑战第21天】Java Socket编程优化涉及识别性能瓶颈,如网络延迟和CPU计算。使用非阻塞I/O(NIO)和多路复用技术提升并发处理能力,减少线程上下文切换。缓存利用可减少I/O操作,异步I/O(AIO)进一步提高效率。持续监控系统性能是关键。通过实践这些策略,开发者能构建高效稳定的通信系统。
198 1
|
8月前
|
安全 Java 数据处理
Python网络编程基础(Socket编程)多线程/多进程服务器编程
【4月更文挑战第11天】在网络编程中,随着客户端数量的增加,服务器的处理能力成为了一个重要的考量因素。为了处理多个客户端的并发请求,我们通常需要采用多线程或多进程的方式。在本章中,我们将探讨多线程/多进程服务器编程的概念,并通过一个多线程服务器的示例来演示其实现。
|
8月前
|
网络协议 Python
pythonTCP客户端编程连接服务器
【4月更文挑战第6天】本教程介绍了TCP客户端如何连接服务器,包括指定服务器IP和端口、发送连接请求、处理异常、进行数据传输及关闭连接。在Python中,使用`socket`模块创建Socket对象,然后通过`connect()`方法尝试连接服务器 `(server_ip, server_port)`。成功连接后,利用`send()`和`recv()`进行数据交互,记得在通信完成后调用`close()`关闭连接,确保资源释放和程序稳定性。
|
4月前
|
安全 Java 调度
Java编程时多线程操作单核服务器可以不加锁吗?
Java编程时多线程操作单核服务器可以不加锁吗?
50 2
|
7月前
|
Java 应用服务中间件 开发者
【实战指南】Java Socket编程:构建高效的客户端-服务器通信
【6月更文挑战第21天】Java Socket编程用于构建客户端-服务器通信。`Socket`和`ServerSocket`类分别处理两端的连接。实战案例展示了一个简单的聊天应用,服务器监听端口,接收客户端连接,并使用多线程处理每个客户端消息。客户端连接服务器,发送并接收消息。了解这些基础,加上错误处理和优化,能帮你开始构建高效网络应用。
479 10
|
7月前
|
IDE Java 开发工具
从零开始学Java Socket编程:客户端与服务器通信实战
【6月更文挑战第21天】Java Socket编程教程带你从零开始构建简单的客户端-服务器通信。安装JDK后,在命令行分别运行`SimpleServer`和`SimpleClient`。服务器监听端口,接收并回显客户端消息;客户端连接服务器,发送“Hello, Server!”并显示服务器响应。这是网络通信基础,为更复杂的网络应用打下基础。开始你的Socket编程之旅吧!
109 3
|
3月前
|
Java Linux
java读取linux服务器下某文档的内容
java读取linux服务器下某文档的内容
44 3
java读取linux服务器下某文档的内容
|
7月前
|
Java
Java Socket编程与多线程:提升客户端-服务器通信的并发性能
【6月更文挑战第21天】Java网络编程中,Socket结合多线程提升并发性能,服务器对每个客户端连接启动新线程处理,如示例所示,实现每个客户端的独立操作。多线程利用多核处理器能力,避免串行等待,提升响应速度。防止死锁需减少共享资源,统一锁定顺序,使用超时和重试策略。使用synchronized、ReentrantLock等维持数据一致性。多线程带来性能提升的同时,也伴随复杂性和挑战。
117 0
|
7月前
|
安全 Java 网络安全
Java Socket编程教程:构建安全可靠的客户端-服务器通信
【6月更文挑战第21天】构建安全的Java Socket通信涉及SSL/TLS加密、异常处理和重连策略。示例中,`SecureServer`使用SSLServerSocketFactory创建加密连接,而`ReliableClient`展示异常捕获与自动重连。理解安全意识,如防数据截获和中间人攻击,是首要步骤。通过良好的编程实践,确保网络应用在复杂环境中稳定且安全。
116 0