4

我想将谷歌的开放位置代码 javascript 实现放入 PostgreSQL(使用plv8 扩展),并使其可用于从 PostGIS 几何/地理数据类型进行编码/解码。

虽然我成功了,但我无法弄清楚如何只为https://github.com/google/open-location-code/blob/master/js/src/openlocationcode.js文件创建一个函数最后我将该函数的副本放入每个需要编码/解码加码的函数中。当我试图将其拉出到自己的函数中时,我可以得到一个包含 javascript 的字符串或 [Object],[object] 的字符串,而不是一个可调用的函数。

PostgreSQL 中的 plv8 扩展可以做到这一点吗?

不完整的代码片段示例(此处为完整版):

DROP FUNCTION IF EXISTS olc.encode(float,float,integer);

CREATE OR REPLACE FUNCTION olc.encode(
    p_latitude double precision,
    p_longitude double precision,
    p_code_length integer DEFAULT 10
)
  RETURNS text AS
$BODY$


 var f  =  function () {
    var OpenLocationCode = {};

    /**
     * Provides a normal precision code, approximately 14x14 meters.
     * @const {number}
     */
    OpenLocationCode.CODE_PRECISION_NORMAL = 10;

    /**
     * Provides an extra precision code, approximately 2x3 meters.
     * @const {number}
     */
    OpenLocationCode.CODE_PRECISION_EXTRA = 11;

    // A separator used to break the code into two parts to aid memorability.
    var SEPARATOR_ = '+';

    // The number of characters to place before the separator.
    var SEPARATOR_POSITION_ = 8;

    // The character used to pad codes.
    var PADDING_CHARACTER_ = '0';
4

1 回答 1

5

你有两个选择。

  1. 将函数的源代码存储在一个特殊的数据库表中,并使用selectand加载它eval()。阅读此答案中的详细信息:plv8 JavaScript 语言扩展是否可以调用 3rd 方库?

  2. 将函数放在初始化模块中,并使用配置参数设置该模块plv8.start_proc,使其在启动时自动执行。您可以在PL/v8 文档中找到详细信息。

第二个选项非常方便,不需要额外的表,但可能看起来有点棘手。一个简单的例子:我们希望square_of_sum(a, b)在所有 plv8 函数中预定义一个函数。首先,创建初始化函数:

create or replace function plv8_init()
returns void language plv8 as $$

    square_of_sum = function(a, b) {
        return (a+ b)* (a+ b)
    }

$$;

设置数据库的初始化函数:

alter database my_database set plv8.start_proc to plv8_init;

并关闭当前连接。

在所有后续会话中,该功能square_of_sum(a, b)在所有其他 plv8 功能中都是已知的,例如:

create or replace function js_test()
returns int language plv8 as $$
    return square_of_sum(3, 2)
$$;

select js_test();

 js_test
---------
      25
(1 row) 
于 2018-04-03T17:01:03.030 回答