[![Actions Status](https://github.com/karupanerura/MySQL-Dump-Parser-XS/workflows/test/badge.svg)](https://github.com/karupanerura/MySQL-Dump-Parser-XS/actions)
# NAME

MySQL::Dump::Parser::XS - mysqldump SQL parser

# SYNOPSIS

    use MySQL::Dump::Parser::XS;

    open my $fh, '<:encoding(utf-8)', 'backup.sql' or die $!;

    my %rows;
    my $parser = MySQL::Dump::Parser::XS->new;
    while (my $line = <$fh>) {
        my @rows  = $parser->parse($line);
        my $table = $parser->current_target_table();
        push @{ $rows{$table} } => @rows if $table;
    }

    for my $table ($parser->tables()) {
        my @columns = $parser->columns($table);
        my $row     = $rows{$table};
        print "[$table] id:$row->{id}\n";
    }

# DESCRIPTION

MySQL::Dump::Parser::XS is `mysqldump` parser written in C/XS.
This module provides schema/data loader from `mysqldump` output SQL directly. No need `mysqld`.

# METHODS

## CLASS METHODS

### `new()`

Creates a new parser instance.
This manages parsing states and table's meta information in the parsing context.

## INSTANCE METHODS

### `reset()`

Re-initialize parsing context.

### `parse($line)`

Parse a line of `mysqldump` output.

### `current_target_table()`

Get current target table name in the parsing context.

### `columns($table_name)`

Get column names as LIST for the table of `$table_name`.
This method can get columns from already parsed tables only.

### `tables()`

Get table names as LIST.
This method can get tables from already parsed tables only.

# FAQ

### How to get column details?

Some `mysqldump` output include poor table schema information only.
So if you just need rich table schema information, I suggest using [DBIx::Inspector](https://metacpan.org/pod/DBIx::Inspector) to solve the problem.

# LICENSE

Copyright (C) karupanerura.

This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.

# AUTHOR

karupanerura <karupa@cpan.org>