Мой тестовый сценарий просто устанавливает соединение perl dbi с базой данных mysql и, учитывая список таблиц, извлекает (1) запись для каждой таблицы.
Для каждой таблицы, которую я перечисляю, я также хочу распечатать эту (1) запись в отдельный файл. Например, если у меня есть список из 100 таблиц, я должен ожидать 100 уникальных файлов с (1) записью в каждом.
Пока код работает, но я заинтересован в создании подпрограммы, назовите ее create_file для частей кода, которые обрабатывают это #Create file
Я не знаком с написанием подпрограмм, и мне нужна помощь в реализации этого, если это возможно. Я не уверен, как бы я назвал часть, в которой строятся данные. $data='';
Может ли кто-нибудь показать мне хороший способ сделать это? Спасибо за вашу помощь.
код:
# Get list of tables
my @tblist = qx(mysql -u foo-bar -ppassw0rd --database $dbsrc -h $node --port 3306 -ss -e "show tables");
# Data output
foreach my $tblist (@tblist)
{
my $data = '';
chomp $tblist;
#Create file
my $out_file = "/home/$node-$tblist.$dt.dat";
open (my $out_fh, '>', $out_file) or die "cannot create $out_file: $!";
my $dbh = DBI->connect("DBI:mysql:database=$dbsrc;host=$node;port=3306",'foo-bar','passw0rd');
my $sth = $dbh->prepare("SELECT UUID(), '$node', ab, cd, ef, gh, hi FROM $tblist limit 1");
$sth->execute();
while (my($id, $nd,$ab,$cd,$ef,$gh,$hi) = $sth->fetchrow_array() ) {
$data = $data. "__pk__^A$id^E1^A$nd^E2^A$ab^E3^A$cd^E4^A$ef^E5^A$gh^E6^A$hi^E7^D";
}
$sth->finish;
$dbh->disconnect;
#Create file
print $out_fh $data;
close $out_fh or die "Failed to close file: $!";
};