Table des matières
Que pouvez-vous faire avec Supabase CLI:
Définir les projets locaux
Votre mode de base de données est considéré comme un code d'application. Toutes les modifications du mode, de la stratégie et des fonctions sont contrôlées. Cela garantit que votre équipe peut collaborer et revenir efficacement pour changer en cas de besoin.
Pièges communs (et comment les éviter)
Maison interface Web js tutoriel SUPABASE Workflows: Du tableau de bord au développement basé sur GIT

SUPABASE Workflows: Du tableau de bord au développement basé sur GIT

Jan 28, 2025 pm 08:33 PM

Supabase Workflows: From Dashboard to Git-Based Development

Supabase a été populaire récemment, ce qui n'est pas accidentel. Il s'agit d'une puissante back-end, c'est-à-dire la plate-forme de service, intègre Postgres, l'authentification, le stockage et les fonctions de temps réel, et est fournie de manière conviviale chez un développeur. Si vous avez déjà utilisé Firebase, alors Supabase vous fera vous sentir davantage au niveau supérieur, surtout lorsque vous souhaitez développer SQL et la base de données en premier.

Mais avec la croissance du projet, le défi a suivi. Si vous avez hésité à changer parce que vous vous inquiétez de rouler les risques, ou il est difficile de suivre la stratégie de sécurité des lignes (RLS) et les fonctions de base de données, vous n'êtes pas seul. Qu'est-ce que la bonne nouvelle? Supabase fournit des outils et des flux de travail pour faire face à ces défis - et ils sont plus forts que vous ne le pensez.

Dans cet article, nous explorerons comment modifier rapidement de l'utilisation de la carte d'instruments Supabase à l'utilisation du flux de travail évolutif basé sur Git pour le développement formel.


Le dilemme de la carte d'instrument

Lorsque vous commencez à utiliser Supabase, le tableau de bord est intuitif et facile à démarrer. Vous pouvez rapidement créer des tables, définir des stratégies RLS et même écrire des fonctions. Cependant, avec la croissance du projet, cette méthode peut devenir chaotique:

    Contrôle illimité
  • : Il est difficile de suivre les modifications sur le tableau de bord, et encore moins de revenir. Modifications à risque élevé
  • : le contact direct avec les données de production ou les stratégies peut entraîner des erreurs difficiles à déboguer.
  • Problèmes de collaboration : Pour l'équipe, le manque de workflow approprié peut rendre la collaboration lourde.
  • La carte d'instruments est très adaptée à la conception du prototype, mais pour les grands projets, vous avez besoin d'outils plus puissants.
Processus de travail de développement local de Supabase

C'est là que le CLI Supabase et le développement local jouent un rôle. Supabase fournit un flux de travail qui vous permet de gérer les modèles de base de données, les stratégies et les migrations localement - toutes sont contrôlées dans GIT. Cela a provoqué l'écart entre la conception du prototype rapide et la pratique du développement professionnel.

Que pouvez-vous faire avec Supabase CLI:

  1. Démarrez l'environnement local : Exécutez la version locale (Postgres, auth, etc.) sur votre machine.
  2. Migration
  3. : Chaque changement de mode de base de données peut être capturé en tant que fichier de migration. Test de sécurité
  4. : Expériences localement sans toucher les données de production.
  5. Tout contrôle du contenu : la migration, la fonction SQL et même les stratégies RLS peuvent être stockées dans GIT.
  6. La migration est appliquée à la production : Soyez assuré que le changement est poussé vers votre environnement réel.
  7. Commencez à utiliser: Installer CLI
  8. : Définissez CLI selon le guide de Supabase.

Définir les projets locaux

: Utilisez
    pour démarrer l'environnement local.
  1. Faire du changement : Modifier le mode, ajouter une stratégie RLS ou créer des fonctions.
  2. Générer la migration : Utilisez pour générer des fichiers de migration. supabase start
  3. Soumettez-vous à Git
  4. : suivez vos modifications comme le code d'application de traitement. Le déploiement modifie
  5. : utilisez
  6. pour appliquer la migration vers la production. supabase db diff
  7. La meilleure pratique du flux de travail Supabase
  8. Afin d'utiliser pleinement Supabase, veuillez utiliser les meilleures pratiques suivantes:
  9. 1. Organisez votre SQL
  10. Gardez votre fonction de base de données, le déclencheur et la stratégie RLS modulaires et réutilisés. Stockez-les dans les fichiers .sql contrôlés par la version et organisez-les de manière logique - par exemple, pour créer un dossier séparé pour la migration, les fonctions et les stratégies. supabase db push
  11. 2. Faites un usage complet du git

Votre mode de base de données est considéré comme un code d'application. Toutes les modifications du mode, de la stratégie et des fonctions sont contrôlées. Cela garantit que votre équipe peut collaborer et revenir efficacement pour changer en cas de besoin.

3. Test local avant le déploiement

n'expérimentez pas sur la base de données de production. Utilisez des modifications, des fonctions et des stratégies du mode de test environnemental local. Cela minimise le risque de nuire aux applications dans l'environnement de production.

