#!/usr/bin/perl use warnings; use strict; use feature qw{ say }; use experimental qw{ signatures }; use DBI; sub run_do($dbh, $id, $name) { $dbh->do(qq{ INSERT INTO customers (id,name) VALUES('$id','$name')}); } sub run_select($dbh) { my $sth = $dbh->prepare('SELECT * FROM customers'); $sth->execute; while (my @row = $sth->fetchrow_array) { say "@row"; } } my %connection = ('dbi:SQLite:dbname=:memory:' => ["", ""], "dbi:Pg:dbname=$ENV{USER}" => [$ENV{USER}, ""]); for my $dbcs (keys %connection) { my $dbh = 'DBI'->connect($dbcs, @{ $connection{$dbcs} }); $dbh->do('CREATE TABLE customers (id INTEGER, name TEXT)'); run_do($dbh, 1, 'John'); run_select($dbh); my $id = q{42', 'Batman'); DROP TABLE customers; -- }; run_do($dbh, $id, 'Joe'); run_select($dbh); }