Click here to Skip to main content
15,992,684 members
Please Sign up or sign in to vote.
0.00/5 (No votes)
I have been working on Flutter development using SQL Database + ASP.NET REST API for the backend. However, I'm now considering transitioning to either Firebase or Appwrite due to their increasing popularity and ease of implementation. As I plan to develop a fully functional ERP Project for cross-platform, mainly mobile application use, I would appreciate guidance on choosing the right backend solution. What are the key considerations I should keep in mind when deciding between these options, particularly in the context of building a comprehensive ERP system? Your insights and experiences would be invaluable in helping me make an informed decision. Thank you!

What I have tried:

my current experience is with SQL Database + ASP.NET REST API, Should I consider using Google Firebase or AppWrite ?
Posted
Updated 25-Feb-24 8:46am
Comments
nickpreston24 25-Feb-24 15:26pm    
I would recommend keeping your .NET and SQL backend, considering the high investment and also considering using Firebase via C#. Firebase is just a database. No need to throw out working code.

Also, you will have to migrate your data from flat SQL table structures to basically to giant JSON docs in Firebase. Be absolutely certain you want to lose the strengths of SQL before you jump to the more trendy JSON doc storage models like Firebase, MongoDB and others.

Personally, I don't think you should put all your eggs in one basket. Try both, and see which works for what use cases.

As a contractor, I've always been forced to put 3d data into 2d SQL-scapes and used to dream of magical solutions like Firebase/Mongo to get me out of SQL Hell. I've since learned that SQL is just fine for transactional, flat data like invoices, orders, loan schedules, logging, etc.

For something requiring nesting, JSON dbs are good at those things, but pretty awful at querying efficiently while maintaining potentially duplicated copies of docs.

If you really need hefty, nested persistence in the form of JSON and simply cannot model everything in SQL (and why would you?), then try something like Neo4J graph database, or something more comprehensive like SurrealDB.

Finally, it sounds like you learned Flutter. Don't base your backend decisions on Flutter's need to juggle JSON like so many other popular frameworks like React. What I mean by "JSON juggling" is, you will have to not only maintain your persistance 'state' in your DB(s) of choice, but also have to maintain JSON 'state' in the UI. I would avoid this at all costs (htmx.org) and just have my API return bits of HTML, or, at worst, use either templaters like nunjucks or something that stays mostly out of the way, but can still be used on mobile like Svelte. Don't be a slave to a UI framework, if you are (many of them create more problems). UI should be both a representation of your persisted state and a remote control for the user, NOT a JSON manager, in my opinion.

What I like to do with C# is write little Services that do specialized work. In your case, I'd write one Firebase service to rule them all, then inject it into whatever API or UI you desire (and throw that sucker up in your Nuget registry of choice). Write once, cry once.

I hope this helps in your future endeavors.

Regards,

Nicholas Preston
https://peerlist.io/nickpreston
My stack: https://github.com/nickpreston24/trash-stack
[no name] 25-Feb-24 16:20pm    
Write is so you can interface with "any" backend; which means writing an "agnostic" front end and using the "repository" pattern. Make calls to the repository for the appropriate backend. Understanding agnostic means understanding "all" platforms you plan to support and knowing what the common interface is; which is usually an "ORM" (e.g. EF). Your choice is not so much which back-end to support; but which "ORM".

This content, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)



CodeProject, 20 Bay Street, 11th Floor Toronto, Ontario, Canada M5J 2N8 +1 (416) 849-8900