Maintenir la fraîcheur des données du store orienté colonnes en mémoire

Sélectionnez une version de la documentation :

Cette page explique comment maintenir la fraîcheur des données dans le store orienté colonnes du moteur columnar dans AlloyDB Omni dans un conteneur.

Lorsque des lignes de tableau sont ajoutées, supprimées ou mises à jour, le moteur de colonnes ne met pas immédiatement à jour les données dans le magasin de colonnes. Au lieu de cela, il marque le contenu concerné dans le column store comme non valide. Les requêtes sont planifiées et exécutées à l'aide de données orientées colonnes provenant du column store et de données orientées lignes provenant du cache de lignes et du stockage de base de données.

Au fil du temps, à mesure que de plus en plus de blocs de données deviennent non valides, les améliorations des performances des requêtes fournies par le moteur en colonnes sont réduites au point où les données en colonnes doivent être actualisées pour retrouver ces améliorations. Lorsque ce seuil d'actualisation est atteint, le moteur en colonnes utilise un job en arrière-plan pour actualiser les données non valides dans le column store. Par défaut, le moteur de colonnes utilise un seuil d'actualisation de 50, ce qui signifie que le contenu donné dans le magasin de colonnes est marqué pour l'actualisation lorsque 50 % de son contenu est devenu non valide. Vous pouvez modifier ce seuil d'actualisation pour ajuster le coût de l'actualisation automatique et potentiellement améliorer les performances des requêtes en continu pour la charge de travail de votre application.

Vous pouvez également actualiser manuellement les données d'un tableau dans le column store à tout moment. En général, vous effectuez une actualisation manuelle lorsque vous souhaitez que les modifications apportées à une table soient reflétées dans le column store dès que possible après avoir été effectuées.

Modifier le seuil d'actualisation du moteur de données en colonnes

Modifiez la valeur de l'option de base de données google_columnar_engine.refresh_threshold_percentage pour modifier le seuil d'actualisation du moteur de données en colonnes.

    ALTER SYSTEM SET google_columnar_engine.refresh_threshold_percentage=THRESHOLD;

THRESHOLD : valeur entière comprise entre 1 et 100. Cette valeur spécifie le pourcentage de blocs de données dans le contenu qui doivent devenir non valides pour que le contenu soit marqué comme devant être actualisé.

Actualiser manuellement les données d'un tableau dans le store orienté colonnes

Exécutez la fonction SQL google_columnar_engine_refresh pour actualiser manuellement les données d'une table dans le column store en mémoire.

SELECT google_columnar_engine_refresh(TABLE_NAME);

TABLE_NAME : chaîne contenant le nom de la table ou de la vue matérialisée. Si la table ou la vue se trouve dans un schéma autre que public, spécifiez le nom du schéma au format SCHEMA_NAME.TABLE_NAME (par exemple, myschema.mytable).