X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FRecordLinks.pm;h=da63872d4c62e8847568ebec9e4f4d15dd72e83b;hb=81fed28305f28aff317639f9a190cdf83a678ed4;hp=fa5de38f79c6eb7b328292e323a99c49514abdb0;hpb=451843cf750b655eb2678de12c369af74bca9867;p=kivitendo-erp.git diff --git a/SL/RecordLinks.pm b/SL/RecordLinks.pm index fa5de38f7..da63872d4 100644 --- a/SL/RecordLinks.pm +++ b/SL/RecordLinks.pm @@ -1,5 +1,8 @@ package RecordLinks; +use utf8; +use strict; + use SL::Common; use SL::DBUtils; use Data::Dumper; @@ -190,7 +193,7 @@ sub delete { add_token(\@where_tokens, \@where_values, col => $col, val => $params{$col}) if $params{$col}; } - my $where = "WHERE ". join ' AND ', map { "($_)" } @where_tokens if scalar @where_tokens; + my $where = @where_tokens ? "WHERE ". join ' AND ', map { "($_)" } @where_tokens : ''; my $query = "DELETE FROM record_links $where"; do_query($form, $dbh, $query, @where_values); @@ -201,3 +204,78 @@ sub delete { } 1; + +__END__ + +=head1 NAME + +SL::RecordLinks - Verlinkung von Lx-Office Objekten. + +=head1 SYNOPSIS + + use SL::RecordLinks; + + my @links = RecordLinks->get_links( + from_table => 'ar', + from_id => 2, + to_table => 'oe', + ); + my @links = RecordLinks->get_links_via( + from_table => 'oe', + to_id => '14', + via => [ + { id => 12 }, + { id => 13}, + ], + ); + + RecordLinks->create_links( + mode => 'ids', + from_table => 'ar', + from_id => 1, + to_table => 'oe', + to_ids => [4, 6, 9], + ) + RecordLinks->create_links(@links); + + delete + +=head1 DESCRIPTION + +Transitive RecordLinks mit get_links_via. + +get_links_via erwartet den zusätzlichen parameter via. via ist ein +hashref mit den jeweils optionalen Einträgen table und id, die sich +genauso verhalten wie die from/to_table/id werte der get_links funktion. + +Alternativ kann via auch ein Array dieser Hashes sein: + + get_links_via( + from_table => 'oe', + from_id => 1, + to_table => 'ar', + via => { + table => 'delivery_orders' + }, + ) + + get_links_via( + from_table => 'oe', + to_id => '14', + via => [ + { id => 12 }, + { id => 13}, + ], + ) + +Die Einträge in einem via-Array werden exakt in dieser Reihenfolge +benutzt und sind nicht optional. Da obige Beispiel würde also die +Verknüpfung: + + oe:11 -> ar:12 -> is:13 -> do:14 + +finden, nicht aber: + + oe:11 -> ar:13 -> do:14 + +=cut