All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.flink.table.dataview.MapViewSerializer Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.apache.flink.table.dataview;

import org.apache.flink.annotation.Internal;
import org.apache.flink.api.common.typeutils.CompositeTypeSerializerUtil;
import org.apache.flink.api.common.typeutils.LegacySerializerSnapshotTransformer;
import org.apache.flink.api.common.typeutils.TypeSerializer;
import org.apache.flink.api.common.typeutils.TypeSerializerSnapshot;
import org.apache.flink.api.common.typeutils.base.MapSerializerConfigSnapshot;
import org.apache.flink.api.common.typeutils.base.MapSerializerSnapshot;
import org.apache.flink.core.memory.DataInputView;
import org.apache.flink.core.memory.DataOutputView;
import org.apache.flink.table.api.dataview.MapView;

import java.io.IOException;
import java.util.Map;

/**
 * A serializer for {@link MapView}. The serializer relies on a key serializer and a value
 * serializer for the serialization of the map's key-value pairs.
 *
 * 

The serialization format for the map is as follows: four bytes for the length of the map, * followed by the serialized representation of each key-value pair. To allow null values, each * value is prefixed by a null marker. * * @param The type of the keys in the map. * @param The type of the values in the map. */ @Internal @Deprecated public class MapViewSerializer extends TypeSerializer> implements LegacySerializerSnapshotTransformer> { private static final long serialVersionUID = -9007142882049098705L; private final TypeSerializer> mapSerializer; public MapViewSerializer(TypeSerializer> mapSerializer) { this.mapSerializer = mapSerializer; } @Override public boolean isImmutableType() { return false; } @Override public TypeSerializer> duplicate() { return new MapViewSerializer<>(mapSerializer.duplicate()); } @Override public MapView createInstance() { return new MapView<>(); } @Override public MapView copy(MapView from) { final MapView view = new MapView<>(); view.setMap(mapSerializer.copy(from.getMap())); return view; } @Override public MapView copy(MapView from, MapView reuse) { return copy(from); } @Override public int getLength() { return -1; } @Override public void serialize(MapView record, DataOutputView target) throws IOException { mapSerializer.serialize(record.getMap(), target); } @Override public MapView deserialize(DataInputView source) throws IOException { final MapView view = new MapView<>(); view.setMap(mapSerializer.deserialize(source)); return view; } @Override public MapView deserialize(MapView reuse, DataInputView source) throws IOException { return deserialize(source); } @Override public void copy(DataInputView source, DataOutputView target) throws IOException { mapSerializer.copy(source, target); } @Override public boolean equals(Object obj) { if (obj instanceof MapViewSerializer) { //noinspection unchecked MapViewSerializer other = (MapViewSerializer) obj; return mapSerializer.equals(other.mapSerializer); } return false; } @Override public int hashCode() { return mapSerializer.hashCode(); } @Override public TypeSerializerSnapshot> snapshotConfiguration() { return new MapViewSerializerSnapshot<>(this); } /** * We need to override this as a {@link LegacySerializerSnapshotTransformer} because in Flink * 1.6.x and below, this serializer was incorrectly returning directly the snapshot of the * nested map serializer as its own snapshot. * *

This method transforms the incorrect map serializer snapshot to be a proper {@link * MapViewSerializerSnapshot}. */ @Override public TypeSerializerSnapshot> transformLegacySerializerSnapshot( TypeSerializerSnapshot legacySnapshot) { if (legacySnapshot instanceof MapViewSerializerSnapshot) { return (TypeSerializerSnapshot>) legacySnapshot; } else if (legacySnapshot instanceof MapSerializerConfigSnapshot) { // first, transform the incorrect map serializer's snapshot // into a proper ListSerializerSnapshot MapSerializerSnapshot transformedNestedMapSerializerSnapshot = new MapSerializerSnapshot<>(); MapSerializerConfigSnapshot snapshot = (MapSerializerConfigSnapshot) legacySnapshot; CompositeTypeSerializerUtil.setNestedSerializersSnapshots( transformedNestedMapSerializerSnapshot, snapshot.getNestedSerializersAndConfigs().get(0).f1, snapshot.getNestedSerializersAndConfigs().get(1).f1); // then, wrap the transformed MapSerializerSnapshot // as a nested snapshot in the final resulting MapViewSerializerSnapshot MapViewSerializerSnapshot transformedMapViewSerializerSnapshot = new MapViewSerializerSnapshot<>(); CompositeTypeSerializerUtil.setNestedSerializersSnapshots( transformedMapViewSerializerSnapshot, transformedNestedMapSerializerSnapshot); return transformedMapViewSerializerSnapshot; } else { throw new UnsupportedOperationException( legacySnapshot.getClass().getCanonicalName() + " is not supported."); } } public TypeSerializer> getMapSerializer() { return mapSerializer; } }