DBIx::Custom::Mapper

作者: JSON_NULL | 来源:发表于2017-12-07 11:12 被阅读8次

    简介

    DBIx::Custom::Mapper模块是DBIx::Custom框架的参数映射器。

    my $mapper = $dbi->mapper(param => $param);
    my $new_param = $mapper->map(
      title => 'book.title', # Key
      author => sub { '%' . $_[0] . '%'} # Value
      price => ['book.price' => sub { '%' . $_[0] . '%' }], # Key and value
    );
    

    属性

    param

    my $param = $mapper->param;
    $mapper = $mapper->param({title => 'Perl', author => 'Ken'});
    

    参数。在执行map方法时,会对这个属性进行映射得到新的new_param并返回。

    pass

    my $pass = $mapper->pass;
    $mapper = $mapper->pass([qw/title author/]);
    

    在执行map方法时,凡是在pass属性中设置的名称,其键与值都会直接复制到结果中,不会做任何改变。

    codition

    my $condition = $mapper->condition;
    $mapper = $mapper->condition('exists');
    

    映射条件,默认为length。

    在执行map的过程中,只有满足codition条件的value才会被放入到结果中。

    你可以将以下值设置为codition:

    exists

    condition => 'exists'
    

    如果key存在,则对key和value进行映射。

    defined

    condition => 'defined';
    

    如果定义了值,则对key和value进行映射。

    length

    condition => 'length';
    

    如果值被定义并且长度不为0,则对key和value进行映射。

    code reference

    condition => sub { defined $_[0] }
    

    你可以把condition的值设置为coderef类型的值。当子程序返回true时,对key和value进行映射。

    方法

    DBIx::Custom::Mapper 模块继承了Object::Simple中的所有方法,并实现了以下方法。

    map

    my $new_param = $mapper->map(
      price => {key => 'book.price'}
      title => {value => '%<value>%'}
      author => ['book.author' => '%<value>%']
    );
    
    my $new_param = $mapper->map(
      price => {key => 'book.price'}
      title => {value => sub { '%' . shift . '%'}}
      author => ['book.author' => sub { '%' . shift . '%'}]
    );
    

    对属性param进行映射,得到新的new_param。

    例如,如果param设置为

    {
      price => 1900,
      title => 'Perl',
      author => 'Ken',
      issue_date => '2010-11-11'
    }
    

    下面的哈希引用被返回。

    {
      'book.price' => 1900,
      title => '%Perl%',
      'book.author' => '%Ken%',
    }
    

    默认情况下,如果值存在且长度不为0,则映射到结果中。

    title => 'Perl'  # Mapped
    {title => '' }   # Not mapped
    {title => undef} # Not mapped
    {}               # Not mapped
    

    你可以设置condition属性,来改变映射条件。

     $mapper->condition('defined');
    

    你也可以为每个key单独指定映射条件:

     my $new_param = $mapper->map(
       price => {key => 'book.price', condition => 'defined'}]
       title => {value => sub { '%' . $_[0] . '%'}, condition => 'defined'}
       author => ['book.author', sub { '%' . $_[0] . '%'}, 'exists']
     );
    

    如果在pass属性中设置了一些key,则这些key对应的key和value会被原样复制到结果中。

    $mapper->pass([qw/title author/]);
    my $new_param = $mapper->map(price => {key => 'book.price'});
    

    如上代码会把下面的param

    {title => 'Perl', author => 'Ken', price => 1900}
    

    映射到下面这个结果

    {title => 'Perl', author => 'Ken', 'book.price' => 1900}
    

    map方法中参数的语法

    map方法接收一个hash作为参数。hash的键名需要与param中的键名对应,而键值的类型为hashref或arrayref,用来指定具体的映射规则。

    当键值为hashref时

    # String => Hash reference
    price => {key => 'book.price'}
    title => {value => '%<value>%'}
    title => {value => sub { '%' . shift . '%'}}
    

    如果在hashref中使用了key,则只对param中的key做映射。

    # Rule
    price => {key => 'book.price'}
    # Parameter
    price => 1900,
    # New parameter
    'book.price' => 1900,
    

    如果在hashref中使用了value,则只对param中的value做映射。

    # Rule
    title => {value => '%<value>%'}
    title => {value => sub { '%' . shift . '%'}}
    
    # Parameter
    title => 'Perl',
    # New parameter
    title => '%Perl%',
    

    <value>会被替换为param中的键值,您也可以使用代码引用对原始做转换。

    当键值为arrayref时

    # String => Array reference
    author => ['book.author' => '%<value>%']
    

    这种情况下,键名和键值都会被映射,其结果与键值为hashref时的如下使用方式相同。

    # Rule
    {key => 'book.author', value => '%<value>%'}
    

    相关文章

      网友评论

        本文标题:DBIx::Custom::Mapper

        本文链接:https://www.haomeiwen.com/subject/osqdixtx.html