Packages

class Snapshot extends SnapshotDescriptor with SnapshotStateManager with StateCache with StatisticsCollection with DataSkippingReader with DeltaLogging

An immutable snapshot of the state of the log at some delta version. Internally this class manages the replay of actions stored in checkpoint or delta files.

After resolving any new actions, it caches the result and collects the following basic information to the driver:

  • Protocol Version
  • Metadata
  • Transaction state
Known Subclasses
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Snapshot
  2. DataSkippingReader
  3. DataSkippingReaderBase
  4. ReadsMetadataFields
  5. DeltaScanGenerator
  6. StatisticsCollection
  7. StateCache
  8. SnapshotStateManager
  9. DeltaLogging
  10. DatabricksLogging
  11. DeltaProgressReporter
  12. Logging
  13. SnapshotDescriptor
  14. AnyRef
  15. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Snapshot(path: Path, version: Long, logSegment: LogSegment, deltaLog: DeltaLog, checksumOpt: Option[VersionChecksum])

Type Members

  1. case class ReconstructedProtocolMetadataAndICT(protocol: Protocol, metadata: Metadata, inCommitTimestamp: Option[Long]) extends Product with Serializable

    Protocol, Metadata, and In-Commit Timestamp retrieved through protocolMetadataAndICTReconstruction which skips a full state reconstruction.

  2. class DataFiltersBuilder extends AnyRef

    Builds the data filters for data skipping.

    Builds the data filters for data skipping.

    Definition Classes
    DataSkippingReaderBase
  3. class CachedDS[A] extends AnyRef
    Definition Classes
    StateCache

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. def aggregationsToComputeState: Map[String, Column]

    A Map of alias to aggregations which needs to be done to calculate the computedState

    A Map of alias to aggregations which needs to be done to calculate the computedState

    Attributes
    protected
    Definition Classes
    SnapshotStateManager
  5. def allFiles: Dataset[AddFile]

    All of the files present in this Snapshot.

    All of the files present in this Snapshot.

    Definition Classes
    SnapshotDataSkippingReaderBase
  6. def applyFuncToStatisticsColumn(statisticsSchema: StructType, statisticsColumn: Column)(function: PartialFunction[(Column, StructField), Option[Column]]): Seq[Column]

    Traverses the statisticsSchema for the provided statisticsColumn and applies function to leaves.

    Traverses the statisticsSchema for the provided statisticsColumn and applies function to leaves.

    Note, for values that are outside the domain of the partial function we keep the original column. If the caller wants to drop the column needs to explicitly return None.

    Definition Classes
    StatisticsCollection
  7. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  8. def cacheDS[A](ds: Dataset[A], name: String): CachedDS[A]

    Create a CachedDS instance for the given Dataset and the name.

    Create a CachedDS instance for the given Dataset and the name.

    Definition Classes
    StateCache
  9. lazy val checkpointProvider: CheckpointProvider

    The CheckpointProvider for the underlying checkpoint

  10. def checkpointSizeInBytes(): Long
  11. val checksumOpt: Option[VersionChecksum]
  12. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... ) @native()
  13. def columnMappingMode: DeltaColumnMappingMode

    The column mapping mode of the target delta table.

    The column mapping mode of the target delta table.

    Definition Classes
    SnapshotStatisticsCollection
  14. def computeChecksum: VersionChecksum

    Computes all the information that is needed by the checksum for the current snapshot.

    Computes all the information that is needed by the checksum for the current snapshot. May kick off state reconstruction if needed by any of the underlying fields. Note that it's safe to set txnId to none, since the snapshot doesn't always have a txn attached. E.g. if a snapshot is created by reading a checkpoint, then no txnId is present.

  15. lazy val computedState: SnapshotState

    Compute the SnapshotState of a table.

    Compute the SnapshotState of a table. Uses the stateDF from the Snapshot to extract the necessary stats.

    Attributes
    protected
    Definition Classes
    SnapshotStateManager
  16. def constructNotNullFilter(statsProvider: StatsProvider, pathToColumn: Seq[String]): Option[DataSkippingPredicate]

    Constructs a DataSkippingPredicate for isNotNull predicates.

    Constructs a DataSkippingPredicate for isNotNull predicates.

    Attributes
    protected
    Definition Classes
    DataSkippingReaderBase
  17. def constructPartitionFilters(filters: Seq[Expression]): Column

    Given the partition filters on the data, rewrite these filters by pointing to the metadata columns.

    Given the partition filters on the data, rewrite these filters by pointing to the metadata columns.

    Attributes
    protected
    Definition Classes
    DataSkippingReaderBase
  18. def convertDataFrameToAddFiles(df: DataFrame): Array[AddFile]
    Attributes
    protected
    Definition Classes
    DataSkippingReaderBase
  19. def dataSchema: StructType

    Returns the schema of the columns written out to file (overridden in write path)

  20. lazy val deletionVectorsSupported: Boolean
    Definition Classes
    StatisticsCollection
  21. def deltaAssert(check: ⇒ Boolean, name: String, msg: String, deltaLog: DeltaLog = null, data: AnyRef = null, path: Option[Path] = None): Unit

    Helper method to check invariants in Delta code.

    Helper method to check invariants in Delta code. Fails when running in tests, records a delta assertion event and logs a warning otherwise.

    Attributes
    protected
    Definition Classes
    DeltaLogging
  22. lazy val deltaFileIndexOpt: Option[DeltaLogFileIndex]

    Given the list of files from LogSegment, create respective file indices to help create a DataFrame and short-circuit the many file existence and partition schema inference checks that exist in DataSource.resolveRelation().

    Given the list of files from LogSegment, create respective file indices to help create a DataFrame and short-circuit the many file existence and partition schema inference checks that exist in DataSource.resolveRelation().

    Attributes
    protected[delta]
  23. def deltaFileSizeInBytes(): Long
  24. val deltaLog: DeltaLog
  25. def domainMetadata: Seq[DomainMetadata]
    Definition Classes
    SnapshotStateManager
  26. def domainMetadatasIfKnown: Option[Seq[DomainMetadata]]
    Attributes
    protected[delta]
    Definition Classes
    SnapshotStateManager
  27. def emptyDF: DataFrame
    Attributes
    protected
  28. def ensureCommitFilesBackfilled(): Unit

    Ensures that commit files are backfilled up to the current version in the snapshot.

    Ensures that commit files are backfilled up to the current version in the snapshot.

    This method checks if there are any un-backfilled versions up to the current version and triggers the backfilling process using the commit-owner. It verifies that the delta file for the current version exists after the backfilling process.

    Exceptions thrown

    IllegalStateException if the delta file for the current version is not found after backfilling.

  29. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  30. def equals(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  31. def extractComputedState(stateDF: DataFrame): SnapshotState

    Extract the SnapshotState from the provided dataframe of actions.

    Extract the SnapshotState from the provided dataframe of actions. Requires that the dataframe has already been deduplicated (either through logReplay or some other method).

    Attributes
    protected
    Definition Classes
    SnapshotStateManager
  32. lazy val fileIndices: Seq[DeltaLogFileIndex]
    Attributes
    protected
  33. def fileSizeHistogram: Option[FileSizeHistogram]
    Definition Classes
    SnapshotStateManager
  34. def filesForScan(limit: Long, partitionFilters: Seq[Expression]): DeltaScan

    Gathers files that should be included in a scan based on the given predicates and limit.

    Gathers files that should be included in a scan based on the given predicates and limit. This will be called only when all predicates are on partitioning columns. Statistics about the amount of data that will be read are gathered and returned.

    Definition Classes
    DataSkippingReaderBaseDeltaScanGenerator
  35. def filesForScan(filters: Seq[Expression], keepNumRecords: Boolean): DeltaScan

    Gathers files that should be included in a scan based on the given predicates.

    Gathers files that should be included in a scan based on the given predicates. Statistics about the amount of data that will be read are gathered and returned. Note, the statistics column that is added when keepNumRecords = true should NOT take into account DVs. Consumers of this method might commit the file. The semantics of the statistics need to be consistent across all files.

    Definition Classes
    DataSkippingReaderBaseDeltaScanGenerator
  36. def filesWithStatsForScan(partitionFilters: Seq[Expression]): DataFrame

    Returns a DataFrame for the given partition filters.

    Returns a DataFrame for the given partition filters. The schema of returned DataFrame is nearly the same as AddFile, except that the stats field is parsed to a struct from a json string.

    Definition Classes
    DataSkippingReaderBaseDeltaScanGenerator
  37. def filterOnPartitions(partitionFilters: Seq[Expression], keepNumRecords: Boolean): (Seq[AddFile], DataSize)

    Get all the files in this table given the partition filter and the corresponding size of the scan.

    Get all the files in this table given the partition filter and the corresponding size of the scan.

    keepNumRecords

    Also select stats.numRecords in the query. This may slow down the query as it has to parse json.

    Attributes
    protected
    Definition Classes
    DataSkippingReaderBase
  38. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  39. def getAllFiles(keepNumRecords: Boolean): Seq[AddFile]

    Get all the files in this table.

    Get all the files in this table.

    keepNumRecords

    Also select stats.numRecords in the query. This may slow down the query as it has to parse json.

    Attributes
    protected
    Definition Classes
    DataSkippingReaderBase
  40. def getBaseStatsColumn: Column

    Returns a Column that references the stats field data skipping should use

    Returns a Column that references the stats field data skipping should use

    Definition Classes
    ReadsMetadataFields
  41. def getBaseStatsColumnName: String
    Definition Classes
    ReadsMetadataFields
  42. final def getClass(): Class[_]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  43. def getCommonTags(deltaLog: DeltaLog, tahoeId: String): Map[TagDefinition, String]
    Definition Classes
    DeltaLogging
  44. def getDataSkippedFiles(partitionFilters: Column, dataFilters: DataSkippingPredicate, keepNumRecords: Boolean): (Seq[AddFile], Seq[DataSize])

    Given the partition and data filters, leverage data skipping statistics to find the set of files that need to be queried.

    Given the partition and data filters, leverage data skipping statistics to find the set of files that need to be queried. Returns a tuple of the files and optionally the size of the scan that's generated if there were no filters, if there were only partition filters, and combined effect of partition and data filters respectively.

    Attributes
    protected
    Definition Classes
    DataSkippingReaderBase
  45. def getErrorData(e: Throwable): Map[String, Any]
    Definition Classes
    DeltaLogging
  46. def getFilesAndNumRecords(df: DataFrame): Iterator[(AddFile, NumRecords)] with Closeable

    Get the files and number of records within each file, to perform limit pushdown.

    Get the files and number of records within each file, to perform limit pushdown.

    Definition Classes
    DataSkippingReaderBase
  47. lazy val getInCommitTimestampOpt: Option[Long]

    Returns the inCommitTimestamp if ICT is enabled, otherwise returns None.

    Returns the inCommitTimestamp if ICT is enabled, otherwise returns None. This potentially triggers an IO operation to read the inCommitTimestamp. This is a lazy val, so repeated calls will not trigger multiple IO operations.

    Attributes
    protected
  48. def getProperties: Map[String, String]

    Return the set of properties of the table.

  49. def getSpecificFilesWithStats(paths: Seq[String]): Seq[AddFile]

    Get AddFile (with stats) actions corresponding to given set of paths in the Snapshot.

    Get AddFile (with stats) actions corresponding to given set of paths in the Snapshot. If a path doesn't exist in snapshot, it will be ignored and no AddFile will be returned for it.

    paths

    Sequence of paths for which we want to get AddFile action

    returns

    a sequence of addFiles for the given paths

    Definition Classes
    DataSkippingReaderBase
  50. final def getStatsColumnOpt(stat: StatsColumn): Option[Column]

    Overload for convenience working with StatsColumn helpers

    Overload for convenience working with StatsColumn helpers

    Attributes
    protected
    Definition Classes
    DataSkippingReaderBase
  51. final def getStatsColumnOpt(statType: String, pathToColumn: Seq[String] = Nil): Option[Column]

    Returns an expression to access the given statistics for a specific column, or None if that stats column does not exist.

    Returns an expression to access the given statistics for a specific column, or None if that stats column does not exist.

    statType

    One of the fields declared by object DeltaStatistics

    pathToColumn

    The components of the nested column name to get stats for.

    Attributes
    protected
    Definition Classes
    DataSkippingReaderBase
  52. final def getStatsColumnOrNullLiteral(stat: StatsColumn): Column

    Overload for convenience working with StatsColumn helpers

    Overload for convenience working with StatsColumn helpers

    Attributes
    protected[delta]
    Definition Classes
    DataSkippingReaderBase
  53. final def getStatsColumnOrNullLiteral(statType: String, pathToColumn: Seq[String] = Nil): Column

    Returns an expression to access the given statistics for a specific column, or a NULL literal expression if that column does not exist.

    Returns an expression to access the given statistics for a specific column, or a NULL literal expression if that column does not exist.

    Attributes
    protected[delta]
    Definition Classes
    DataSkippingReaderBase
  54. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  55. def init(): Unit

    Performs validations during initialization

    Performs validations during initialization

    Attributes
    protected
  56. def initialState(metadata: Metadata): SnapshotState

    Generate a default SnapshotState of a new table, given the table metadata

    Generate a default SnapshotState of a new table, given the table metadata

    Attributes
    protected
    Definition Classes
    SnapshotStateManager
  57. def initializeLogIfNecessary(isInterpreter: Boolean, silent: Boolean): Boolean
    Attributes
    protected
    Definition Classes
    Logging
  58. def initializeLogIfNecessary(isInterpreter: Boolean): Unit
    Attributes
    protected
    Definition Classes
    Logging
  59. def initializeTableCommitOwner(): Option[TableCommitOwnerClient]
    Attributes
    protected
  60. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  61. def isTraceEnabled(): Boolean
    Attributes
    protected
    Definition Classes
    Logging
  62. def loadActions: DataFrame

    Loads the file indices into a DataFrame that can be used for LogReplay.

    Loads the file indices into a DataFrame that can be used for LogReplay.

    In addition to the usual nested columns provided by the SingleAction schema, it should provide two additional columns to simplify the log replay process: COMMIT_VERSION_COLUMN (which, when sorted in ascending order, will order older actions before newer ones, as required by InMemoryLogReplay); and ADD_STATS_TO_USE_COL_NAME (to handle certain combinations of config settings for delta.checkpoint.writeStatsAsJson and delta.checkpoint.writeStatsAsStruct).

    Attributes
    protected
  63. def log: Logger
    Attributes
    protected
    Definition Classes
    Logging
  64. def logConsole(line: String): Unit
    Definition Classes
    DatabricksLogging
  65. def logDebug(msg: ⇒ String, throwable: Throwable): Unit
    Attributes
    protected
    Definition Classes
    Logging
  66. def logDebug(msg: ⇒ String): Unit
    Attributes
    protected
    Definition Classes
    Logging
  67. def logError(msg: ⇒ String, throwable: Throwable): Unit
    Definition Classes
    Snapshot → Logging
  68. def logError(msg: ⇒ String): Unit
    Definition Classes
    Snapshot → Logging
  69. def logInfo(msg: ⇒ String): Unit
    Definition Classes
    Snapshot → Logging
  70. def logInfo(msg: ⇒ String, throwable: Throwable): Unit
    Attributes
    protected
    Definition Classes
    Logging
  71. def logName: String
    Attributes
    protected
    Definition Classes
    Logging
  72. val logSegment: LogSegment
  73. def logTrace(msg: ⇒ String, throwable: Throwable): Unit
    Attributes
    protected
    Definition Classes
    Logging
  74. def logTrace(msg: ⇒ String): Unit
    Attributes
    protected
    Definition Classes
    Logging
  75. def logWarning(msg: ⇒ String, throwable: Throwable): Unit
    Definition Classes
    Snapshot → Logging
  76. def logWarning(msg: ⇒ String): Unit
    Definition Classes
    Snapshot → Logging
  77. def metadata: Metadata
  78. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  79. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  80. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  81. def numOfFiles: Long
    Definition Classes
    SnapshotStateManager
  82. def numOfFilesIfKnown: Option[Long]
    Attributes
    protected[delta]
    Definition Classes
    SnapshotStateManager
  83. def numOfMetadata: Long
    Definition Classes
    SnapshotStateManager
  84. def numOfProtocol: Long
    Definition Classes
    SnapshotStateManager
  85. def numOfRemoves: Long
    Definition Classes
    SnapshotStateManager
  86. def numOfSetTransactions: Long
    Definition Classes
    SnapshotStateManager
  87. def outputAttributeSchema: StructType

    The schema of the output attributes of the write queries that needs to collect statistics.

    The schema of the output attributes of the write queries that needs to collect statistics. The partition columns' definitions are not included in this schema.

    Definition Classes
    SnapshotStatisticsCollection
  88. def outputTableStatsSchema: StructType

    The output attributes (outputAttributeSchema) that are replaced with table schema with the physical mapping information.

    The output attributes (outputAttributeSchema) that are replaced with table schema with the physical mapping information. NOTE: The partition columns' definitions are not included in this schema.

    Definition Classes
    SnapshotStatisticsCollection
  89. val path: Path
    Definition Classes
    SnapshotDataSkippingReaderBase
  90. def protocol: Protocol
  91. def protocolMetadataAndICTReconstruction(): Array[ReconstructedProtocolMetadataAndICT]

    Pulls the protocol and metadata of the table from the files that are used to compute the Snapshot directly--without triggering a full state reconstruction.

    Pulls the protocol and metadata of the table from the files that are used to compute the Snapshot directly--without triggering a full state reconstruction. This is important, because state reconstruction depends on protocol and metadata for correctness. If the current table version does not have a checkpoint, this function will also return the in-commit-timestamp of the latest commit if available.

    Also this method should only access methods defined in UninitializedCheckpointProvider which are not present in CheckpointProvider. This is because initialization of Snapshot.checkpointProvider depends on Snapshot.protocolMetadataAndICTReconstruction() and so if Snapshot.protocolMetadataAndICTReconstruction() starts depending on Snapshot.checkpointProvider then there will be cyclic dependency.

    Attributes
    protected
  92. def pruneFilesByLimit(df: DataFrame, limit: Long): ScanAfterLimit
    Attributes
    protected[delta]
    Definition Classes
    DataSkippingReaderBase
  93. def recordDeltaEvent(deltaLog: DeltaLog, opType: String, tags: Map[TagDefinition, String] = Map.empty, data: AnyRef = null, path: Option[Path] = None): Unit

    Used to record the occurrence of a single event or report detailed, operation specific statistics.

    Used to record the occurrence of a single event or report detailed, operation specific statistics.

    path

    Used to log the path of the delta table when deltaLog is null.

    Attributes
    protected
    Definition Classes
    DeltaLogging
  94. def recordDeltaOperation[A](deltaLog: DeltaLog, opType: String, tags: Map[TagDefinition, String] = Map.empty)(thunk: ⇒ A): A

    Used to report the duration as well as the success or failure of an operation on a deltaLog.

    Used to report the duration as well as the success or failure of an operation on a deltaLog.

    Attributes
    protected
    Definition Classes
    DeltaLogging
  95. def recordDeltaOperationForTablePath[A](tablePath: String, opType: String, tags: Map[TagDefinition, String] = Map.empty)(thunk: ⇒ A): A

    Used to report the duration as well as the success or failure of an operation on a tahoePath.

    Used to report the duration as well as the success or failure of an operation on a tahoePath.

    Attributes
    protected
    Definition Classes
    DeltaLogging
  96. def recordEvent(metric: MetricDefinition, additionalTags: Map[TagDefinition, String] = Map.empty, blob: String = null, trimBlob: Boolean = true): Unit
    Definition Classes
    DatabricksLogging
  97. def recordFrameProfile[T](group: String, name: String)(thunk: ⇒ T): T
    Attributes
    protected
    Definition Classes
    DeltaLogging
  98. def recordOperation[S](opType: OpType, opTarget: String = null, extraTags: Map[TagDefinition, String], isSynchronous: Boolean = true, alwaysRecordStats: Boolean = false, allowAuthTags: Boolean = false, killJvmIfStuck: Boolean = false, outputMetric: MetricDefinition = METRIC_OPERATION_DURATION, silent: Boolean = true)(thunk: ⇒ S): S
    Definition Classes
    DatabricksLogging
  99. def recordProductEvent(metric: MetricDefinition with CentralizableMetric, additionalTags: Map[TagDefinition, String] = Map.empty, blob: String = null, trimBlob: Boolean = true): Unit
    Definition Classes
    DatabricksLogging
  100. def recordProductUsage(metric: MetricDefinition with CentralizableMetric, quantity: Double, additionalTags: Map[TagDefinition, String] = Map.empty, blob: String = null, forceSample: Boolean = false, trimBlob: Boolean = true, silent: Boolean = false): Unit
    Definition Classes
    DatabricksLogging
  101. def recordUsage(metric: MetricDefinition, quantity: Double, additionalTags: Map[TagDefinition, String] = Map.empty, blob: String = null, forceSample: Boolean = false, trimBlob: Boolean = true, silent: Boolean = false): Unit
    Definition Classes
    DatabricksLogging
  102. def redactedPath: String
    Definition Classes
    SnapshotDataSkippingReaderBase
  103. def schema: StructType
    Definition Classes
    SnapshotDescriptor
  104. def setTransactions: Seq[SetTransaction]
    Definition Classes
    SnapshotStateManager
  105. def setTransactionsIfKnown: Option[Seq[SetTransaction]]
    Attributes
    protected[delta]
    Definition Classes
    SnapshotStateManager
  106. def sizeInBytes: Long

    The following is a list of convenience methods for accessing the computedState.

    The following is a list of convenience methods for accessing the computedState.

    Definition Classes
    SnapshotStateManager
  107. def sizeInBytesIfKnown: Option[Long]
    Attributes
    protected[delta]
    Definition Classes
    SnapshotStateManager
  108. val snapshotToScan: Snapshot

    Snapshot to scan by the DeltaScanGenerator for metadata query optimizations

    Snapshot to scan by the DeltaScanGenerator for metadata query optimizations

    Definition Classes
    SnapshotDeltaScanGenerator
  109. def spark: SparkSession
    Attributes
    protected
    Definition Classes
    SnapshotStatisticsCollectionStateCache
  110. lazy val statCollectionLogicalSchema: StructType

    statCollectionLogicalSchema is the logical schema that is composed of all the columns that have the stats collected with our current table configuration.

    statCollectionLogicalSchema is the logical schema that is composed of all the columns that have the stats collected with our current table configuration.

    Definition Classes
    StatisticsCollection
  111. lazy val statCollectionPhysicalSchema: StructType

    statCollectionPhysicalSchema is the schema that is composed of all the columns that have the stats collected with our current table configuration.

    statCollectionPhysicalSchema is the schema that is composed of all the columns that have the stats collected with our current table configuration.

    Definition Classes
    StatisticsCollection
  112. def stateDF: DataFrame

    The current set of actions in this Snapshot as plain Rows

  113. def stateDS: Dataset[SingleAction]

    The current set of actions in this Snapshot as a typed Dataset.

  114. def stateReconstruction: Dataset[SingleAction]
    Attributes
    protected
  115. lazy val statsCollector: Column

    Returns a struct column that can be used to collect statistics for the current schema of the table.

    Returns a struct column that can be used to collect statistics for the current schema of the table. The types we keep stats on must be consistent with DataSkippingReader.SkippingEligibleLiteral. If a column is missing from dataSchema (which will be filled with nulls), we will only collect the NULL_COUNT stats for it as the number of rows.

    Definition Classes
    StatisticsCollection
  116. lazy val statsColumnSpec: DeltaStatsColumnSpec

    Number of columns to collect stats on for data skipping

    Number of columns to collect stats on for data skipping

    Definition Classes
    SnapshotStatisticsCollection
  117. lazy val statsSchema: StructType

    Returns schema of the statistics collected.

    Returns schema of the statistics collected.

    Definition Classes
    StatisticsCollection
  118. final def synchronized[T0](arg0: ⇒ T0): T0
    Definition Classes
    AnyRef
  119. val tableCommitOwnerClientOpt: Option[TableCommitOwnerClient]

    CommitOwnerClient for the given delta table as of this snapshot.

    CommitOwnerClient for the given delta table as of this snapshot. - This must be present when managed commit is enabled. - This must be None when managed commit is disabled.

  120. def tableSchema: StructType

    Returns the data schema of the table, used for reading stats

    Returns the data schema of the table, used for reading stats

    Definition Classes
    SnapshotStatisticsCollection
  121. def timestamp: Long

    Returns the timestamp of the latest commit of this snapshot.

    Returns the timestamp of the latest commit of this snapshot. For an uninitialized snapshot, this returns -1.

    When InCommitTimestampTableFeature is enabled, the timestamp is retrieved from the CommitInfo of the latest commit which can result in an IO operation.

  122. def toString(): String
    Definition Classes
    Snapshot → AnyRef → Any
  123. def tombstones: Dataset[RemoveFile]

    All unexpired tombstones.

  124. lazy val transactions: Map[String, Long]

    A map to look up transaction version by appId.

    A map to look up transaction version by appId.

    Definition Classes
    SnapshotStateManager
  125. def uncache(): Unit

    Drop any cached data for this Snapshot.

    Drop any cached data for this Snapshot.

    Definition Classes
    StateCache
  126. def updateStatsToWideBounds(withStats: DataFrame, statsColName: String): DataFrame

    Sets the TIGHT_BOUNDS column to false and converts the logical nullCount to a tri-state nullCount.

    Sets the TIGHT_BOUNDS column to false and converts the logical nullCount to a tri-state nullCount. The nullCount states are the following: 1) For "all-nulls" columns we set the physical nullCount which is equal to the physical numRecords. 2) "no-nulls" columns remain unchanged, i.e. zero nullCount is the same for both physical and logical representations. 3) For "some-nulls" columns, we leave the existing value. In files with wide bounds, the nullCount in SOME_NULLs columns is considered unknown.

    The file's state can transition back to tight when statistics are recomputed. In that case, TIGHT_BOUNDS is set back to true and nullCount back to the logical value.

    Note, this function gets as input parsed statistics and returns a json document similarly to allFiles. To further match the behavior of allFiles we always return a column named stats instead of statsColName.

    withStats

    A dataFrame of actions with parsed statistics.

    statsColName

    The name of the parsed statistics column.

    Definition Classes
    StatisticsCollection
  127. def verifyStatsForFilter(referencedStats: Set[StatsColumn]): Column

    Returns an expression that can be used to check that the required statistics are present for a given file.

    Returns an expression that can be used to check that the required statistics are present for a given file. If any required statistics are missing we must include the corresponding file.

    NOTE: We intentionally choose to disable skipping for any file if any required stat is missing, because doing it that way allows us to check each stat only once (rather than once per use). Checking per-use would anyway only help for tables where the number of indexed columns has changed over time, producing add.stats_parsed records with differing schemas. That should be a rare enough case to not worry about optimizing for, given that the fix requires more complex skipping predicates that would penalize the common case.

    Attributes
    protected
    Definition Classes
    DataSkippingReaderBase
  128. val version: Long
  129. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  130. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  131. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... ) @native()
  132. def withNoStats: DataFrame

    All files with the statistics column dropped completely.

    All files with the statistics column dropped completely.

    Definition Classes
    DataSkippingReaderBase
  133. final def withStats: DataFrame

    Returns a parsed and cached representation of files with statistics.

    Returns a parsed and cached representation of files with statistics.

    returns

    DataFrame

    Definition Classes
    DataSkippingReaderBase
  134. def withStatsDeduplicated: DataFrame
    Definition Classes
    DataSkippingReaderBase
  135. def withStatsInternal: DataFrame
    Attributes
    protected
    Definition Classes
    DataSkippingReaderBase
  136. def withStatusCode[T](statusCode: String, defaultMessage: String, data: Map[String, Any] = Map.empty)(body: ⇒ T): T

    Report a log to indicate some command is running.

    Report a log to indicate some command is running.

    Definition Classes
    DeltaProgressReporter

Inherited from DataSkippingReader

Inherited from DataSkippingReaderBase

Inherited from ReadsMetadataFields

Inherited from DeltaScanGenerator

Inherited from StatisticsCollection

Inherited from StateCache

Inherited from SnapshotStateManager

Inherited from DeltaLogging

Inherited from DatabricksLogging

Inherited from DeltaProgressReporter

Inherited from Logging

Inherited from SnapshotDescriptor

Inherited from AnyRef

Inherited from Any

Ungrouped