[ 
https://issues.apache.org/jira/browse/IGNITE-20106?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Roman Puchkovskiy resolved IGNITE-20106.
----------------------------------------
    Resolution: Fixed

> Check that client schema version matches server-side schema version
> -------------------------------------------------------------------
>
>                 Key: IGNITE-20106
>                 URL: https://issues.apache.org/jira/browse/IGNITE-20106
>             Project: Ignite
>          Issue Type: Improvement
>            Reporter: Roman Puchkovskiy
>            Assignee: Roman Puchkovskiy
>            Priority: Major
>              Labels: iep-110, ignite-3
>             Fix For: 3.0.0-beta2
>
>
> As per 
> https://cwiki.apache.org/confluence/display/IGNITE/IEP-110%3A+Schema+synchronization%3A+basic+schema+changes#IEP110:Schemasynchronization:basicschemachanges-Overallflow
>  , the schema version that the client sends with each  request should be 
> validated against the server-side schema version corresponding to the given 
> table in the tx. If it does not match, SCHEMA_VERSION_MISMATCH_ERR should be 
> sent to the client along with the correct server-side schema version.
> The check should be done on a tx coordinator. Also, the coordinator must 
> check that all the tuples sent by the client (in the same request) are 
> encoded using the same schema version.
> The IEP defines baseTs as tableEnlistTs(tx, table). On the first iteration, 
> we should implement a simpler way to calculate baseTs (max(beginTs, 
> tableCreationTs) to allow created tables to 'appear' in a transaction or even 
> simply beginTs). The full-blown baseTs calculation will be implemented in 
> IGNITE-20108. It makes sense to do it later because it requires substantially 
> more work to only support a not-to-common use-case (ALTER TABLEs after a 
> transaction started, but before it enlisted the table).



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to