4. Utilisez l'outil pour suivre votre flux de travail

Bien que la fonction CLI Supabase soit puissante, vous pouvez envisager d'utiliser d'autres outils pour maintenir l'organisation:

notion ou trllo

: enregistrez votre stratégie, votre fonction et votre flux de travail.

postico ou dbeaver : Gérez votre base de données selon les besoins.

pipeline CI / CD

: La migration est déployée automatiquement vers l'environnement de production.

5. Garder la stratégie RLS simple

La sécurité au niveau du cycle est l'une des caractéristiques les plus puissantes de Supabase, mais des stratégies trop compliquées peuvent être difficiles à déboguer. À partir simplement, tester et construire progressivement progressivement.


Pièges communs (et comment les éviter)

  1. Évitez les tests locaux : Testez toujours votre migration et votre stratégie localement avant le déploiement. Il est facile d'ignorer cette étape, mais cela peut éviter les problèmes dans l'environnement de production.
  2. La stratégie est trop compliquée. Construisez une stratégie en itérative et faites-en un bon enregistrement pour améliorer la clarté.
  3. ne comptez que sur le tableau de bord : La carte d'instrument est très adaptée à la conception du prototype rapide, mais pour les grands projets, il doit être passé à un flux de travail basé sur Git dès que possible.
  4. Conclusion
  5. Supabase n'est pas seulement un substitut de Firebase -Il est une puissante plate-forme arrière-end qui peut être bien développée via le flux de travail correct. En adoptant la CLI Supabase, le développement local et les flux de travail basés sur le flux de travail, vous pouvez construire et développer votre projet en toute confiance sans vous soucier de détruire l'environnement de production.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Porce de variable PHP expliquée
4 Il y a quelques semaines By 百草
Conseils pour écrire des commentaires PHP
4 Il y a quelques semaines By 百草
Commentant le code en php
4 Il y a quelques semaines By 百草
<🎜>: Grow A Garden - Guide complet des marchands itinérants
3 Il y a quelques semaines By Jack chen

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel PHP
1510
276
Appareils et contextes avancés JavaScript Appareils et contextes avancés JavaScript Jul 24, 2025 am 12:42 AM

