Efcore: Map JSON values stored in database to EF properties

Created on 9 Dec 2015  ยท  77Comments  ยท  Source: dotnet/efcore

SQL Server, PostgreSQL, MySQL, and Oracle databases enable developers to store JSON in columns and use values from JSON documents in queries. As an example, we can create product table with few fixed columns and variable information stored as JSON:

Product[id,title,decription,datecreated,info]

info column can contain JSON text. Use cases are:

  1. I can put different non-standard information about products in JSON column as a set of key:value pairs in JSON column, e.g. {"color":"red","price":35.99,"status":1}.
  2. I can have new kind of single table inheritance where I can put all properties specific to some leaf classes as a bag of key:values instead of additional columns.

In SQL Server/Oracle we can use JSON_VALUE function to read JSON values from JSN column by keys, e.g.:

SELECT id, title,
       json_value(info,'$.price'),json_value(info,'$.color'),json_value(info,'$.status')
FROM product

PostgreSQL has ->> operator and MySQL has json_extract function that are similar.

Problem

Currently, JSON fields can be mapped to entities in entity framework as string properties and we can parse them using Json.Net library. It would be good if we could map properties in EF model to (JSON text+path).

Proposal

  1. Basic - Could we map property from EF model to string column that contains text and specify path of value in JSON (e.g. price, status) ? EF can extract json value on JSON path and populate property in EF model with proper type casting.
  2. Medium - Enable updates of properties mapped to json value. If some EF property that is mapped to JSON values is updated, EF could format all of them as JSON and save them back in the in JSON column.
  3. Advanced - Enable LINQ support over JSON properties. If we use Select(obj=>obj.price), or Where(obj => obj.price < 100) in LINQ queries, these predicates could be transformed to JSON_VALUE for SQL Server/Oracle, -> for PostgreSQL. This way we will be able to query JSON values directly from EF.

_edited by @smitpatel on 16th March 2018_

You can use JSON_VALUE function using user defined function feature in EF Core 2.0
https://github.com/aspnet/EntityFrameworkCore/issues/11295#issuecomment-373852015 explains how to do it for SqlServer.

area-c-mapping area-relational-mapping needs-design type-enhancement

Most helpful comment

I can't believe this issue is still open in 2020! This feature is highly desirable.

All 77 comments

@JocaPC We are of course busy completing more basic functionality than this at the moment but eventually I would love us to enable all of this. BTW, I think providing a way to declare indexes for values in the JSON payload (so that those queries can be optmized) would also be nice.

@rowanmiller
It would be helpful and user friendly if we could add to our POCO a dynamic property and through the modelbuilder mark it as JSON (modelbuilder.Entity<Product>().Property(x=> x.CustomFields).AsJson() where CustomFields is dynamic/ ExpandoObject).

And then we will be able to nicely query the dynamic object like:

context.Products.Where(x=> x.InsertDate > DateTime.Now && x.CustomFields.Retailer.Name == "Doron")

// Or 
context.Products.Where(x=> x.InsertDate > DateTime.Now && 
                           x.CustomFields.Retailer.Items.Contains("Foo"))

Though I'm just not sure how indexing will work in SQL-Server 2016 for JSON columns @JocaPC

OData is using something similar with _Open Types_ and it's intuitive and very easy to use.

OData Open Type story sounds like a perfect fit to SQL-Server 2016 + EF Core!

You can add index on computed column that exposes JSON value:

  1. Create non-persisted computed column with expression JSON_VALUE(jsonCol, '$.Retailer.Name')
  2. Create index on that computed column

Original queries don't need to be rewritten. When SQL Server finds a query that uses JSON_VALUE and if path in JSON_VALUE matches computed column that has index, it will use indexing. See
https://msdn.microsoft.com/en-us/library/mt612798.aspx

I would like to see this support.

My team is currently investigating EF for a new application we are undertaking and I was hoping to use this very feature. If we were so inclined to invest in working on this feature, for our own selfish needs, would that be worthwhile contributing?

We realy need this functionality

At the moment, I think that we can just use FromSql function to execute raw SQL and include JSON_VALUE.
example:

var contacts = _context.Contacts.FromSql("SELECT Id, Name, Address, City, State, Zip " +
                                        "FROM Contacts " +
                                        "WHERE JSON_VALUE(Info, '$.Moniker') = @p1", moniker1);

