Perl can read and process your input file (as can awk and several other tools) but it can also interact directly with an SQL database using the DBI module.
You could use perl to do something like this:
#!/usr/bin/perl
use strict;
use DBI;    # perl's SQL database module
# if the first argument is -n or --dry-run, then this is a dry-run:
my $dry_run = 0;
if ($ARGV[0] eq '-n' or $ARGV[0] eq '--dry-run') {
  $dry_run = 1;
  shift;
};
# Connect to the database. DBI can talk to sqlite, Mysql,
# Postgresql, Oracle, Microsoft SQL Server, and more.
#
# You didn't mention what database you'e using, OR info about the
# table schema, so I'm going to make the following assumptions:
#
# 1. sqlite, using a database file called solar.db
#
# 2. a single table called data with a field for the inverter
# name followed by fields for each of the ;-delimited values.
my $dbfile = './solar.db';
my $dbh = DBI->connect("dbi:SQLite:dbname=$dbfile","","");
# Assume that there are 35 fields data fields, including one for
# the inverter name. Construct a string with 34 ? characters
# separated by commas plus one final ? without a comma.
# By using `?` placeholders in the SQL command string, we don't
# need to worry about field data types or quoting, DBI handles all
# that auto-magically.
my $placeholders = '?,' x 34 . '?';
# Use that with the sql insert command.
my $sql = "INSERT INTO data VALUES($placeholders)";
# Prepare the statement handle ($sth) with this $sql string
# for later use in the main loop.
my $sth = $dbh->prepare($sql);
my $inverter; # variable to hold the name of the current inverter.
while(<<>>) {
  chomp; # strip end-of-line character(s), e.g. \n, \r\n, or \n\r
  # This assumes you only want the inverter id AFTER the colon.
  # adjust to suit if you need the whole line or some other
  # part of it.
  if (s/^#INV\d ESN://i) {
    $inverter = $_;
    next;
  };
  # skip all other input lines unless they start with a date. 
  next unless (m/^\d\d-\d\d-\d\d\d\d/);
  my @data = split /;/;   # split the input line on semi-colons
  # NOTE: the first field is a date, but it's in a terrible
  # format, MM-DD-YYYY or DD-MM-YYYY.  Most SQL databases prefer
  # YYYY-MM-DD format for date fields because it's the ISO
  # standard and it's unambiguous.  You may need to transform
  # the first field, `$data[0]`, to YYYY-MM-DD by un-commenting
  # one of the next two lines:
  #
  #$data[0] =~ s/^(\d\d)-(\d\d)-(\d\d\d\d)/$3-$2-$1/; # if DD-MM-YYYY
  #$data[0] =~ s/^(\d\d)-(\d\d)-(\d\d\d\d)/$3-$1-$2/; # if MM-DD-YYYY
  #
  # I just used a TEXT field for the date in my dummy database so
  # didn't need to.
  # Insert any other code here that you might need to modify
  # or transform the various fields in the @data array.
  if ($dry_run) {
    # DEBUG/dry-run, only print what it would do
    print 'INSERT INTO data VALUES(' . join(",", $inverter, @data) . ");\n";
  } else {
    # actually insert the data into the database.
    $sth->execute($inverter, @data);
  };
}
This script looks long, but more than two-thirds of the 90 lines are comments and blank lines.  According to sloccount, there's only 27 lines of actual perl code in there...most of which is "boilerplate".
I saved this as import-into-sqlite.pl, made it executable with chmod +x import-into-sqlite.pl, saved your sample data into a file called input.log, then ran the script like so:
$ ./import-into-sqlite.pl input.log
That ended up with the following data in my solar.db
$ sqlite3 solar.db 
SQLite version 3.46.1 2024-08-13 09:16:08
Enter ".help" for usage hints.
sqlite> select * from data;
ES22B0048634|08-12-2024 15:30:00|504.3|504.3|502.8|502.8|620.3|620.3|493.0|493.0|0.11|-0.04|0.13|-0.05|0.06|0.0|0.09|0.0|228.7|229.7|228.0|0.64|0.607|0.637|512.0|0.0|19.4|0.975|50.0|0.03|0.007|0.01|6.42|162.22|5.0
ES22B0048634|08-12-2024 15:25:00|506.5|506.5|500.2|500.2|631.5|631.5|460.9|460.9|0.1|-0.04|0.12|-0.06|0.04|0.0|0.09|0.0|228.7|229.7|228.0|0.552|0.541|0.563|512.0|0.0|19.6|0.994|49.99|0.026|0.003|0.0|6.41|162.21|5.0
ES22B0048591|08-12-2024 15:30:00|480.3|480.3|492.7|492.7|377.1|377.1|386.9|386.9|-0.07|0.13|0.02|0.05|-0.01|0.07|0.02|0.0|229.6|231.3|231.7|0.51|0.469|0.523|512.0|0.0|19.5|0.999|50.0|0.045|-0.002|0.01|6.65|164.65|5.0
ES22B0048591|08-12-2024 15:25:00|478.8|478.8|484.7|484.7|385.1|385.1|410.9|410.9|-0.07|0.12|0.02|0.04|-0.02|0.06|0.0|0.0|229.6|232.3|231.7|0.486|0.451|0.522|512.0|0.0|19.6|0.993|49.99|0.036|0.004|0.0|6.64|164.64|5.0
sqlite> 
For this, I created the following table in my dummy 'solar.db' database:
CREATE TABLE data (
    Inverter    TEXT,
    Time    TEXT,
    Upv1    REAL,
    Upv2    REAL,
    Upv3    REAL,
    Upv4    REAL,
    Upv5    REAL,
    Upv6    REAL,
    Upv7    REAL,
    Upv8    REAL,
    Ipv1    REAL,
    Ipv2    REAL,
    Ipv3    REAL,
    Ipv4    REAL,
    Ipv5    REAL,
    Ipv6    REAL,
    Ipv7    REAL,
    Ipv8    REAL,
    Uac1    REAL,
    Uac2    REAL,
    Uac3    REAL,
    Iac1    REAL,
    Iac2    REAL,
    Iac3    REAL,
    Status  REAL,
    Error   REAL,
    Temp    REAL,
    cos REAL,
    fac REAL,
    Pac REAL,
    Qac REAL,
    Eac REAL,
    E_Day   REAL,
    E_Total REAL,
    Cycle_Time  REAL
);
I wasn't too concerned about getting the field data types exactly right, I just wanted something I could insert data into without error.  The Time field should probably be some kind of date / datetime type in most SQL databases, and the Cycle_Time field should maybe be INTEGER rather than REAL.
NOTE:  DBI is NOT installed as standard with perl, so you'll need to install it along with the DBD driver for the SQL database you're using.  The process of installing these modules depends on what kind of unix you're using, or which linux distribution.  Most Linux distros have packages for DBI and the various DBD modules. Otherwise, you can install them directly from CPAN.
For example, to install DBI and the DBD::SQLite3 modules on Debian:
sudo apt-get install libdbi-perl libdbd-sqlite3-perl 
Debian also has DBD module packages for several other databases, and even for working with CSV and Excel files as if they were SQL databases.  Most linux distributions will have a similar set of packages:
$ apt-cache search -n libdbd perl
libdbd-cassandra-perl - Perl DBI database backend for Cassandra
libdbd-csv-perl - DBI driver for CSV files
libdbd-excel-perl - SQL interface (via DBI) for accessing Excel files
libdbd-firebird-perl - Perl DBI driver for Firebird RDBMS server
libdbd-ldap-perl - Perl extension for LDAP access via an SQL/Perl DBI interface
libdbd-mariadb-perl - Perl5 database interface to the MariaDB/MySQL databases
libdbd-mock-perl - Mock database driver for testing
libdbd-multi-perl - failover and load balancing of DBI handles
libdbd-mysql-perl - Perl5 database interface to the MariaDB/MySQL database
libdbd-odbc-perl - Perl Database Driver implementing ODBC for DBI
libdbd-pg-perl - Perl DBI driver for the PostgreSQL database server
libdbd-sqlite3-perl - Perl DBI driver with a self-contained RDBMS
libdbd-sybase-perl - Sybase/MS SQL database driver for the DBI module
libdbd-xbase-perl - Perl module to access xbase files (optionally through DBI)
libdbd-oracle-perl - Perl DBI driver for Oracle