App Inventor working with Firebase database

yes, I am thinking time stamps will keep things unique.

Use systemTime, this provides the date/time in milliseconds.

1 Like

fixed this question

TIMAI2 - I should use systemTime instead of .now? What I see from systemTime is that it returns mills since 1970? What I do not see how it returns the value?

You can convert it to human readable date/time using clock blocks

Thank you. Why is this better than using call Clock1.now? Easy enough change. Thank you

image
The code using systemtime stores the data in a subtag tree vs the YYMMDDHHSS format building the unique tag.

Did we forget to mention that the slash (/) character used in date formatting has a side effect in Firebase tags of creating subtrees?

Though it has a beneficial side effect of making your key/value trees short, unordered and bushy for performance, it interferes with any attempts to grab multi-day ranges .

What looks good to the eye does not work best behind the scenes in a database.

ABG thank you. That makes sense.
In times, I hope to be able to graph the data and "unordered and bushy" tags seem like they would be difficult and much more effort.

I am working now on a simple task of refreshing the last values on the app and reading back last value even from a saved key has been challenging. is there a book or manual that would be more efficient than my try,fail,try, fail, try search google, try, fail approach.?

I apologize in advance if this is for the wrong Firebase flavor:
https://firebase.google.com/docs/database/web/structure-data

1 Like

I am working on three problems:

  1. the data in the firebase database "appears" different if I use MIT APP to write record or manually type into the Firebase web screen. See image, some values have quotes, others do not?
    datadiff

Problem 2 -perhaps design issue. The APP hopefully will "open" with the most recent data from the Firebase data showing. For now I am trying to add a button that populates the screen with the most recent values. A button on the screen "Recent" will call the attached blocks but it is not retrieving the data but showing the tag in the text box . My blocks -
Repaint screen

Problem 3 - When I click "Update", I am writing the data to the database and then wanting to write a copy to a parrallel projectbucket, that can overwrite the prior entry, the purpose is to keep the last TAG used for faster recall and loading the screen. The projectbucket "SalinityLast" should only keep one piece of data -the TAG for the last entry made into the projectbucket "Salinity". See my blocks. I am thinking I need to be using not StoreValue but Change or Append?

If you want to get rid of all the double quotes - " - then use the web component to interact with Firebase

Will the double quotes impact the way the app functions? My goal for the project is to have arduino load some data into the firebase and the MIT App to load some data into the database. I do not plan to manually add data to the database via the web interface. I was thinking I need to use the NumbersOnly or other setting?

I suggest you first just try it as you are, and see if you have any data issues when returning the values to your app.

Repaint screen

If you want to retrieve what is under tag SalinityLast in Button5, you would have to first temporarily set your ProjectBucket to the empty string, the top of the tag tree.

The incoming value for tag SalinityLast would then be a dictionary with key a datetime string and a subvalue of the salinity.

When I write into the database with tag of Salinity, I want to write an entry under SalinityLast but it does not need to be a new entry in SalinityLast but overwrite or replace the exisiting. SalinityLast should only have one record under it and it will be the last tag used. Do I first delete the record or can I write over?

Here's the sequence to write SalinityLast:

  • set bucket to empty text block
  • store at tag 'SalinityLast' value Textbox7.Text

THANK YOU...that worked

This topic was automatically closed 7 days after the last reply. New replies are no longer allowed.