当前位置:网站首页>Golden Warehouse Database KingbaseGIS User Manual (6.10. Geometric Object Operation Operator)
Golden Warehouse Database KingbaseGIS User Manual (6.10. Geometric Object Operation Operator)
2022-08-11 05:02:00 【A thousand sails pass by the side of the sinking boat_】
6.10. Geometry object manipulation operators
6.10.1. &&
&& — If the input objectA的2D bounding box与输入对象B的2D bounding box有交集,则返回TRUE
用法
boolean &&( geometry A , geometry B ); boolean &&( geography A , geography B );
描述
If the input objectA的2D bounding box与输入对象B的2D bounding box有交集,则返回TRUE
注意
This operator takes advantage of any available index on the geometry object
样例
SELECT tbl1.column1, tbl2.column1, tbl1.column2 && tbl2.column2 AS overlaps FROM ( VALUES (1, 'LINESTRING(0 0, 3 3)'::geometry), (2, 'LINESTRING(0 1, 0 5)'::geometry)) AS tbl1, ( VALUES (3, 'LINESTRING(1 2, 4 6)'::geometry)) AS tbl2; column1 | column1 | overlaps ---------+---------+---------- 1 | 3 | t 2 | 3 | f (2 rows)
参考
|&>,&>,&<|,&<, ~, @
6.10.2. &&&
&&& —If the input objectA的n-D bounding box与输入对象B的n-D bounding box有交集,则返回TRUE.
用法
boolean &&&( geometry A , geometry B );
描述
If the input objectA的n-D bounding box与输入对象B的n-D bounding box有交集,则返回TRUE.
注意
This operator can take advantage of any index on the geometry object.
样例: 3D LineStrings
SELECT tbl1.column1, tbl2.column1, tbl1.column2 &&& tbl2.column2 AS overlaps_3d, tbl1.column2 && tbl2.column2 AS overlaps_2d FROM ( VALUES (1, 'LINESTRING Z(0 0 1, 3 3 2)'::geometry), (2, 'LINESTRING Z(1 2 0, 0 5 -1)'::geometry)) AS tbl1, ( VALUES (3, 'LINESTRING Z(1 2 1, 4 6 1)'::geometry)) AS tbl2; column1 | column1 | overlaps_3d | overlaps_2d ---------+---------+-------------+------------- 1 | 3 | t | t 2 | 3 | f | t
样例: 3M LineStrings
SELECT tbl1.column1, tbl2.column1, tbl1.column2 &&& tbl2.column2 AS overlaps_3zm, tbl1.column2 && tbl2.column2 AS overlaps_2d FROM ( VALUES (1, 'LINESTRING M(0 0 1, 3 3 2)'::geometry), (2, 'LINESTRING M(1 2 0, 0 5 -1)'::geometry)) AS tbl1, ( VALUES (3, 'LINESTRING M(1 2 1, 4 6 1)'::geometry)) AS tbl2; column1 | column1 | overlaps_3zm| overlaps_2d ---------+---------+-------------+------------- 1 | 3 | t | t 2 | 3 | f | t
参考
&&
6.10.3. &<
&< — If you import geometric objectsA的bounding boxwith the input geometry objectB的bounding boxcoincident or to the right of the latter,则返回TRUE
用法
boolean &<( geometry A , geometry B );
描述
If you import geometric objectsA的bounding boxwith the input geometry objectB的bounding boxcoincident or to the left of the latter,则返回TRUE.或者更准确地说,Override or not import geometry objectsB 的bounding box的右侧.
注意
This operator can take advantage of any index on the geometry object.
样例
SELECT tbl1.column1, tbl2.column1, tbl1.column2 &< tbl2.column2 AS overleft FROM ( VALUES (1, 'LINESTRING(1 2, 4 6)'::geometry)) AS tbl1, ( VALUES (2, 'LINESTRING(0 0, 3 3)'::geometry), (3, 'LINESTRING(0 1, 0 5)'::geometry), (4, 'LINESTRING(6 0, 6 1)'::geometry)) AS tbl2; column1 | column1 | overleft ---------+---------+---------- 1 | 2 | f 1 | 3 | f 1 | 4 | t (3 rows)
参考
&&, |&>, &>, &<|
6.10.4. &<|
&<| — 如果A的bounding boxcovered or inB的bounding box的下侧,则返回TRUE.
用法
boolean &<|( geometry A , geometry B );
描述
如果A的bounding boxcovered or inB的bounding box的下侧,则返回TRUE,Or more precisely overwrite or not input geometry objectsB的 bounding box的上侧.
- 该函数支持CircularString和Curve几何类型对象. 
- 该函数支持 Polyhedral Surface类型几何对象. 
注意
This operator can take advantage of any index on the geometry object.
样例
SELECT tbl1.column1, tbl2.column1, tbl1.column2 &<| tbl2.column2 AS overbelow FROM ( VALUES (1, 'LINESTRING(6 0, 6 4)'::geometry)) AS tbl1, ( VALUES (2, 'LINESTRING(0 0, 3 3)'::geometry), (3, 'LINESTRING(0 1, 0 5)'::geometry), (4, 'LINESTRING(1 2, 4 6)'::geometry)) AS tbl2; column1 | column1 | overbelow ---------+---------+----------- 1 | 2 | f 1 | 3 | t 1 | 4 | t (3 rows)
参考
&&, |&>, &>, &<
6.10.5. &>
&> —如果A的bounding boxcovered or inB的bounding box的右侧,则返回TRUE.
用法
boolean &>( geometry A , geometry B );
描述
如果A的bounding boxcovered or inB的bounding box的右侧,则返回TRUE,Or more precisely overwrite or not input geometry objectsB的bounding box的左侧.
注意
This operator can take advantage of any index on the geometry object.
样例
SELECT tbl1.column1, tbl2.column1, tbl1.column2 &> tbl2.column2 AS overright FROM ( VALUES (1, 'LINESTRING(1 2, 4 6)'::geometry)) AS tbl1, ( VALUES (2, 'LINESTRING(0 0, 3 3)'::geometry), (3, 'LINESTRING(0 1, 0 5)'::geometry), (4, 'LINESTRING(6 0, 6 1)'::geometry)) AS tbl2; column1 | column1 | overright -----------+---------+----------- 1 |2 | t 1 |3 | t 1 |4 | f (3 rows)
参考
&&, |&>, &<|, &<
6.10.6. <<
<< — 如果A的bounding box严格地在B的bounding box左侧,则返回TRUE.
用法
boolean <<( geometry A , geometry B );
描述
如果A的bounding box严格地在B的bounding box左侧,则返回TRUE.
注意
This operator can take advantage of any index on the geometry object.
样例
SELECT tbl1.column1, FROM ( VALUES (1, 'LINESTRING (1 ( VALUES (2, 'LINESTRING (0 (3, 'LINESTRING (6 (4, 'LINESTRING (2 tbl2.column1, tbl1.column2 << tbl2.column2 AS left 2, 1 5)'::geometry)) AS tbl1, 0, 4 3)'::geometry), 0, 6 5)'::geometry), 2, 5 6)'::geometry)) AS tbl2; column1 | column1 | left ---------+---------+------ 1 | 2 | f 1 | 3 | t 1 | 4 | t (3 rows)
参考
>>, |>>, <<|
6.10.7. <<|
<<| —如果A的bounding box严格地在B的bounding box下侧,则返回TRUE
用法
boolean <<|( geometry A , geometry B );
描述
如果A的bounding box严格地在B的bounding box下侧,则返回TRUE
注意
This operator can take advantage of any index on the geometry object.
样例
SELECT tbl1.column1, FROM ( VALUES (1, 'LINESTRING (0 ( VALUES tbl2.column1, tbl1.column2 <<| tbl2.column2 AS below 0, 4 3)'::geometry)) AS tbl1, (2, LINESTRING (1 4, 1 7)'::geometry), (3, 'LINESTRING (6 (4, 'LINESTRING (2 1, 6 5)'::geometry), 3, 5 6)'::geometry)) AS tbl2; column1 | column1 | below ---------+---------+------- 1 | 2 | t 1 | 3 | f 1 | 4 | f (3 rows)
参考
<<, >>, |>>
6.10.8. =
= — 当 geometry/geography When the value and order of the sequence of object coordinates of type are the same,返回 true.
用法
boolean =( geometry A , geometry B ); boolean =( geography A , geography B );
描述
当 geometry/geography When the value and order of the sequence of object coordinates of type are the same,返回 true. KingbaseESUse operators defined for geometric objects=,<和>to perform internal sorting and comparison of geometric objects(例如在GROUP BY或ORDER BY这样的SQL子句中).
注意
只有当 geometry/geography Objects of type are the same in all respects:相同的坐标点,the same order of coordinates,This operator will determine them as equal. 对于“Spatial Equivalence”,The order of the coordinate points may be ignored,will have different representations,But objects that cover the same spatial extent are judged to be equivalent.It should be considered at this time ST_OrderingEquals 或 ST_Equals.
警告
This operator does not take advantage of indices on geometry objects.If you want to use the index to check for equivalence,Please use in combination = 和 && 操作符.
- 该函数支持CircularString和Curve几何类型对象 
- 该函数支持 Polyhedral Surface类型几何对象. 
样例
SELECT 'LINESTRING(0 0, 0 1, 1 0)'::geometry = 'LINESTRING(1 1, 0 0)'::geometry;
?column?
----------
t
(1 row)
SELECT ST_AsText(column1)FROM ( VALUES
('LINESTRING(0 0, 1 1)'::geometry),
('LINESTRING(1 1, 0 0)'::geometry)) AS foo;
st_astext
---------------------
LINESTRING(0 0,1 1)
LINESTRING(1 1,0 0)
(2 rows)
注意:此处的 GROUP BY 子句使用 = No. Compare geometric objects for equality.
SELECT ST_AsText(column1)
FROM ( VALUES
('LINESTRING(0 0, 1 1)'::geometry),
('LINESTRING(1 1, 0 0)'::geometry)) AS foo
GROUP BY column1;
st_astext
---------------------
LINESTRING(0 0,1 1)(1 row)
SELECT ST_GeomFromText('POINT(1707296.37 4820536.77)') =
ST_GeomFromText('POINT(1707296.27 4820536.87)') As pt_intersect;
pt_intersect
-------------
f
参考
ST_Equals, ST_OrderingEquals
6.10.9. >>
>> — If geometry objectA的bounding boxStrictly in geometric objectsB的右边,则返回true.
用法
boolean >>( geometry A , geometry B );
描述
If geometry objectA的bounding boxStrictly in geometric objectsB的右边,则返回true.
注意
This operator can take advantage of any index on the geometry object.
样例
SELECT tbl1.column1, tbl2.column1, tbl1.column2 >> tbl2.column2 AS right FROM ( VALUES (1, 'LINESTRING (2 3, 5 6)'::geometry)) AS tbl1, ( VALUES (2, 'LINESTRING (1 4, 1 7)'::geometry), (3, 'LINESTRING (6 1, 6 5)'::geometry), (4, 'LINESTRING (0 0, 4 3)'::geometry)) AS tbl2; column1 | column1 | right ---------+---------+------- 1 | 2 | t 1 | 3 | f 1 | 4 | f (3 rows)
参考
<<, |>>, <<|
6.10.10. @
@ —If geometry objectA的bounding boxthe geometric objectB的bounding boxStrictly contain,则返回true.
用法
boolean @( geometry A , geometry B );
描述
If geometry objectA的bounding boxthe geometric objectB的bounding boxStrictly contain,则返回true.
注意
This operator can take advantage of any index on the geometry object.
样例
SELECT tbl1.column1, tbl2.column1, tbl1.column2 @ tbl2.column2 AS contained FROM ( VALUES (1, 'LINESTRING (1 1, 3 3)'::geometry)) AS tbl1, ( VALUES (2, 'LINESTRING (0 0, 4 4)'::geometry), (3, 'LINESTRING (2 2, 4 4)'::geometry), (4, 'LINESTRING (1 1, 3 3)'::geometry)) AS tbl2; column1 | column1 | contained ---------+---------+----------- 1 | 2 | t 1 | 3 | f 1 | 4 | t (3 rows)
参考
~, &&
6.10.11. |&>
|&> —If geometry objectA的bounding box覆盖B的bounding box或在B的bounding box上面,则返回true
用法
boolean |&>( geometry A , geometry B );
描述
If geometry objectA的bounding box覆盖B的bounding box或在B的bounding box上面,则返回true,Or more precisely coverB的boundingbox或者不在B的bounding box下面.
注意
This operator can take advantage of any index on the geometry object.
样例
SELECT tbl1.column1, tbl2.column1, tbl1.column2 |&> tbl2.column2 AS overabove FROM ( VALUES (1, 'LINESTRING(6 0, 6 4)'::geometry)) AS tbl1, ( VALUES (2, 'LINESTRING(0 0, 3 3)'::geometry), (3, 'LINESTRING(0 1, 0 5)'::geometry), (4, 'LINESTRING(1 2, 4 6)'::geometry)) AS tbl2; column1 | column1 | overabove ---------+---------+----------- 1 | 2 | t 1 | 3 | f 1 | 4 | f (3 rows)
参考
&&, &>, &<|, &<
6.10.12. |>>
|>> — 如果A的bounding box严格地在B的bounding box上面,则返回TRUE.
用法
boolean |>>( geometry A , geometry B );
描述
如果A的bounding box严格地在B的bounding box上面,则返回TRUE.
注意
This operator can take advantage of any index on the geometry object.
样例
SELECT tbl1.column1, tbl2.column1, tbl1.column2 |>> tbl2.column2 AS above FROM ( VALUES (1, 'LINESTRING (1 4, 1 7)'::geometry)) AS tbl1, ( VALUES (2, 'LINESTRING (0 0, 4 2)'::geometry), (3, 'LINESTRING (6 1, 6 5)'::geometry), (4, 'LINESTRING (2 3, 5 6)'::geometry)) AS tbl2; column1 | column1 | above ---------+---------+------- 1 | 2 | t 1 | 3 | f 1 | 4 | f (3 rows)
参考
<<, >>, <<|
6.10.13. ~
~ —如果A的bounding box包含B的bounding box,则返回TRUE
用法
boolean ~( geometry A , geometry B );
描述
如果A的bounding box包含B的bounding box,则返回TRUE
注意
This operator can take advantage of any index on the geometry object.
样例
SELECT tbl1.column1, tbl2.column1, tbl1.column2 ~ tbl2.column2 AS contains FROM ( VALUES (1, 'LINESTRING (0 0, 3 3)'::geometry)) AS tbl1, ( VALUES (2, 'LINESTRING (0 0, 4 4)'::geometry), (3, 'LINESTRING (1 1, 2 2)'::geometry), (4, 'LINESTRING (0 0, 3 3)'::geometry)) AS tbl2; column1 | column1 | contains ---------+---------+---------- 1 | 2 | f 1 | 3 | t 1 | 4 | t (3 rows)
参考
@,&&
6.10.14. ~=
~= —如果A的bounding box和B的bounding box相同,则返回TRUE.
用法
boolean ~=( geometry A , geometry B );
描述
如果A的bounding box和B的bounding box相同,则返回TRUE.
注意
This operator can take advantage of any index on the geometry object.
- 该函数支持 Polyhedral Surface类型几何对象. 
样例
select 'LINESTRING(0 0, 1 1)'::geometry ~= 'LINESTRING(0 1, 1 0)'::geometry as equality; equality | -----------------+---------- t |
参考
ST_Equals, ST_OrderingEquals, =
6.10.15. <->
<-> — Returns between two geometry objects 2D 距离.
用法
double precision <->( geometry A , geometry B ); double precision <->( geography A , geography B );
描述
Returns between two geometry objects 2D 距离. 用于在 ORDER BY In the clause, the index is used to find the nearest neighbor result set. 对于 geography 类型,returns the distance on the ellipsoid.
注意
This operator can be used on any geometric object 2D GiST 索引.This operator is different from other operators,Spatial index usage can only be used for ORDER BY 子句的场景.
注意
If one of the geometry objects of the input parameter is a constant(不在子查询中),例如'SRID=3005;POINT(1011102450541)'::geometry则使用索引,If both the left and right sides of the operator are normalgeometry,那么不会使用索引
样例
SELECT ST_Distance(geom, 'SRID=3005;POINT(1011102 450541)'::geometry) as d,edabbr, vaabbr FROM va2005 ORDER BY d limit 10; d | edabbr | vaabbr ------------------+--------+-------- 0 | ALQ | 128 5541.57712511724 | ALQ | 129A 5579.67450712005 | ALQ | 001 6083.4207708641 | ALQ | 131 7691.2205404848 | ALQ | 003 7900.75451037313 | ALQ | 122 8694.20710669982 | ALQ | 129B 9564.24289057111 | ALQ | 130 12089.665931705 | ALQ | 127 18472.5531479404 | ALQ | 002 (10 rows) KNNThe raw result of the algorithm:
SELECT st_distance(geom, 'SRID=3005;POINT(1011102 450541)'::geometry) as d,edabbr, vaabbr FROM va2005 ORDER BY geom <-> 'SRID=3005;POINT(1011102 450541)'::geometry limit 10; d | edabbr | vaabbr ------------------+--------+-------- 0 | ALQ | 128 5579.67450712005 | ALQ | 001 5541.57712511724 | ALQ | 129A 8694.20710669982 | ALQ | 129B 9564.24289057111 | ALQ | 130 6083.4207708641 | ALQ | 131 12089.665931705 | ALQ | 127 24795.264503022 | ALQ | 124 24587.6584922302 | ALQ | 123 26764.2555463114 | ALQ | 125 (10 rows)
Note the items that are misplaced on the actual distance ordering,and the different items that actually show up in the top ten. 最后,The result of mixing is :
WITH index_query AS ( SELECT ST_Distance(geom, 'SRID=3005;POINT(1011102 450541)'::geometry) as d,edabbr, vaabbr FROM va2005 ORDER BY geom <-> 'SRID=3005;POINT(1011102 450541)'::geometry LIMIT 100) SELECT * FROM index_query ORDER BY d limit 10; d | edabbr | vaabbr ------------------+--------+-------- 0 | ALQ | 128 5541.57712511724 | ALQ | 129A 5579.67450712005 | ALQ | 001 6083.4207708641 | ALQ | 131 7691.2205404848 | ALQ | 003 7900.75451037313 | ALQ | 122 8694.20710669982 | ALQ | 129B 9564.24289057111 | ALQ | 130 12089.665931705 | ALQ | 127 18472.5531479404 | ALQ | 002 (10 rows)
参考
ST_DWithin, ST_Distance,<#>
6.10.16. |=|
|=| — Returns between two trajectories3D距离.
用法
double precision |=|( geometry A , geometry B );
描述
|=|The operator returns the distance between two trajectories3D距离(参见 ST_IsValidTrajectory).
这与 ST_DistanceCPA 函数功能相同,But as an operator,It can be used based on N Dimensional index for nearest neighbor search.
注意
This operator can be used on geometric objects N 维 GiST 索引.It differs from other operators in that,只有用在 ORDER BY A spatial index will be used only when in the clause.
注意
This operator is constant only if one of the geometry objects is constant(Not in subqueries or CTE中)的时候才会使用索引,例如:'SRID=3005;LINESTRINGM(0 0 0,0 0 1)'::geometry .
样例
Save the trace produced by a query in ksql 变量中.
\set qt 'ST_AddMeasure(ST_MakeLine(ST_MakePointM(-350,300,0),ST_MakePointM(-410,490,0)),10,20)'
SELECT track_id, dist FROM (
SELECT track_id, ST_DistanceCPA(tr,:qt) dist
FROM trajectories
ORDER BY tr |=| :qt
LIMIT 5
) foo;
track_id        dist
----------+-------------------
      395 | 0.576496831518066
      380 |  5.06797130410151
      390 |  7.72262293958322
      385 |   9.8004461358071
      405 |  10.9534397988433
(5 rows)
参考
ST_DistanceCPA, ST_ClosestPointOfApproach, ST_IsValidTrajectory
6.10.17. <#>
<#> —Returns two geometry objectsbounding box之间的距离.This operator uses floating-point precision(Relative to the basic points used by the objectdouble双精度).for other geometry types,返回的是bounding boxThe double-precision output distance between the center points of .Sort and use by distanceKNN The function is useful when limiting the number of output objects by neighbors.
用法
double precision <#>( geometry A , geometry B );
描述
<#>operator computes two single-precision onesbounding box之间的距离,If there is a spatial index,Use a spatial index.This function is useful for distance sorting after calculation using nearest neighbors.
注意
This operator can take advantage of any index on the geometry object.This operator is different from other operators,Spatial index usage can only be used for ORDER BY 子句的场景.
注意
This operator only works if one of the geometry objects is constant,例如ORDER BY (ST_GeomFromText('POINT(1 2)') <#> geom)会使用索引,如果是g1.geom<#>g2.geom则不使用索引.
样例
SELECT * FROM (
SELECT b.tlid, b.mtfcc,
b.geom <#> ST_GeomFromText('LINESTRING(746149 2948672,745954 2948576,
745787 2948499,745740 2948468,745712 2948438,
745690 2948384,745677 2948319)',2249) As b_dist,
ST_Distance(b.geom, ST_GeomFromText('LINESTRING(746149 2948672,745954
2948576,
745787 2948499,745740 2948468,745712 2948438,
745690 2948384,745677 2948319)',2249)) As act_dist
FROM bos_roads As b
ORDER BY b_dist, b.tlid LIMIT 100) As foo
ORDER BY act_dist, tlid LIMIT 10;
Tlid      | mtfcc  | b_dist           |act_dist
----------+--------+------------------+-------------------------
85732027  | S1400  | 0                | 0
85732029  | S1400  | 0                | 0
85732031  | S1400  | 0                | 0
85734335  | S1400  | 0                | 0
85736037  | S1400  | 0                | 0
624683742 | S1400  | 0                | 128.528874268666
85719343  | S1400  | 260.839270432962 | 260.839270432962
85741826  | S1400  | 164.759294123275 | 260.839270432962
85732032  | S1400  | 277.75           | 311.830282365264
85735592  | S1400  | 222.25           | 311.830282365264
(10 rows)
参考
ST_DWithin, ST_Distance, <->
6.10.18. <<->>
<<->> — Returns the distance between the centers of the bounding boxes of two geometry objects3D距离.
用法
double precision <<->>( geometry A , geometry B );
描述
<#>The operator returns the distance between the centers of the bounding boxes of two geometric objects3D距离. It is suitable for sorting geometric objects by approximate distance when doing nearest neighbor search.
注意
This operator can be used on geometric objects N Dimension space index.It differs from other operators in that,只有用在 ORDER BY A spatial index will be used only when in the clause.
注意
This operator is constant only if one of the geometry objects is constant(Not in subqueries or CTE中)的时候才会使用索引,例如:'SRID=3005;POINT(1011102 450541)'::geometry .
参考
<<#>>, <->
边栏推荐
- Resize() usage row pit in vector
- FPGA工程师面试试题集锦111~120
- How to read a paper
- ERROR: Could not install packages due to an OSError: [Errno 2] No such file or directory: '/data/xxxx
- Let's talk programming languages together
- map and set - natural search and lookup semantics
- 4 模块三:文献阅读与研究方法
- Redis: Solve the problem of modifying the same key with distributed high concurrency
- 2022年质量员-土建方向-通用基础(质量员)考试模拟100题及在线模拟考试
- FPGA工程师面试试题集锦121~130
猜你喜欢
 - 交换机和路由器技术-27-OSPF路由重分发 
 - 交换机和路由器技术-36-端口镜像 
 - 每周推荐短视频:你常用的拍立淘,它的前身原来是这样的! 
 - I wrote some code in my resume, but I still can't pass the interview 
 - 我的LaTeX入门 
 - 延长经济保险(jeecgboot) 
 - The use of async (asynchronous) and await 
 - Do you understand how the Selenium automated testing framework works? 
 - Dry goods: The principle and practice of server network card group technology 
 - 【电商运营】社交媒体营销策略该如何制定? 
随机推荐
- 【无2022上海市安全员A证考试题库及模拟考试 
- 2022年质量员-土建方向-通用基础(质量员)考试模拟100题及在线模拟考试 
- How to switch Green Shield encryption to IP-Guard encryption smoothly 
- Switch and Router Technology - 25 - OSPF Multi-Area Configuration 
- C Language: Practical Debugging Tips 
- Embedded Sharing Collection 33 
- MySQL必知必会(初级篇) 
- 梅克尔工作室--OpenEuler培训笔记(1) 
- About CC Attacks 
- [QNX Hypervisor 2.2 User Manual] 10.16 vdev virtio-blk 
- 分层架构&SOA架构 
- 智能指针笔记 
- 在 关闭页面/卸载(unload)文档 之前向服务器发送请求 
- 用白嫖的Adobe正版软件,减少应届毕业生的慢就业、不就业等现象 
- 网络协议1 
- MFC 进程间通信(共享内存) 
- Kong implements ban on foreign IP access 
- Unity WebGL RuntimeError: integer overflow(整数溢出问题) 
- The shortest path out of the maze 
- 交换机和路由器技术-34-动态NAT