


BQ insère le type d'enregistrement avec succès, mais aucune donnée n'est insérée
l'éditeur php Banana vous présentera un problème courant de fonctionnement de la base de données, c'est-à-dire que le type d'enregistrement est inséré avec succès dans la base de données BQ mais les données réelles ne sont pas insérées. Cette situation peut entraîner une incohérence des données, nous devons donc en découvrir la cause et résoudre le problème. Dans ce qui suit, nous détaillerons les causes possibles et les solutions pour aider les lecteurs à mieux gérer ce problème.
Contenu de la question
J'essaie d'insérer des données dans bigquery selon l'exemple suivant Texte avec tableau pré-créé par rapport à l'exemple donné. Mon code est le suivant
type tagInfo struct { proj_name string `bigquery:"proj_name"` Tags Tags `bigquery:"tags"` } type Tags struct { key string `bigquery:"key"` values string `bigquery:"values"` } func insertData() error { prjName := "prjName" datasetID := "DSName" tableID := "TName" ctx := context.Background() client, err := bigquery.NewClient(ctx, prjName) if err != nil { return fmt.Errorf("Bigquery.NewClient: %w", err) } defer client.Close() item := &tagInfo{ proj_name: "Devil", Tags: Tags{ key: "engcontact", values: "Meryl Streep", }, } fmt.Printf("Item is: %s", item) items := []*tagInfo{item} table := client.Dataset(datasetID).Table(tableID) inserter := table.Inserter() err = inserter.Put(ctx, items) if err != nil { if multiErr, ok := err.(bigquery.PutMultiError); ok { for _, putErr := range multiErr { fmt.Printf("failed to insert row %d with err: %v \n", putErr.RowIndex, putErr.Error()) fmt.Println(putErr.Errors) } } return err } return nil }
Le code s'exécute avec succès mais je ne vois aucun enregistrement inséré. La structure du tableau est la suivante
Étiquette de politique de valeur par défaut de règle de tri de clé de mod de type de nom de champ
chaîne de nom_proj nullable
Étiquette. Le dossier peut être vide
clé. La chaîne peut être vide valeurs. La chaîne peut être vide
Je ne sais pas ce qui ne va pas, si quelqu'un peut me donner des conseils, merci beaucoup.
tia Srikanth
Attendez-vous à ce que l'enregistrement soit inséré avec succès dans le tableau.
Solution de contournement
Les champs doivent être exportés. Ce problème a été signalé trop de fois :
- json : json.marshal(struct) renvoie "{}"
- bson : Insérer une structure dans mongodb dans golang
- yaml : Unmarshal yaml dans une structure
- toml : Impossible de lire le fichier toml créé à l'aide des bibliothèques go et burntsushi
type taginfo struct { projname string `bigquery:"proj_name"` tags tags `bigquery:"tags"` } type tags struct { key string `bigquery:"key"` values string `bigquery:"values"` }
Voir la documentation (*inserter).put< /a> :
...
Si src est Valuesaver, sa méthode save est appelée pour générer une ligne à télécharger.
Si src est une structure ou un pointeur vers une structure, le schéma en est déduit et utilisé pour créer le structsaver. L'insertid de structsaver sera vide.
...
Ceci est un commentaire sur // inferFields extracts all exported field types from struct type.
func inferFields(rt reflect.Type) (Schema, error) {
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

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

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds





Oui, la production de pages H5 est une méthode de mise en œuvre importante pour le développement frontal, impliquant des technologies de base telles que HTML, CSS et JavaScript. Les développeurs construisent des pages H5 dynamiques et puissantes en combinant intelligemment ces technologies, telles que l'utilisation du & lt; Canvas & gt; Tag pour dessiner des graphiques ou utiliser JavaScript pour contrôler le comportement d'interaction.

Prix USD Bitcoin en temps réel Facteurs qui affectent le prix du bitcoin Indicateurs pour prédire les prix des futurs bitcoins Voici quelques informations clés sur le prix du bitcoin en 2018-2024:

La méthode de personnalisation des symboles de redimension dans CSS est unifiée avec des couleurs d'arrière-plan. Dans le développement quotidien, nous rencontrons souvent des situations où nous devons personnaliser les détails de l'interface utilisateur, tels que l'ajustement ...

Concernant les raisons et les solutions pour l'affichage mal aligné des éléments de blocage en ligne. Lors de la mise en page de la page Web, nous rencontrons souvent des problèmes d'affichage apparemment étranges. Comparer...

Comment utiliser JavaScript ou CSS pour contrôler le haut et la fin de la page dans les paramètres d'impression du navigateur. Dans les paramètres d'impression du navigateur, il existe une option pour contrôler si l'écran est ...

Comment réaliser l'effet de courbe à 45 degrés du segmenter? Dans le processus de mise en œuvre du segmentant, comment faire transformer la bordure droite en une courbe de 45 degrés lorsque vous cliquez sur le bouton gauche, et le point ...

Conseils pour implémenter les effets des segments dans la conception de l'interface utilisateur, le segmenter est un élément de navigation commun, en particulier dans les applications mobiles et les pages Web réactives. ...

Le problème de l'ouverture des conteneurs en raison d'une omission excessive du texte sous disposition flexible et de solutions est utilisé ...