My two cents (what I'm doing for now) for proposal 1:

I configure my entities this way:

public class ConfigCTransfer : EntityMappingConfiguration<CTransfer>
{
    public override void Map(EntityTypeBuilder<CTransfer> entity)
    {
        entity.HasJsonValue(x => x.Serialized, y => y.Data.Status, z => z.FStatus);
    }
}

x.Serialized is the JSON/text field.
y.Data is the object that is serialized into Serialized. Status is just a property of Data.
z.FStatus is the column where I'm going to store the value of y.Data.Status.

the heavyweight is done by the HasJson extension method. I include the code (not a clean one) for copy paste, but the important thing here is that I'm setting the FStatus property as a computed column, as @JocaPC commented.

    public static void HasJsonValue<T, U>(this EntityTypeBuilder<T> value, Expression<Func<T, string>> jsonFieldExpr, Expression<Func<T, U>> jsonPathExpr, Expression<Func<T, U>> dataFieldExpr) where T : class
    {
        var jsonPathSegments = PathFromExpression(jsonPathExpr);
        jsonPathSegments.RemoveAt(0);
        var jsonPath = string.Join(".", jsonPathSegments);

        var jsonFieldSegments = PathFromExpression(jsonFieldExpr);
        var jsonField = string.Join(".", jsonFieldSegments);

        var sqlDataType = new SqlServerTypeMapper().FindMapping(typeof(U));
        //var typeName =  sqlDataType.DefaultTypeName;
        var typeName = sqlDataType.StoreType;
        var property = value.Property(dataFieldExpr);
        var isNullable = property.Metadata.IsNullable;
        var isForeignKey = property.Metadata.IsForeignKey();
        var maxLength = property.Metadata.GetMaxLength();
        if (maxLength != null) typeName = typeName.Replace("(max)", $"({maxLength.Value})");
        var columnDefinition = $"CAST((json_value([{jsonField}],'$.{jsonPath}')) AS {typeName})";
        if (isNullable == false || isForeignKey) columnDefinition = columnDefinition + " PERSISTED";
        if (isNullable == false) columnDefinition = columnDefinition + " NOT NULL";
        value.Property(dataFieldExpr).HasComputedColumnSql(columnDefinition);
    }

    //For other solutions, see:
    //http://stackoverflow.com/questions/1667408/c-getting-names-of-properties-in-a-chain-from-lambda-expression
    //and
    //http://stackoverflow.com/questions/2789504/get-the-property-as-a-string-from-an-expressionfunctmodel-tproperty
    public static List<string> PathFromExpression<T, P>(Expression<Func<T, P>> expr)
    {
        var result = new List<string>();
        MemberExpression me;
        switch (expr.Body.NodeType)
        {
            case ExpressionType.Convert:
            case ExpressionType.ConvertChecked:
                var ue = expr.Body as UnaryExpression;
                me = ((ue != null) ? ue.Operand : null) as MemberExpression;
                break;
            default:
                me = expr.Body as MemberExpression;
                break;
        }

        while (me != null)
        {
            string propertyName = me.Member.Name;
            //Type propertyType = me.Type;
            result.Add(propertyName);
            //Console.WriteLine(propertyName + ": " + propertyType);

            me = me.Expression as MemberExpression;
        }
        result.Reverse();
        return result;
    }

The EntityMappingConfiguration thing is just a friendly way of having the configuration of an entity in its own class. You can see the implementation and the discussion here:
https://github.com/aspnet/EntityFramework/issues/2805#issuecomment-218548872

If anyone needs helps with this, just ask me.

This has several limitations, though, at least:
1 - The properties are computed columns. The value will not be set until the entity is saved. But it will be of use for indexing.
2 - It doesn't support polymorphism, at least not in an easy/clear way. You can't use the same data for different entities... or I haven't found the way:

a - You can't use different classes to point to the very same table #6001
b - You can't use different classes to point to the very same field #240

Sorry if something about my conclusions is not completely accurate. There are others more capable of validating them. I just tried to expose my experience so far.

And...

3 - This solution only supports SQL Server. No support for in memory database.

I think the comment of @ikourfaln is superiour (and simplest to implement, ie already done) in combination with the flexible mapping idea.

When it will be done?

@Ma3yTa :disappointed:
not yet decided. must be moved from Backlog to a Milestone

I find the implementation complexity for this feature, compared with its
usefulness, to be amazingly disproportionate.

2016-09-29 16:48 GMT+02:00 IKOURFALN Slimane [email protected]:

@Ma3yTa https://github.com/Ma3yTa ๐Ÿ˜ž
not yet decided. must be moved from Backlog to a Milestone

โ€”
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
https://github.com/aspnet/EntityFramework/issues/4021#issuecomment-250488400,
or mute the thread
https://github.com/notifications/unsubscribe-auth/AAoyABSu8XPPrfjW7sIuoEmL_Vfjs_zsks5qu8_GgaJpZM4Gxzpa
.

I also think this would be very interesting to have JSON query support in EF Core.

Actually, for me, LINQ support would be secondary (or ternary) to the actual mapping functionality. Nice, of course, but if it takes much more time the "milestones" should be split up.

IMO ... LINQ (as in: the query expression parsing bit) is a leaky abstraction that's not all that useful. It's often quite confusing. The IEnumerable extensions are stellar, though, the all-time best idea that the .NET team has conceived of. But I digress.

Is it possible to work around this limitation in todays codebase?

For example, I'd like a simple integer to be mapped to a Link object that contains an ID ...

@bjorn-ali-goransson it's not natively supported but with Field Mapping support (added in 1.1 - currently in preview) you could map the integer to a private field and then have a property that converts to/from the Link object. See this post for details on 1.1 Preview1 and how to use field mapping https://blogs.msdn.microsoft.com/dotnet/2016/10/25/announcing-entity-framework-core-1-1-preview-1/.

Why just not to start from simpler things: smartly serialize entity (with all its "navigation") to JSON using model information to avoid circular references? Together you will be able just to insert JSON DB fields "as is". Then user will be able easy to send the serialized result to further layers (usually SPA). It should cover 95% of JSON DB field usages.

Yes, agree that we want mapping for just selection. It's not critical to serialize/deserialize on update but would be very helpful with odata sorting and filtering.

Good to have something like UserType in NHibernate http://blog.denouter.net/2015/03/json-serialized-object-in-nhibernate.html?m=1

@rowanmiller @divega Maybe JSON mapping could be implemented using backing fields. Here is a proposal: https://github.com/aspnet/EntityFramework/issues/7394

Guys from NHibernate started to implement this feature https://nhibernate.jira.com/plugins/servlet/mobile#issue/NH-3930

This would be fantastic to see.
More and more data in databases is unstructured or has shallow hierarchies that need not span multiple tables thus don't map to simple columns (such as the Complex Types feature would bring). JSON is a perfect structure for these scenarios but right now it takes not only the programming complexity hit, but more importantly a performance hit to serialize/deserialize as string blobs.

When we are competing against NoSQL DBs that naturally crunch JSON with high-performance, the whole relational world could really use a one-up to compete better against those solutions โ€“ which often come with their own slew of problems (lack of integrity, migration / data corruption over time).

Here is the article that explains how to map objects and arrays to JSON fields. Using not-mapped/backing fields we can map non-value properties to JSON columns in database.

The bigges thing that is missing is some ability to translate LINQ queries like this:

_context.Blogs
         .Where(b => b.Owner.Status == 1)
         .OrderBy(b => b.Owner.Email)
         .Take(10)
         .Select(b => b.Owner.Name);

to something like this:

SELECT TOP 10 Name
FROM Blogs b
      CROSS APPLY OPENJSON( b.Owner ) WITH (Status int, Name nvarchar(400))
WHERE Status = 1
ORDER BY Email

@jovanpop-msft Fantastic article link Jovan. Thanks for that share.
The in-database translation is exactly the golden feature we were looking for.

Fingers crossed for future support on this in the not too distant future =)

@divega @rowanmiller Guys, When expect this feature will be done?

I would love to see this implemented. I personally think that this is more of a "must have" rather than a "nice to have" feature.

I understand that there are other basic requirements that have to be implemented before resources are available to implement this one but still...

Must have, on a feature that was just introduced in SQL server 2016 that almost no application is taking advantage of.
It's not useless by any mean, but the definition of must have is not "this feature will help me very much"

P.s. This feature WILL help me very much...

Yes it's important.

But on the other hand, if you need a JSON storage solution, you're not really the primary target audience for EF Core - it's relational DB consumers. This can be found out both by looking at the EF Core goals and history, and by looking at the fact that neither this nor the flexible mapping is getting any attention. The team is busy developing relational database support (and other features).

Maybe you should start to look at other solutions. There are RavenDB (costs though), MongoDB, CouchBase, and some other serious alternatives.

@gdoron

the definition of must have is not "this feature will help me very much"

Exactly what you said. The two definitions are different and I am free to define it as a "must have" feature where as you define it as a "will help me" feature. The EF Core team also is free to say "not to be implemented" and close this issue. Right? I prefer the team to speak for themselves.

And oh yeah, we are very much taking advantage of the native JSON data support in SQL server 2016. You might not, that is your concern.

@bjorn-ali-goransson Forget about EF Core, SQL server itself is a relational database, however it has native JSON data support introduced in SQL server 2016. PostgreSQL and MySQL are also relational databases but they support native JSON data. Thus your assumption that I am not really the primary target audience for EF Core is just wrong. And if it was right, SQL server 2016 - being a relational database - should not support JSON data at all. Right?

The point you are missing is that an application could be implemented on top of a relational database and at the same time support dynamic schema only for some of its fields on some specific tables.

So the suggestion you make to look at no-SQL databases is not really of any help.

I suggest you read https://blogs.technet.microsoft.com/dataplatforminsider/2016/01/05/json-in-sql-server-2016-part-1-of-4/ where it states:

As the most-requested feature on the Microsoft SQL Server connect site, with more than 1,000 votes, support for JSON text processing has been added to SQL Server 2016.

SQL server developers could have very well said "this is a relational database, you are not our primary audience, go look at no-SQL databases" but they have not.

Everyone's requirements does not have to fit in yours. Just like the JSON text processing being the "most requested feature" on SQL server 2016 and may be you never needing it at all.


I don't know why you guys paying attention to unnecessary things like how I defined the feature (must have vs will help me) or if the EF Core team has other things to do first (I already said I understand that!) but seriously, I wrote my comment so the team of EF Core can speak for themselves and also know that there is one more developer here who is very much looking forward for having this feature implemented at some point in the future.

Definitely a must have. Stuck with SQL Server for some of our enterprise customers, but wanting to take advantage of JSON column. Would love to see this receive some attention.

@divega What is the status of this request? Are you guys going to work on it?

@asadmalik3 This issue is in the Backlog milestone. This means that it is not going to happen for the 2.1 release. We will re-assess the backlog following the 2.1 release and consider this item at that time. However, keep in mind that there are many other high priority features with which it will be competing for resources.

Update: You can use JSON_VALUE function using user defined function feature in EF Core 2.0
https://github.com/aspnet/EntityFrameworkCore/issues/11295#issuecomment-373852015 explains how to do it for SqlServer.

(also added to first post)

See #2282.
Also please check out Impatient, and read the issue I posted there.

I would also love to have these features. In the meantime, I'm working on an EFCore extension project that compiles the call to OPENJSON through a linq expression and an extension method. You can see the results here.

This would be cool, i hope you have enough time due the danger of a currency burn

Any development on this?
This feature can potentially unlock a whole new world of dynamic types with EF!
And in turn support NoSQL with EF.

I bet this is one of the most requested features of EF core with 130+ ๐Ÿ‘ and 30+ โค๏ธ yet no attention _resource_ wise.

I am reading this today and still no solution to query the JSON Data stored in SQL Server 2016 in a table column using EF CORE. Should we resort to using ADO.Net for now and calling procedures. Please suggest.

@mutanttech - You can use https://github.com/aspnet/EntityFrameworkCore/issues/11295#issuecomment-373852015 for querying part, if that is the only blocker.

@smitpatel Be careful using it. Check details at https://github.com/aspnet/EntityFrameworkCore/issues/11295#issuecomment-449521486

@CoskunSunali - Thanks for bringing it to attention. Though I believe, it would not be difficult to define function based on OPENJSON similarly.

Thanks @CoskunSunali , @smitpatel for the response.
The solution can work but not really sure if reliable. I really wanted to use EFCore, but I have started to think use Stored Procs & Dapper to get the stuff done for now. What do you think of this approach?

@mutanttech the solution provided in #11295 is legitimate and reliable. The query translates to JSON_VALUE correctly. It's just unfortunately not bundled with EFCore.

Would be nice to be able to query like this

drop table dbo.#TestTable 
CREATE TABLE dbo.#TestTable 
   ( 
   Id int NOT NULL, 
   Settings varchar(512)
   ) 

INSERT INTO dbo.#TestTable (Id, settings)  VALUES (1,'{"Languages": ["uk"], "Content": [ "modern", "ballroom"]}') 

select *  from dbo.#TestTable  
    CROSS APPLY OPENJSON(settings,'$.Languages')  WITH (lang   varchar(10)   '$')
    CROSS APPLY OPENJSON(settings,'$.Content')  WITH (content   varchar(10)   '$')
where ISJSON(settings) > 0 and lang in ('uk') and content in ('ballroom')

Any development on this feature?
It's very usefull!

@ramax495 This issue is in the Backlog milestone. This means that it is not going to happen for the 3.0 release. We will re-assess the backlog following the 3.0 release and consider this item at that time. However, keep in mind that there are many other high priority features with which it will be competing for resources.

@mutanttech the solution provided in #11295 is legitimate and reliable. The query translates to JSON_VALUE correctly. It's just unfortunately not bundled with EFCore.

@aaronhudon For selecting primitive values, yes. For selecting real complex JSON data that can exceed 4000 chars, no. You have to switch to OPENJSON in that case and it has a whole another syntax.

@CoskunSunali - Thanks for bringing it to attention. Though I believe, it would not be difficult to define function based on OPENJSON similarly.

@smitpatel Sorry for the late response. I am not sure it would be that easy for average Joe. OPENJSON has a whole another syntax that requires common table expressions like WITH or a CROSS APPLY or even both at the same time.

Example (taken from here):

SELECT store.title, location.street, location.lat, location.long  
FROM store  
CROSS APPLY OPENJSON(store.jsonCol, 'lax $.location')   
     WITH (street varchar(500) ,  postcode  varchar(500) '$.postcode' ,  
     lon int '$.geo.longitude', lat int '$.geo.latitude')  
     AS location

Comparing it to JSON_VALUE, it is quite a complex statement for querying data. I mean, from expression point of view, not when you write raw T-SQL. Consider partial selects, partial updates, array values and so on.

@mutanttech the solution provided in #11295 is legitimate and reliable. The query translates to JSON_VALUE correctly. It's just unfortunately not bundled with EFCore.

@aaronhudon For selecting primitive values, yes. For selecting real complex JSON data that can exceed 4000 chars, no. You have to switch to OPENJSON in that case and it has a whole another syntax.

@mutanttech the solution provided in #11295 is legitimate and reliable. The query translates to JSON_VALUE correctly. It's just unfortunately not bundled with EFCore.

@aaronhudon For selecting primitive values, yes. For selecting real complex JSON data that can exceed 4000 chars, no. You have to switch to OPENJSON in that case and it has a whole another syntax.

@CoskunSunali for "complex" JSON fragments, use the same technique as described for JSON_VALUE, but use JSON_QUERY, then materialize the result by deserializing into a client side model. I've been doing this, and it works pretty well.

Time to bring this into SQL Server provider.
https://github.com/npgsql/Npgsql.EntityFrameworkCore.PostgreSQL/pull/982
Hooray @roji!

@CADbloke I think you misunderstood me. Npgsql has support for mapping those JSON objects to POCO classes, and even enables querying them in the DB.
Otherwise, I misunderstood what that PR was about.

The Npgsql provider version 3.0 indeed added out the ability to map properties of EF entities to database JSON columns, and to query within those columns with LINQ as usual.

@CADbloke's links above do provide alternative means to do the mapping - a value converter can be used to convert any user POCO type to a JSON document (via Json.NET or System.Text.Json) to be sent to the database. However, that approach does not allow querying, only storage.

I knew I didn't underestimate your power @roji...

@CADbloke In the linked case, npgsql can even map a .NET List<string> or string[] into a PostgreSQL column of type text[], no need of JSON at all:
https://www.npgsql.org/efcore/mapping/array.html

This can even be combined with costom conversions, we're successfully mapping sets of our own structs to PostgreSQL text[] by using a ValueConverter<SortedSet<OurStruct>,string[]>. (The sets are empty in most cases, and only contain half a handful of entries otherwise, so an extra table was not worth the hassle...)

Never underestimate the Power of PostgreSQL and npgsql :-)

PS: We've been motivated by Andrew Locks article series about primitive obsession: https://andrewlock.net/generating-strongly-typed-ids-at-build-time-with-roslyn-using-strongly-typed-entity-ids-to-avoid-primitive-obsession-part-5/

@roji any plans to bring this over to the SQL Server provider?

@rogerfar nothing concrete at the moment - but we haven't yet done the planning for our next version (after 3.1), this might make it in.

I can't believe this issue is still open in 2020! This feature is highly desirable.

As soon as EF Core becomes a viable alternative to EF 6.x โ€“ and can support real production features such as TPT (open since 2015 โ€“ https://github.com/dotnet/efcore/issues/2266), I'm sure the team will begin planning this one out and "consider it".

Please thumbs up the original post so that it has a better chance of being considered in the Plan for Entity Framework Core 5.0.

Your feedback on planning is important. The best way to indicate the importance of an issue is to vote (thumbs-up ๐Ÿ‘) for that issue on GitHub. This data will then feed into the planning process for the next release.

Please thumbs up the original post so that it has a better chance of being considered in the Plan for Entity Framework Core 5.0.

Your feedback on planning is important. The best way to indicate the importance of an issue is to vote (thumbs-up ๐Ÿ‘) for that issue on GitHub. This data will then feed into the planning process for the next release.

@mguinness FYI, if you're working on a new project, npgsql has JSON licked like a hot damn, I'm very happy with it so far. https://www.npgsql.org/efcore/mapping/json.html?tabs=data-annotations%2Cpoco

Guess it's (finally?) time to switch over to PostgreSQL.

SQLServer has been the last thorn in our side with .NET Core / multi-platform .NET development (ie: not needing to spin up a Windows VM just to be able to access SQLServer/SSMS), and the magnitude + importance of this missing feature might just be the motivation to go all-in on the DB switch.

Thanks @roji for illuminating us on the fantastic benefits of the Npgsql, including the NodaTime support (we've been battling with DateTime hacks for years), primitive arrays, native enums etc. Looks like the provider is WAY ahead of the SQLServer one!

not needing to spin up a Windows VM just to be able to access SQLServer/SSMS

To be fair, SQL Server seems to work great on Linux, so if Windows is a big issue you may want to consider that.

As for the rest, a lot of the cool stuff (arrays, enums) is things PostgreSQL itself supports - the provider only surfaces that (just to make it clear where the goodness is coming from).

PostgreSQL > MSSQL for licensing alone. Even if that's not an immediate concern, take it seriously on principle.

I can't even begin to count the tricky ways you can get cornered by MSSQL and duped into an upsell.

Thanks for the thoughts guys.

We went with the typical least-resistance path in choosing MSSQL (out of not knowing better, since we're devs not DBAs), in hope for maximum compatibility with the upwards stack (EF6/EFCore/.NET).

Ironically that path seems to have NOT optimized for maximum support/compatibility โ€“ and when database features such as the lack of native enums, arrays and JSON columns don't exist in the DB/provider, they end up inherently limiting and skewing your higher-level abstractions you are able to leverage, thus getting less value upwards on the stack โ€“ double irony.

Need no further convincing over here.

To be fair, SQL Server seems to work great on Linux, so if Windows is a big issue you may want to consider that.

If I may ask what DB tool is good in replacement of SSMS on Mac (preferrably) Linux?
It's more the tooling that has held us back (make backups/restores easily during dev process) than anything.

Tried running DataGrid on Docker instances but were unable to get the connection working successfully, and did not find any support for .bak file backup/restore (ie: .bak files rather than SQL-based import/export)

Apologies for the slighty off-topic skew of the discussion โ€“ but strangely enough all these decisions go together and boil down to the adoption of JSON-mapped fields in the ORM.

Azure Data Studio with extensions

Fantastic @ErikEJ
Thanks!

@marchy Thanks for the positive feedback!

Hello :)

Would you also consider adding support for modifying JSON in the DB without first retrieving the full JSON?

For example, T-SQL supports "in situ" modification of JSON via the JSON_MODIFY() T-SQL command:

DECLARE @info NVARCHAR(100)='{"name":"John","skills":["C#","SQL"]}'

PRINT @info

-- Update name  

SET @info=JSON_MODIFY(@info,'$.name','Mike')

I believe MongoDB also has support for this via similar commands.

Or should I open a new issue for this?

Hello :)

Would you also consider adding support for modifying JSON in the DB without first retrieving the full JSON?

For example, T-SQL supports "in situ" modification of JSON via the JSON_MODIFY() T-SQL command:

DECLARE @info NVARCHAR(100)='{"name":"John","skills":["C#","SQL"]}'

PRINT @info

-- Update name  

SET @info=JSON_MODIFY(@info,'$.name','Mike')

I believe MongoDB also has support for this via similar commands.

Or should I open a new issue for this?

wanna this feature also, seemed a new issue is better for tracking

Was this page helpful?
0 / 5 - 0 ratings