-
Notifications
You must be signed in to change notification settings - Fork 3.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Cosmos: Add basic support for collections and dictionaries of primitive types #14762
Comments
Hi, I'm keen to understand the |
@kierenj - We use This issue is currently in backlog milestone so we are not working on it for our next release 3.1. Cosmos being a new provider which is going to be RTM first time in 3.0, we are going to evolve cosmos based on user feedback. We will prioritize adding features which are requested by many customers. When planning a release, we look at how many people have voted for a feature to decide if it is in demand. Please upvote first issue if you need this. |
It seems weird to me that the provided documentation states how easy it is to embed entities, that I couldn't believe that embedding a simple string collection is unsupported. @ajcvickers or @smitpatel do you guys maybe have an update for us? Since EF Core 5 is just released and this still isn't supported. |
@svrooij Strings aren't entities, of course. I think the documentation is accurate |
Yes, if you put it that way, sure. But I wasn't talking about the documentation, I was talking about that it's weird you're able to embed entire objects but not a collection of strings. Even more because cosmos supports the ARRAY_CONTAINS query function. So if I stop using the EF core framework and just connect to plain cosmos I can set a property to a string collection and even use ARRAY_CONTAINS to query based on the values. |
@AndriySvyryd can you show an example on how to do it with a ValueConverter? I would really appreciate it. |
@Assassinbeast
|
@Marusyk Thanks! So this will mean in my C# code, that its a string array, but in CosmosDB, it will become a single string. That means I cant make a CosmosDB query against an array. Is that correct? |
That is exactly the problem. This way it is saved but you cannot query for it. |
Is there any update on this? It definitely missed 5.0 as well. |
@Drew-E It's in the Backlog milestone, meaning it's not planned for 6.0 either |
Hi Folks, Facing same issue. Just need to save an double[], but using the folowing code:
It gets saved as:
But I expect:
This EF Core Cosmos useless on my case as I need to run Spatial Queries against the data. Quite annoying to see that this issue is open for so long, but still not in place. That way I am forced to use CosmosDB SDK directly, which I wanted to avoid on this specific scenario... Are there any workaround I could make to overcome this issue until there`s a fix for it? Tried many options, but none worked... (Actually, there is, check next "Edit/Update").. Edit/Update By doing that you are actually manipulating the real json which will be persisted on cosmos. As the MSDN mentions, that should be a last resort... So far that is the only way I managed to save the array as expected... on my case as a double[]... |
Thanks for the Heads up, @AndriySvyryd ! |
For issues in the backlog we don't have any specific plans, they are reprioritized after each release. |
Is first-class support for collections and dictionaries of primitive types anywhere in our future? Why is such a basic capability in the backlog for so long? Not having this capability is a showstopper for my team. Whatever your reprioritization plans are you are giving us the impression that the EF Core provider just isn't important. |
@ericb-blankenburg , @PaulOst , |
Yes, there are workarounds. We could modify our document structure to use a list of objects with a single property. We can use the Cosmos SDK instead of EF Core. But really, this is such a basic feature that it should be supported by EF Core. Why such a low priority on supporting this? Are there not enough people that require it? Is the effort too large? Is every backlog item ahead of this one really a higher priority? A little transparency would be great. |
You can read about our planning process, based on it we came up with the following plan. It does have Cosmos database provider in it, but the details haven't been decided as it depends on the progress of other features in the plan. As soon as the team members that can work on Cosmos finish their assigned committed features we will update the plan. You can see exactly what we are currently working on in the biweekly updates. |
It should be possible to implement this without a
ValueConverter
because Cosmos supports them natively.This issue doesn't include server translation of queries with any methods using properties of these types, essentially they will be treated as atomic units.
The text was updated successfully, but these errors were encountered: