Pavel, If you are ok with narrowing range for unsigned types then we could add a constraint for unsigned types on schema level (like nullability flag) and treat them as signed types in storage.
We are going with a separate storage type-system and binary protocol type-system, however most of type will match 1 to 1 with storage (native) type. On .Net side you will either have a separate type id or treat serialized value regarding a schema (signed or unsigned flag). Igor, I'm not sure users can ever foresee the consequences of using unsigned types. Assume, a user used to unsigned types perfectly works with some database, then he turns into Ignite successor confession with our "native" unsigned-types support. But later, he finds that he can use the power of Ignite Compute on Java for some tasks or a new app. Finally, the user will either fail to use his unsigned data on Java due or face performance issues due to natural Java type system limitations e.g. conversion uLong to BigInteger. I believe that natively supported types with possible value ranges and limitations should be known. So, the only question is what trade-off we found acceptable: narrowing unsigned type range or use types of wider range on systems like Java. On Tue, Nov 24, 2020 at 3:25 PM Igor Sapego <isap...@apache.org> wrote: > Actually, I think it is not so hard to implement comparison of unsigned > numbers in > SQL even in Java, so it does not seem to be a big issue from my > perspective. > > Now to the usage of unsigned types from Java - I think, if a user uses > unsigned type > in a schema and is going to interact with it from Java he knows what he is > doing. > > Mostly they are for use from platforms where they have native support and > widely > used, like in C++ or .NET, where users currently have to make a manual type > casting > or even just stop using unsigned types when they use Ignite. > > Best Regards, > Igor > > > On Tue, Nov 24, 2020 at 3:06 PM Pavel Tupitsyn <ptupit...@apache.org> > wrote: > > > Andrey, > > > > I think it is much simpler: > > - Add protocol support for those types (basically, just add more type > ids) > > - Treat uLong as long in Java (bitwise representation is the same) > > > > ANSI SQL does not have unsigned integers, so we can simply say that > > unsigned value relative comparison is not supported in SQL (equality will > > work). > > > > > > On Tue, Nov 24, 2020 at 2:40 PM Andrey Mashenkov < > > andrey.mashen...@gmail.com> > > wrote: > > > > > Thanks, Pavel and Igor. > > > > > > I like your ideas to have i8 or int8 instead of Integer. > > > But the naming doesn't address the issue. > > > > > > I agree internal types should be portable across different systems with > > and > > > without unsigned type support. > > > The only issue here is that unsigned types cover different ranges. > > > > > > Let's assume we want to introduce a uLong. > > > It doesn't look like a big deal to add uLong type support at storage > > level > > > and fit it to a 8 bytes and then use it in e.g. .Net only. > > > But how we could support it in e.g. Java? > > > > > > Let's keep in mind Long range is about (2^-63 .. 2^63) and uLong range > is > > > (0 .. 2^64) > > > 1. The first option is to restrict range to (0 .. 2^63). This allows to > > use > > > signed in e.g. > > > Java with no conversion, but doesn't look like a 'real' unsigned uLong > > > support. Things go worse when the user will use uByte, as limitation > can > > > make uByte totally unusable. > > > > > > 2. The second one is to map unsigned types to a type of wider type and > > add > > > a constraint for negative values. E.g. uLong to BigInteger. > > > So, we can't use primitive Java type for Long here. However, it is > still > > > possible to store uLong in 8 bytes, but have a special comparator for > > > unsigned types to avoid unwanted deserialization. > > > > > > WDYT? > > > > > > > > > > > > > > > > > > > > > On Tue, Nov 24, 2020 at 2:04 PM Pavel Tupitsyn <ptupit...@apache.org> > > > wrote: > > > > > > > Agree, let's get rid of "long, short, byte" in the protocol > definition. > > > > > > > > We can use Rust style, which is concise and unambiguous: > > > > i8, u8, i16, u16, etc > > > > > > > > On Tue, Nov 24, 2020 at 1:58 PM Igor Sapego <isap...@apache.org> > > wrote: > > > > > > > > > Pavel, > > > > > > > > > > I totally support that. Also, if we are aiming for > > > > > stronger platform-independance, > > > > > in our schemas we may want to support bit-notation (int32, uint64)? > > For > > > > > example > > > > > "long" can mean a different type on different platforms and it's > easy > > > to > > > > > confuse > > > > > them (happens often when using ODBC for example). > > > > > > > > > > Best Regards, > > > > > Igor > > > > > > > > > > > > > > > On Tue, Nov 24, 2020 at 1:34 PM Pavel Tupitsyn < > ptupit...@apache.org > > > > > > > > wrote: > > > > > > > > > > > Igniters, > > > > > > > > > > > > I think we should support unsigned data types: > > > > > > uByte, uShort, uInt, uLong > > > > > > > > > > > > Java does not have them, but many other languages do, > > > > > > and with the growing number of thin clients this is important. > > > > > > > > > > > > For example, in current Ignite.NET implementation we store > unsigned > > > > > values > > > > > > as signed internally, > > > > > > but this is a huge pain when it comes to metadata, binary > objects, > > > etc. > > > > > > (it is easy to deserialize int as uint when you have a class, but > > not > > > > > with > > > > > > BinaryObject.GetField) > > > > > > > > > > > > Any objections? > > > > > > > > > > > > On Tue, Nov 24, 2020 at 12:28 PM Andrey Mashenkov < > > > > > > andrey.mashen...@gmail.com> wrote: > > > > > > > > > > > > > Denis, > > > > > > > > > > > > > > Good point. Both serializers use reflection API. > > > > > > > However, we will allow users to configure static schema along > > with > > > > > > 'strict' > > > > > > > schema mode, we still need to validate user classes on client > > nodes > > > > > > against > > > > > > > the latest schema in the grid and reflection API is the only > way > > > to > > > > do > > > > > > it. > > > > > > > One can find a few articles on the internet on how to enable > > > > reflection > > > > > > in > > > > > > > GraalVM. > > > > > > > > > > > > > > I'll create a task for supporting GraalVM, and maybe someone > who > > is > > > > > > > familiar with GraalVM will suggest a solution or a proper > > > workaround. > > > > > Or > > > > > > > I'll do it a bit later. > > > > > > > If no workaround is found, we could allow users to write it's > own > > > > > > > serializer, but I don't think it is a good idea to expose any > > > > internal > > > > > > > classes to the public. > > > > > > > > > > > > > > On Tue, Nov 24, 2020 at 2:55 AM Denis Magda <dma...@apache.org > > > > > > wrote: > > > > > > > > > > > > > > > Andrey, thanks for the update, > > > > > > > > > > > > > > > > Does any of the serializers take into consideration the > > > > > > > > native-image-generation feature of GraalVM? > > > > > > > > https://www.graalvm.org/reference-manual/native-image/ > > > > > > > > > > > > > > > > With the current binary marshaller, we can't even generate a > > > native > > > > > > image > > > > > > > > for the code using our thin client APIs. > > > > > > > > > > > > > > > > - > > > > > > > > Denis > > > > > > > > > > > > > > > > > > > > > > > > On Mon, Nov 23, 2020 at 4:39 AM Andrey Mashenkov < > > > > > > > > andrey.mashen...@gmail.com> > > > > > > > > wrote: > > > > > > > > > > > > > > > > > Hi Igniters, > > > > > > > > > > > > > > > > > > I'd like to continue discussion of IEP-54 (Schema-first > > > > approach). > > > > > > > > > > > > > > > > > > Hope everyone who is interested had a chance to get > familiar > > > with > > > > > the > > > > > > > > > proposal [1]. > > > > > > > > > Please, do not hesitate to ask questions and share your > > ideas. > > > > > > > > > > > > > > > > > > I've prepared a prototype of serializer [2] for the data > > layout > > > > > > > described > > > > > > > > > in the proposal. > > > > > > > > > In prototy, I compared 2 approaches to (de)serialize > objects, > > > the > > > > > > first > > > > > > > > one > > > > > > > > > uses java reflection/unsafe API and similar to one we > already > > > use > > > > > in > > > > > > > > Ignite > > > > > > > > > and the second one generates serializer for particular user > > > class > > > > > and > > > > > > > > uses > > > > > > > > > Janino library for compilation. > > > > > > > > > Second one shows better results in benchmarks. > > > > > > > > > I think we can go with it as default serializer and have > > > > > > > reflection-based > > > > > > > > > implementation as a fallback if someone will have issues > with > > > the > > > > > > first > > > > > > > > > one. > > > > > > > > > WDYT? > > > > > > > > > > > > > > > > > > There are a number of tasks under the umbrella ticket [3] > > > waiting > > > > > for > > > > > > > the > > > > > > > > > assignee. > > > > > > > > > > > > > > > > > > BTW, I'm going to create more tickets for schema manager > > modes > > > > > > > > > implementation, but would like to clarify some details. > > > > > > > > > > > > > > > > > > I thought schemaManager on each node should held: > > > > > > > > > 1. Local mapping of "schema version" <--> validated local > > > > > key/value > > > > > > > > > classes pair. > > > > > > > > > 2. Cluster-wide schema changes history. > > > > > > > > > On the client side. Before any key-value API operation we > > > should > > > > > > > > validate a > > > > > > > > > schema for a given key-value pair. > > > > > > > > > If there is no local-mapping exists for a given key-value > > pair > > > or > > > > > if > > > > > > a > > > > > > > > > cluster wide schema has a more recent version then the > > > key-value > > > > > pair > > > > > > > > > should be validated against the latest version and local > > > mapping > > > > > > should > > > > > > > > be > > > > > > > > > updated/actualized. > > > > > > > > > If an object doesn't fit to the latest schema then it > depends > > > on > > > > > > schema > > > > > > > > > mode: either fail the operation ('strict' mode) or a new > > > mapping > > > > > > should > > > > > > > > be > > > > > > > > > created and a new schema version should be propagated to > the > > > > > cluster. > > > > > > > > > > > > > > > > > > On the server side we usually have no key-value classes and > > we > > > > > > operate > > > > > > > > with > > > > > > > > > tuples. > > > > > > > > > As schema change history is available and a tuple has > schema > > > > > version, > > > > > > > > then > > > > > > > > > it is possible to upgrade any received tuple to the last > > > version > > > > > > > without > > > > > > > > > desialization. > > > > > > > > > Thus we could allow nodes to send key-value pairs of > previous > > > > > > versions > > > > > > > > (if > > > > > > > > > they didn't receive a schema update yet) without reverting > > > schema > > > > > > > changes > > > > > > > > > made by a node with newer classes. > > > > > > > > > > > > > > > > > > Alex, Val, Ivan did you mean the same? > > > > > > > > > > > > > > > > > > > > > > > > > > > [1] > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > https://cwiki.apache.org/confluence/display/IGNITE/IEP-54%3A+Schema-first+Approach > > > > > > > > > [2] > > > > > > > https://github.com/apache/ignite/tree/ignite-13618/modules/commons > > > > > > > > > [3] https://issues.apache.org/jira/browse/IGNITE-13616 > > > > > > > > > > > > > > > > > > On Thu, Sep 17, 2020 at 9:21 AM Ivan Pavlukhin < > > > > > vololo...@gmail.com> > > > > > > > > > wrote: > > > > > > > > > > > > > > > > > > > Folks, > > > > > > > > > > > > > > > > > > > > Please do not ignore history. We had a thread [1] with > many > > > > > bright > > > > > > > > > > ideas. We can resume it. > > > > > > > > > > > > > > > > > > > > [1] > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > http://apache-ignite-developers.2346864.n4.nabble.com/Applicability-of-term-cache-to-Apache-Ignite-td36541.html > > > > > > > > > > > > > > > > > > > > 2020-09-10 0:08 GMT+03:00, Denis Magda < > dma...@apache.org > > >: > > > > > > > > > > > Val, makes sense, thanks for explaining. > > > > > > > > > > > > > > > > > > > > > > Agree that we need to have a separate discussion thread > > for > > > > the > > > > > > > > "table" > > > > > > > > > > and > > > > > > > > > > > "cache" terms substitution. I'll appreciate it if you > > start > > > > the > > > > > > > > thread > > > > > > > > > > > sharing pointers to any relevant IEPs and reasoning > > behind > > > > the > > > > > > > > > suggested > > > > > > > > > > > change. > > > > > > > > > > > > > > > > > > > > > > - > > > > > > > > > > > Denis > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > On Tue, Sep 8, 2020 at 6:01 PM Valentin Kulichenko < > > > > > > > > > > > valentin.kuliche...@gmail.com> wrote: > > > > > > > > > > > > > > > > > > > > > >> Hi Denis, > > > > > > > > > > >> > > > > > > > > > > >> I guess the wording in the IEP is a little bit > > confusing. > > > > All > > > > > it > > > > > > > > means > > > > > > > > > > is > > > > > > > > > > >> that you should not create nested POJOs, but rather > > inline > > > > > > fields > > > > > > > > > into a > > > > > > > > > > >> single POJO that is mapped to a particular schema. In > > > other > > > > > > words, > > > > > > > > > > nested > > > > > > > > > > >> POJOs are not supported. > > > > > > > > > > >> > > > > > > > > > > >> Alex, is this correct? Please let me know if I'm > missing > > > > > > > something. > > > > > > > > > > >> > > > > > > > > > > >> As for the "cache" term, I agree that it is outdated, > > but > > > > I'm > > > > > > not > > > > > > > > sure > > > > > > > > > > >> what we can replace it with. "Table" is tightly > > associated > > > > > with > > > > > > > SQL, > > > > > > > > > but > > > > > > > > > > >> SQL is optional in our case. Do you want to create a > > > > separate > > > > > > > > > discussion > > > > > > > > > > >> about this? > > > > > > > > > > >> > > > > > > > > > > >> -Val > > > > > > > > > > >> > > > > > > > > > > >> On Tue, Sep 8, 2020 at 4:37 PM Denis Magda < > > > > dma...@apache.org > > > > > > > > > > > > > > wrote: > > > > > > > > > > >> > > > > > > > > > > >>> Val, > > > > > > > > > > >>> > > > > > > > > > > >>> I've checked the IEP again and have a few questions. > > > > > > > > > > >>> > > > > > > > > > > >>> Arbitrary nested objects and collections are not > > allowed > > > as > > > > > > > column > > > > > > > > > > >>> values. > > > > > > > > > > >>> > Nested POJOs should either be inlined into schema, > or > > > > > stored > > > > > > as > > > > > > > > > BLOBs > > > > > > > > > > >>> > > > > > > > > > > >>> > > > > > > > > > > >>> Could you provide a DDL code snippet showing how the > > > > inlining > > > > > > of > > > > > > > > > POJOs > > > > > > > > > > >>> is > > > > > > > > > > >>> supposed to work? > > > > > > > > > > >>> > > > > > > > > > > >>> Also, we keep using the terms "cache" and "table" > > > > throughout > > > > > > the > > > > > > > > IEP. > > > > > > > > > > Is > > > > > > > > > > >>> it > > > > > > > > > > >>> the right time to discuss an alternate name that > would > > > > > replace > > > > > > > > those > > > > > > > > > > >>> too? > > > > > > > > > > >>> Personally, the "table" should stay and the "cache" > > > should > > > > go > > > > > > > > > > >>> considering > > > > > > > > > > >>> that SQL is one of the primary APIs in Ignite and > that > > > DDL > > > > is > > > > > > > > > supported > > > > > > > > > > >>> out-of-the-box. > > > > > > > > > > >>> > > > > > > > > > > >>> > > > > > > > > > > >>> - > > > > > > > > > > >>> Denis > > > > > > > > > > >>> > > > > > > > > > > >>> > > > > > > > > > > >>> On Mon, Sep 7, 2020 at 12:26 PM Valentin Kulichenko < > > > > > > > > > > >>> valentin.kuliche...@gmail.com> wrote: > > > > > > > > > > >>> > > > > > > > > > > >>> > Ivan, > > > > > > > > > > >>> > > > > > > > > > > > >>> > I see your point. I agree that with the automatic > > > updates > > > > > we > > > > > > > step > > > > > > > > > > into > > > > > > > > > > >>> the > > > > > > > > > > >>> > schema-last territory. > > > > > > > > > > >>> > > > > > > > > > > > >>> > Actually, if we support automatic evolution, we can > > as > > > > well > > > > > > > > support > > > > > > > > > > >>> > creating a cache without schema and inferring it > from > > > the > > > > > > first > > > > > > > > > > >>> > insert. > > > > > > > > > > >>> In > > > > > > > > > > >>> > other words, we can have both "schema-first" and > > > > > > "schema-last" > > > > > > > > > modes. > > > > > > > > > > >>> > > > > > > > > > > > >>> > Alexey, what do you think? > > > > > > > > > > >>> > > > > > > > > > > > >>> > -Val > > > > > > > > > > >>> > > > > > > > > > > > >>> > On Mon, Sep 7, 2020 at 5:59 AM Alexey Goncharuk < > > > > > > > > > > >>> > alexey.goncha...@gmail.com> > > > > > > > > > > >>> > wrote: > > > > > > > > > > >>> > > > > > > > > > > > >>> > > Ivan, > > > > > > > > > > >>> > > > > > > > > > > > > >>> > > Thank you, I got your concern now. As it is > mostly > > > > > > regarding > > > > > > > > the > > > > > > > > > > >>> > > terminology, I am absolutely fine with changing > the > > > > name > > > > > to > > > > > > > > > > whatever > > > > > > > > > > >>> fits > > > > > > > > > > >>> > > the approach best. Dynamic or evolving schema > > sounds > > > > > > great. I > > > > > > > > > will > > > > > > > > > > >>> make > > > > > > > > > > >>> > > corresponding changes to the IEP once we settle > on > > > the > > > > > > name. > > > > > > > > > > >>> > > > > > > > > > > > > >>> > > пн, 7 сент. 2020 г. в 11:33, Ivan Pavlukhin < > > > > > > > > vololo...@gmail.com > > > > > > > > > >: > > > > > > > > > > >>> > > > > > > > > > > > > >>> > > > Hi Val, > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > Thank you for your answer! > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > My understanding is a little bit different. > Yes, > > > > schema > > > > > > > > > evolution > > > > > > > > > > >>> > > > definitely should be possible. But I see a main > > > > > > difference > > > > > > > in > > > > > > > > > > "how > > > > > > > > > > >>> > > > schema is updated". I treat a common SQL > approach > > > > > > > > schema-first. > > > > > > > > > > >>> Schema > > > > > > > > > > >>> > > > and data manipulation operations are clearly > > > > separated > > > > > > and > > > > > > > it > > > > > > > > > > >>> enables > > > > > > > > > > >>> > > > interesting capabilities, e.g. preventing > > untended > > > > > schema > > > > > > > > > changes > > > > > > > > > > >>> > > > by > > > > > > > > > > >>> > > > mistaken data operations, restricting user > > > > permissions > > > > > to > > > > > > > > > change > > > > > > > > > > >>> > > > schema. > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > > Schema-first means that schema exists in > > advance > > > > and > > > > > > all > > > > > > > > the > > > > > > > > > > >>> stored > > > > > > > > > > >>> > > data > > > > > > > > > > >>> > > > is compliant with it - that's exactly what is > > > > proposed. > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > A schema-last approach mentioned in [1] also > > > assumes > > > > > that > > > > > > > > > schema > > > > > > > > > > >>> > > > exists, but it is inferred from data. Is not it > > > more > > > > > > > similar > > > > > > > > to > > > > > > > > > > >>> > > > the > > > > > > > > > > >>> > > > proposing approach? > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > And I would like to say, that my main concern > so > > > far > > > > is > > > > > > > > mostly > > > > > > > > > > >>> > > > about > > > > > > > > > > >>> > > > terminology. And I suppose if it confuses me > then > > > > > others > > > > > > > > might > > > > > > > > > be > > > > > > > > > > >>> > > > confused as well. My feeling is closer to > > "dynamic > > > or > > > > > > > liquid > > > > > > > > or > > > > > > > > > > >>> > > > may > > > > > > > > > > >>> be > > > > > > > > > > >>> > > > evolving schema". > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > [1] > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > https://people.cs.umass.edu/~yanlei/courses/CS691LL-f06/papers/SH05.pdf > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > 2020-09-07 0:47 GMT+03:00, Valentin Kulichenko > < > > > > > > > > > > >>> > > > valentin.kuliche...@gmail.com>: > > > > > > > > > > >>> > > > > Hi Ivan, > > > > > > > > > > >>> > > > > > > > > > > > > > > >>> > > > > I don't see an issue with that. Schema-first > > > means > > > > > that > > > > > > > > > schema > > > > > > > > > > >>> exists > > > > > > > > > > >>> > > in > > > > > > > > > > >>> > > > > advance and all the stored data is compliant > > with > > > > it > > > > > - > > > > > > > > that's > > > > > > > > > > >>> exactly > > > > > > > > > > >>> > > > what > > > > > > > > > > >>> > > > > is proposed. There are no restrictions > > > prohibiting > > > > > > > changes > > > > > > > > to > > > > > > > > > > >>> > > > > the > > > > > > > > > > >>> > > schema. > > > > > > > > > > >>> > > > > > > > > > > > > > > >>> > > > > -Val > > > > > > > > > > >>> > > > > > > > > > > > > > > >>> > > > > On Sat, Sep 5, 2020 at 9:52 PM Ivan > Pavlukhin < > > > > > > > > > > >>> vololo...@gmail.com> > > > > > > > > > > >>> > > > wrote: > > > > > > > > > > >>> > > > > > > > > > > > > > > >>> > > > >> Alexey, > > > > > > > > > > >>> > > > >> > > > > > > > > > > >>> > > > >> I am a little bit confused with terminology. > > My > > > > > > > > > understanding > > > > > > > > > > >>> > conforms > > > > > > > > > > >>> > > > >> to a survey [1] (see part X Semi Structured > > > Data). > > > > > Can > > > > > > > we > > > > > > > > > > >>> > > > >> really > > > > > > > > > > >>> > treat > > > > > > > > > > >>> > > > >> a "dynamic schema" approach as a kind of > > > > > > "schema-first"? > > > > > > > > > > >>> > > > >> > > > > > > > > > > >>> > > > >> [1] > > > > > > > > > > >>> > > > >> > > > > > > > > > > >>> > > > > > > > > > > > > >>> > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > https://people.cs.umass.edu/~yanlei/courses/CS691LL-f06/papers/SH05.pdf > > > > > > > > > > >>> > > > >> > > > > > > > > > > >>> > > > >> 2020-09-02 1:53 GMT+03:00, Denis Magda < > > > > > > > dma...@apache.org > > > > > > > > >: > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > >>> > > > >> >> However, could you please elaborate on > the > > > > > relation > > > > > > > > > between > > > > > > > > > > >>> > Ignite > > > > > > > > > > >>> > > > and > > > > > > > > > > >>> > > > >> >> ORM? > > > > > > > > > > >>> > > > >> >> Is there a use case for Hibernate running > > on > > > > top > > > > > of > > > > > > > > > Ignite > > > > > > > > > > >>> > > > >> >> (I > > > > > > > > > > >>> > > haven't > > > > > > > > > > >>> > > > >> >> seen > > > > > > > > > > >>> > > > >> >> one so far)? If so, what is missing > exactly > > > on > > > > > the > > > > > > > > Ignite > > > > > > > > > > >>> side to > > > > > > > > > > >>> > > > >> support > > > > > > > > > > >>> > > > >> >> this? In my understanding, all you need > is > > > SQL > > > > > API > > > > > > > > which > > > > > > > > > we > > > > > > > > > > >>> > already > > > > > > > > > > >>> > > > >> have. > > > > > > > > > > >>> > > > >> >> Am I missing something? > > > > > > > > > > >>> > > > >> > > > > > > > > > > > >>> > > > >> > > > > > > > > > > > >>> > > > >> > Good point, yes, if all the ORM > integrations > > > use > > > > > > > Ignite > > > > > > > > > SQL > > > > > > > > > > >>> APIs > > > > > > > > > > >>> > > > >> > internally, then they can easily translate > > an > > > > > Entity > > > > > > > > > object > > > > > > > > > > >>> into > > > > > > > > > > >>> > an > > > > > > > > > > >>> > > > >> > INSERT/UPDATE statement that lists all the > > > > > object's > > > > > > > > > fields. > > > > > > > > > > >>> > Luckily, > > > > > > > > > > >>> > > > >> > our > > > > > > > > > > >>> > > > >> > Spring Data integration is already based > on > > > the > > > > > > Ignite > > > > > > > > SQL > > > > > > > > > > >>> > > > >> > APIs > > > > > > > > > > >>> > and > > > > > > > > > > >>> > > > >> > needs > > > > > > > > > > >>> > > > >> > to be improved once the schema-first > > approach > > > is > > > > > > > > > supported. > > > > > > > > > > >>> That > > > > > > > > > > >>> > > would > > > > > > > > > > >>> > > > >> > solve a ton of usability issues. > > > > > > > > > > >>> > > > >> > > > > > > > > > > > >>> > > > >> > I would revise the Hibernate integration > as > > > well > > > > > > > during > > > > > > > > > the > > > > > > > > > > >>> Ignite > > > > > > > > > > >>> > > 3.0 > > > > > > > > > > >>> > > > >> dev > > > > > > > > > > >>> > > > >> > phase. Can't say if it's used a lot but > > Spring > > > > > Data > > > > > > is > > > > > > > > > > >>> > > > >> > getting > > > > > > > > > > >>> > > > traction > > > > > > > > > > >>> > > > >> for > > > > > > > > > > >>> > > > >> > sure. > > > > > > > > > > >>> > > > >> > > > > > > > > > > > >>> > > > >> > @Michael Pollind, I'll loop you in as long > > as > > > > > you've > > > > > > > > > started > > > > > > > > > > >>> > working > > > > > > > > > > >>> > > > on > > > > > > > > > > >>> > > > >> the > > > > > > > > > > >>> > > > >> > Ignite support for Micornaut Data > > > > > > > > > > >>> > > > >> > < > > > > > > > > > > >>> > > > > > > > > > > > > https://micronaut-projects.github.io/micronaut-data/latest/guide/> > > > > > > > > > > >>> > > > and > > > > > > > > > > >>> > > > >> > came across some challenges. Just watch > this > > > > > > > discussion. > > > > > > > > > > >>> > > > >> > That's > > > > > > > > > > >>> > what > > > > > > > > > > >>> > > > is > > > > > > > > > > >>> > > > >> > coming in Ignite 3.0. > > > > > > > > > > >>> > > > >> > > > > > > > > > > > >>> > > > >> > > > > > > > > > > > >>> > > > >> > - > > > > > > > > > > >>> > > > >> > Denis > > > > > > > > > > >>> > > > >> > > > > > > > > > > > >>> > > > >> > > > > > > > > > > > >>> > > > >> > On Mon, Aug 31, 2020 at 5:11 PM Valentin > > > > > Kulichenko > > > > > > < > > > > > > > > > > >>> > > > >> > valentin.kuliche...@gmail.com> wrote: > > > > > > > > > > >>> > > > >> > > > > > > > > > > > >>> > > > >> >> Hi Denis, > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > >>> > > > >> >> Generally speaking, I believe that the > > > > > schema-first > > > > > > > > > > approach > > > > > > > > > > >>> > > natively > > > > > > > > > > >>> > > > >> >> addresses the issue if duplicate fields > in > > > key > > > > > and > > > > > > > > value > > > > > > > > > > >>> objects, > > > > > > > > > > >>> > > > >> because > > > > > > > > > > >>> > > > >> >> schema will be created for a cache, not > for > > > an > > > > > > > object, > > > > > > > > as > > > > > > > > > > it > > > > > > > > > > >>> > > happens > > > > > > > > > > >>> > > > >> now. > > > > > > > > > > >>> > > > >> >> Basically, the schema will define whether > > > there > > > > > is > > > > > > a > > > > > > > > > > primary > > > > > > > > > > >>> key > > > > > > > > > > >>> > or > > > > > > > > > > >>> > > > >> >> not, > > > > > > > > > > >>> > > > >> >> and which fields are included in case > there > > > is > > > > > one. > > > > > > > Any > > > > > > > > > API > > > > > > > > > > >>> that > > > > > > > > > > >>> > we > > > > > > > > > > >>> > > > >> would > > > > > > > > > > >>> > > > >> >> have must be compliant with this, so it > > > becomes > > > > > > > fairly > > > > > > > > > easy > > > > > > > > > > >>> > > > >> >> to > > > > > > > > > > >>> > work > > > > > > > > > > >>> > > > >> >> with > > > > > > > > > > >>> > > > >> >> data as with a set of records, rather > than > > > > > > key-value > > > > > > > > > pairs. > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > >>> > > > >> >> However, could you please elaborate on > the > > > > > relation > > > > > > > > > between > > > > > > > > > > >>> > Ignite > > > > > > > > > > >>> > > > and > > > > > > > > > > >>> > > > >> >> ORM? > > > > > > > > > > >>> > > > >> >> Is there a use case for Hibernate running > > on > > > > top > > > > > of > > > > > > > > > Ignite > > > > > > > > > > >>> > > > >> >> (I > > > > > > > > > > >>> > > haven't > > > > > > > > > > >>> > > > >> >> seen > > > > > > > > > > >>> > > > >> >> one so far)? If so, what is missing > exactly > > > on > > > > > the > > > > > > > > Ignite > > > > > > > > > > >>> side to > > > > > > > > > > >>> > > > >> support > > > > > > > > > > >>> > > > >> >> this? In my understanding, all you need > is > > > SQL > > > > > API > > > > > > > > which > > > > > > > > > we > > > > > > > > > > >>> > already > > > > > > > > > > >>> > > > >> have. > > > > > > > > > > >>> > > > >> >> Am I missing something? > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > >>> > > > >> >> -Val > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > >>> > > > >> >> On Mon, Aug 31, 2020 at 2:08 PM Denis > > Magda < > > > > > > > > > > >>> dma...@apache.org> > > > > > > > > > > >>> > > > wrote: > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > >>> > > > >> >> > Val, > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > I would propose adding another point to > > the > > > > > > > > motivations > > > > > > > > > > >>> > > > >> >> > list > > > > > > > > > > >>> > > which > > > > > > > > > > >>> > > > >> >> > is > > > > > > > > > > >>> > > > >> >> > related to the ORM frameworks such as > > > Spring > > > > > > Data, > > > > > > > > > > >>> Hibernate, > > > > > > > > > > >>> > > > >> Micronaut > > > > > > > > > > >>> > > > >> >> and > > > > > > > > > > >>> > > > >> >> > many others. > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > Presently, the storage engine requires > to > > > > > > > distinguish > > > > > > > > > key > > > > > > > > > > >>> > objects > > > > > > > > > > >>> > > > >> >> > from > > > > > > > > > > >>> > > > >> >> the > > > > > > > > > > >>> > > > >> >> > value ones that complicate the usage of > > > > Ignite > > > > > > with > > > > > > > > > those > > > > > > > > > > >>> ORM > > > > > > > > > > >>> > > > >> >> > frameworks > > > > > > > > > > >>> > > > >> >> > (especially if a key object comprises > > > several > > > > > > > > fields). > > > > > > > > > > >>> > > > >> >> > More > > > > > > > > > > >>> on > > > > > > > > > > >>> > > this > > > > > > > > > > >>> > > > >> can > > > > > > > > > > >>> > > > >> >> be > > > > > > > > > > >>> > > > >> >> > found here: > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > >>> > > > >> > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > > > > > > > > > > >>> > > > > > > > > > > > >>> > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > http://apache-ignite-developers.2346864.n4.nabble.com/DISCUSSION-Key-and-Value-fields-with-same-name-and-SQL-DML-td47557.html > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > It will be nice if the new schema-first > > > > > approach > > > > > > > > allows > > > > > > > > > > us > > > > > > > > > > >>> to > > > > > > > > > > >>> > > work > > > > > > > > > > >>> > > > >> with > > > > > > > > > > >>> > > > >> >> > a > > > > > > > > > > >>> > > > >> >> > single entity object when it comes to > the > > > > ORMs. > > > > > > > With > > > > > > > > no > > > > > > > > > > >>> need to > > > > > > > > > > >>> > > > >> >> > split > > > > > > > > > > >>> > > > >> >> > the > > > > > > > > > > >>> > > > >> >> > entity into a key and value. Just want > to > > > be > > > > > sure > > > > > > > > that > > > > > > > > > > the > > > > > > > > > > >>> > Ignite > > > > > > > > > > >>> > > > >> >> > 3.0 > > > > > > > > > > >>> > > > >> >> > has > > > > > > > > > > >>> > > > >> >> > all the essential public APIs that > would > > > > > support > > > > > > > the > > > > > > > > > > >>> > > single-entity > > > > > > > > > > >>> > > > >> >> > based > > > > > > > > > > >>> > > > >> >> > approach. > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > What do you think? > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > - > > > > > > > > > > >>> > > > >> >> > Denis > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > On Fri, Aug 28, 2020 at 3:50 PM > Valentin > > > > > > > Kulichenko < > > > > > > > > > > >>> > > > >> >> > valentin.kuliche...@gmail.com> wrote: > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > > Igniters, > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > > >>> > > > >> >> > > One of the big changes proposed for > > > Ignite > > > > > 3.0 > > > > > > is > > > > > > > > the > > > > > > > > > > >>> > so-called > > > > > > > > > > >>> > > > >> >> > > "schema-first approach". To add more > > > > clarity, > > > > > > > I've > > > > > > > > > > >>> > > > >> >> > > started > > > > > > > > > > >>> > > > writing > > > > > > > > > > >>> > > > >> >> > > the > > > > > > > > > > >>> > > > >> >> > IEP > > > > > > > > > > >>> > > > >> >> > > for this change: > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > >>> > > > >> > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > > > > > > > > > > >>> > > > > > > > > > > > >>> > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > https://cwiki.apache.org/confluence/display/IGNITE/IEP-54%3A+Schema-first+Approach > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > > >>> > > > >> >> > > Please take a look and let me know if > > > there > > > > > are > > > > > > > any > > > > > > > > > > >>> immediate > > > > > > > > > > >>> > > > >> >> > > thoughts, > > > > > > > > > > >>> > > > >> >> > > suggestions, or objections. > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > > >>> > > > >> >> > > -Val > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > > >>> > > > >> >> > > > > > > > > > > >>> > > > >> > > > > > > > > > > > >>> > > > >> > > > > > > > > > > >>> > > > >> > > > > > > > > > > >>> > > > >> -- > > > > > > > > > > >>> > > > >> > > > > > > > > > > >>> > > > >> Best regards, > > > > > > > > > > >>> > > > >> Ivan Pavlukhin > > > > > > > > > > >>> > > > >> > > > > > > > > > > >>> > > > > > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > -- > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > Best regards, > > > > > > > > > > >>> > > > Ivan Pavlukhin > > > > > > > > > > >>> > > > > > > > > > > > > > >>> > > > > > > > > > > > > >>> > > > > > > > > > > > >>> > > > > > > > > > > >> > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > -- > > > > > > > > > > > > > > > > > > > > Best regards, > > > > > > > > > > Ivan Pavlukhin > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > -- > > > > > > > > > Best regards, > > > > > > > > > Andrey V. Mashenkov > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > -- > > > > > > > Best regards, > > > > > > > Andrey V. Mashenkov > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > -- > > > Best regards, > > > Andrey V. Mashenkov > > > > > > -- Best regards, Andrey V. Mashenkov