mirror of
https://github.com/NodeBB/NodeBB.git
synced 2026-03-19 11:01:11 +01:00
refactor: switch to cursor
This commit is contained in:
@@ -40,9 +40,19 @@ module.exports = function (module) {
|
|||||||
|
|
||||||
module.scan = async function (params) {
|
module.scan = async function (params) {
|
||||||
const match = dbHelpers.globToRegex(params.match);
|
const match = dbHelpers.globToRegex(params.match);
|
||||||
return await module.client.collection('objects').distinct(
|
const cursor = await module.client.collection('objects').find({
|
||||||
'_key', { _key: { $regex: new RegExp(match) } }
|
_key: { $regex: new RegExp(match) },
|
||||||
);
|
}, {
|
||||||
|
projection: { _id: 0, _key: 1 },
|
||||||
|
}).batchSize(params.batch || 1000);
|
||||||
|
const found = new Set();
|
||||||
|
// eslint-disable-next-line no-await-in-loop
|
||||||
|
while (await cursor.hasNext()) {
|
||||||
|
// eslint-disable-next-line no-await-in-loop
|
||||||
|
const item = await cursor.next();
|
||||||
|
found.add(item._key);
|
||||||
|
}
|
||||||
|
return Array.from(found);
|
||||||
};
|
};
|
||||||
|
|
||||||
module.delete = async function (key) {
|
module.delete = async function (key) {
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
module.exports = function (module) {
|
module.exports = function (module) {
|
||||||
|
const Cursor = require('pg-cursor');
|
||||||
const helpers = require('./helpers');
|
const helpers = require('./helpers');
|
||||||
const dbHelpers = require('../helpers');
|
const dbHelpers = require('../helpers');
|
||||||
|
|
||||||
@@ -85,17 +86,43 @@ module.exports = function (module) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
module.scan = async function (params) {
|
module.scan = async function (params) {
|
||||||
const regex = dbHelpers.globToRegex(params.match);
|
const match = dbHelpers.globToRegex(params.match);
|
||||||
|
const batchSize = params.batch || 1000;
|
||||||
|
const found = new Set();
|
||||||
|
|
||||||
const res = await module.pool.query({
|
const client = await module.pool.connect();
|
||||||
text: `
|
|
||||||
SELECT o."_key"
|
|
||||||
FROM "legacy_object_live" o
|
|
||||||
WHERE o."_key" ~ $1`,
|
|
||||||
values: [regex],
|
|
||||||
});
|
|
||||||
|
|
||||||
return res.rows.map(r => r._key);
|
const cursor = client.query(new Cursor(`
|
||||||
|
SELECT "_key"
|
||||||
|
FROM "legacy_object_live"
|
||||||
|
WHERE "_key" ~ $1
|
||||||
|
`, [match]));
|
||||||
|
|
||||||
|
try {
|
||||||
|
const fetchRows = () => {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
cursor.read(batchSize, (err, rows) => {
|
||||||
|
if (err) return reject(err);
|
||||||
|
resolve(rows);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
let rows;
|
||||||
|
do {
|
||||||
|
// eslint-disable-next-line no-await-in-loop
|
||||||
|
rows = await fetchRows();
|
||||||
|
for (const row of rows) {
|
||||||
|
found.add(row._key);
|
||||||
|
}
|
||||||
|
} while (rows.length > 0);
|
||||||
|
} finally {
|
||||||
|
cursor.close(() => {
|
||||||
|
client.release();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return Array.from(found);
|
||||||
};
|
};
|
||||||
|
|
||||||
module.delete = async function (key) {
|
module.delete = async function (key) {
|
||||||
|
|||||||
Reference in New Issue
Block a user