+
+ @functools.lru_cache(maxsize=1)
+ def _index_sql(self, num_places: int) -> pysql.Composed:
+ return pysql.SQL("""UPDATE location_property_osmline
+ SET indexed_status = 0, address = v.addr, token_info = v.ti
+ FROM (VALUES {}) as v(id, addr, ti)
+ WHERE place_id = v.id
+ """).format(_mk_valuelist("(%s, %s::hstore, %s::jsonb)", num_places))
+
+
+ def index_places(self, worker: DBConnection, places: DictCursorResults) -> None:
+ values: List[Any] = []
+ for place in places:
+ values.extend((place[x] for x in ('place_id', 'address')))
+ values.append(_analyze_place(place, self.analyzer))
+
+ worker.perform(self._index_sql(len(places)), values)
+
+
+
+class PostcodeRunner(Runner):