BQ inserts record type successfully, but no data is inserted
php Editor Banana will introduce to you a common database operation problem, that is, the record type is successfully inserted into the BQ database but the actual data is not inserted. This situation may cause data inconsistency, so we need to find out the cause and solve the problem. In the following, we will detail the possible causes and solutions to help readers better deal with this problem.
Question content
I am trying to insert data into bigquery as per the following example Text with pre-created table compared to given example. My code is as follows
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 }
The code runs successfully, but I don't see any records inserted. The table structure is as follows
Field name type mod key sorting rule default value policy label
proj_name string nullable
Label. Records can be empty
key. String can be empty values. String can be empty
Not sure what's going wrong, if anyone can provide guidance, thank you very much.
tia Srikanth
Expect records to be successfully inserted into the table.
Solution
Fields should be exported. This issue has been reported too many times:
- json:json.marshal(struct) returns "{}"
- bson: Insert structure in mongodb in golang
- yaml: Unmarshall yaml into a structure
- toml: Unable to read toml file created using go and burntsushi libraries
type taginfo struct { projname string `bigquery:"proj_name"` tags tags `bigquery:"tags"` } type tags struct { key string `bigquery:"key"` values string `bigquery:"values"` }
See documentation (*inserter).put< /a>:
...
If src is valuesaver, call its save method to generate a row for uploading.
If src is a structure or a pointer to a structure, the schema is inferred from it and used to create the structsaver. The insertid of structsaver will be empty.
...
This is a comment on // inferFields extracts all exported field types from struct type.
func inferFields(rt reflect.Type) (Schema, error) {
The above is the detailed content of BQ inserts record type successfully, but no data is inserted. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Real-time Bitcoin USD Price Factors that affect Bitcoin price Indicators for predicting future Bitcoin prices Here are some key information about the price of Bitcoin in 2018-2024:

Yes, H5 page production is an important implementation method for front-end development, involving core technologies such as HTML, CSS and JavaScript. Developers build dynamic and powerful H5 pages by cleverly combining these technologies, such as using the <canvas> tag to draw graphics or using JavaScript to control interaction behavior.

The method of customizing resize symbols in CSS is unified with background colors. In daily development, we often encounter situations where we need to customize user interface details, such as adjusting...

Regarding the reasons and solutions for misaligned display of inline-block elements. When writing web page layout, we often encounter some seemingly strange display problems. Compare...

How to use JavaScript or CSS to control the top and end of the page in the browser's printing settings. In the browser's printing settings, there is an option to control whether the display is...

How to achieve the 45-degree curve effect of segmenter? In the process of implementing the segmenter, how to make the right border turn into a 45-degree curve when clicking the left button, and the point...

The problem of container opening due to excessive omission of text under Flex layout and solutions are used...

Tips for Implementing Segmenter Effects In user interface design, segmenter is a common navigation element, especially in mobile applications and responsive web pages. ...