La portée de JavaScript détermine la portée d'accessibilité des variables, qui sont divisées en étendue globale, fonction et au niveau du bloc; Le contexte détermine la direction de cela et dépend de la méthode d'appel de fonction. 1. Les étendues incluent la portée globale (accessible n'importe où), la portée de la fonction (valide uniquement dans la fonction) et la portée au niveau du bloc (LET et const sont valides dans {}). 2. Le contexte d'exécution contient l'objet variable, la chaîne de portée et les valeurs de cela. Cela pointe vers global ou non défini dans la fonction ordinaire, l'appel de méthode pointe vers l'objet d'appel, le constructeur pointe vers le nouvel objet, et peut également être explicitement spécifié par appel / application / liaison. 3. La fermeture fait référence aux fonctions accédant et en se souvenant des variables de portée externes. Ils sont souvent utilisés pour l'encapsulation et le cache, mais peuvent provoquer

Comment obtenir la valeur d'un champ de saisie en JavaScript Comment obtenir la valeur d'un champ de saisie en JavaScript Jul 15, 2025 am 03:09 AM

Pour obtenir la valeur de la boîte d'entrée HTML, le noyau consiste à trouver l'élément correspondant via l'opération DOM et à lire l'attribut de valeur. 1. Utilisez Document.GetElementByid pour être le moyen le plus direct. Après avoir ajouté un ID à l'entrée, vous pouvez obtenir l'élément et lire la valeur via cette méthode; 2. Utilisez QueySelector pour être plus flexible, et vous pouvez sélectionner des éléments en fonction d'attributs tels que le nom, la classe, le type, etc.; 3. Vous pouvez ajouter des auditeurs d'événements d'entrée ou de modification pour atteindre des fonctions interactives, telles que l'obtention du contenu d'entrée en temps réel; 4. Faites attention au synchronisation d'exécution du script, aux erreurs d'orthographe et au jugement nul, et assurez-vous que l'élément existe avant d'accéder à la valeur.

Comment obtenir la valeur d'un bouton radio sélectionné avec JS? Comment obtenir la valeur d'un bouton radio sélectionné avec JS? Jul 18, 2025 am 04:17 AM

Il existe deux méthodes de base pour obtenir la valeur du bouton radio sélectionné. 1. Utilisez QuerySelector pour obtenir directement l'élément sélectionné, et utilisez l'entrée [name = "Votre nom-radio"]: Sélecteur vérifié pour obtenir l'élément sélectionné et lire son attribut de valeur. Il convient aux navigateurs modernes et a un code concis; 2. Utilisez Document.PetelementsByName pour traverser et trouver la première radio vérifiée via la boucle Nodelist et obtenir sa valeur, qui convient aux scénarios compatibles avec les anciens navigateurs ou nécessitent un contrôle manuel du processus; De plus, vous devez faire attention à l'orthographe de l'attribut de nom, à la gestion des situations non sélectionnées et à un chargement dynamique du contenu

Construire des iframes de sable à sable sécurisé avec JavaScript Construire des iframes de sable à sable sécurisé avec JavaScript Jul 16, 2025 am 02:33 AM

Pour utiliser JavaScript pour créer un sandbox sable sécurisé iframe, utilisez d'abord l'attribut de bac à sable de HTML pour limiter le comportement IFRAME, tel que l'interdiction de l'exécution du script, des fenêtres contextuelles et de la soumission de formulaire; Deuxièmement, en ajoutant des jetons spécifiques tels que des scénaristes pour assouplir les autorisations au besoin; Combinez ensuite PostMessage () pour obtenir une communication inter-domaine sécurisée, tout en vérifiant strictement les sources et les données de messages; Enfin, évitez les erreurs de configuration courantes, telles que ne pas vérifier la source, ne pas configurer CSP, etc., et effectuer des tests de sécurité avant de se rendre en ligne.

API de composition Vue 3 Vs API Options: une comparaison détaillée API de composition Vue 3 Vs API Options: une comparaison détaillée Jul 25, 2025 am 03:46 AM

CompositionAPI dans Vue3 convient plus à la logique complexe et à la dérivation de type, et OptionsAPI convient aux scénarios et débutants simples; 1. OptionsAPI organise le code en fonction d'options telles que les données et les méthodes, et a une structure claire mais les composants complexes sont fragmentés; 2. CompositionAPI utilise la configuration pour concentrer la logique liée, ce qui est propice à la maintenance et à la réutilisation; 3. CompositionAPI réalise la réutilisation logique sans conflit et paramétrisable par le biais de fonctions composables, ce qui est mieux que le mixin; 4. CompositionAPI a une meilleure prise en charge de la dérivation de type dactylographiée et de type plus précise; 5. Il n'y a pas de différence significative dans le volume de performances et d'emballage des deux; 6.

Techniques de débogage avancées pour les applications JavaScript complexes, en utilisant les principes du débogueur Java Techniques de débogage avancées pour les applications JavaScript complexes, en utilisant les principes du débogueur Java Jul 17, 2025 am 01:42 AM

Le débogage des applications JavaScript complexes nécessite des outils d'utilisation systématiques. 1. Définissez des points d'arrêt et des points d'arrêt conditionnels pour intercepter les processus suspects, tels qu'avant l'entrée de la fonction, la boucle, le rappel asynchrone et le filtre en fonction des conditions; 2. Activer la fonction BlackBoxing pour bloquer les interférences de bibliothèque tierce; 3. Utiliser les déclarations du débogueur pour contrôler l'entrée de débogage en fonction du jugement environnemental; 4. Tracez le lien d'appel via CallStack, analysez le chemin d'exécution et l'état de la variable, localisez ainsi efficacement la cause profonde du problème.

Maîtriser les modèles de concurrence JavaScript: les travailleurs du web contre les threads Java Maîtriser les modèles de concurrence JavaScript: les travailleurs du web contre les threads Java Jul 25, 2025 am 04:31 AM

Il existe une différence essentielle entre les travailleurs Web de JavaScript et Javathreads dans un traitement simultané. 1. JavaScript adopte un modèle unique. WebWorkers est un fil indépendant fourni par le navigateur. Il convient pour effectuer des tâches longues qui ne bloquent pas l'interface utilisateur, mais ne peuvent pas utiliser le DOM; 2. Java prend en charge le multithreading réel à partir du niveau de la langue, créé via la classe de threads, adapté à un traitement simultanée complexe et côté serveur; 3. Les travailleurs Web utilisent PostMessage () pour communiquer avec le fil principal, qui est hautement sécurisé et isolé; Les threads Java peuvent partager la mémoire, de sorte que les problèmes de synchronisation doivent être prêts à prêter attention; 4. Les travailleurs Web sont plus adaptés à l'informatique parallèle frontale, comme le traitement d'image, et

Exploration des règles de coercition de type en javascript Exploration des règles de coercition de type en javascript Jul 21, 2025 am 02:31 AM

La coulée de type est le comportement de la conversion automatique d'un type de valeur en un autre type en JavaScript. Les scénarios courants incluent: 1. Lorsque vous utilisez des opérateurs, si un côté est une chaîne, l'autre côté sera également converti en une chaîne, comme '5' 5. Le résultat est "55"; 2. Dans le contexte booléen, les valeurs non cooliennes seront implicitement converties en types booléens, tels que des chaînes vides, 0, nuls, non définies, etc., qui sont considérées comme fausses; 3. Null participe aux opérations numériques et sera convertie en 0, et non défini sera converti en NAN; 4. Les problèmes causés par la conversion implicite peuvent être évitées grâce à des fonctions de conversion explicites telles que Number (), String () et Boolean (). La maîtrise de ces règles aide

See all articles