NAME
Bio::Chado::Schema::Result::Stock::Stock
DESCRIPTION
Any stock can be globally identified by the combination of organism, uniquename and stock type. A stock is the physical entities, either living or preserved, held by collections. Stocks belong to a collection; they have IDs, type, organism, description and may have a genotype.
ACCESSORS
stock_id
data_type: 'integer'
is_auto_increment: 1
is_nullable: 0
sequence: 'stock_stock_id_seq'
dbxref_id
data_type: 'integer'
is_foreign_key: 1
is_nullable: 1
The dbxref_id is an optional primary stable identifier for this stock. Secondary indentifiers and external dbxrefs go in table: stock_dbxref.
organism_id
data_type: 'integer'
is_foreign_key: 1
is_nullable: 1
The organism_id is the organism to which the stock belongs. This column should only be left blank if the organism cannot be determined.
name
data_type: 'varchar'
is_nullable: 1
size: 255
The name is a human-readable local name for a stock.
uniquename
data_type: 'text'
is_nullable: 0
description
data_type: 'text'
is_nullable: 1
The description is the genetic description provided in the stock list.
type_id
data_type: 'integer'
is_foreign_key: 1
is_nullable: 0
The type_id foreign key links to a controlled vocabulary of stock types. The would include living stock, genomic DNA, preserved specimen. Secondary cvterms for stocks would go in stock_cvterm.
is_obsolete
data_type: 'boolean'
default_value: false
is_nullable: 0
RELATIONS
nd_experiment_stocks
Type: has_many
Related object: Bio::Chado::Schema::Result::NaturalDiversity::NdExperimentStock
dbxref
Type: belongs_to
Related object: Bio::Chado::Schema::Result::General::Dbxref
type
Type: belongs_to
Related object: Bio::Chado::Schema::Result::Cv::Cvterm
organism
Type: belongs_to
Related object: Bio::Chado::Schema::Result::Organism::Organism
stockcollection_stocks
Type: has_many
Related object: Bio::Chado::Schema::Result::Stock::StockcollectionStock
stock_cvterms
Type: has_many
Related object: Bio::Chado::Schema::Result::Stock::StockCvterm
stock_dbxrefs
Type: has_many
Related object: Bio::Chado::Schema::Result::Stock::StockDbxref
stock_genotypes
Type: has_many
Related object: Bio::Chado::Schema::Result::Stock::StockGenotype
stockprops
Type: has_many
Related object: Bio::Chado::Schema::Result::Stock::Stockprop
stock_pubs
Type: has_many
Related object: Bio::Chado::Schema::Result::Stock::StockPub
stock_relationship_subjects
Type: has_many
Related object: Bio::Chado::Schema::Result::Stock::StockRelationship
stock_relationship_objects
Type: has_many
Related object: Bio::Chado::Schema::Result::Stock::StockRelationship
create_stockprops
Usage: $set->create_stockprops({ baz => 2, foo => 'bar' });
Desc : convenience method to create stock properties using cvterms
        from the ontology with the given name
Args : hashref of { propname => value, ...},
       options hashref as:
        {
          autocreate => 0,
             (optional) boolean, if passed, automatically create cv,
             cvterm, and dbxref rows if one cannot be found for the
             given stockprop name.  Default false.
          cv_name => cv.name to use for the given stockprops.
                     Defaults to 'stock_property',
          db_name => db.name to use for autocreated dbxrefs,
                     default 'null',
          dbxref_accession_prefix => optional, default
                                     'autocreated:',
          definitions => optional hashref of:
              { cvterm_name => definition,
              }
           to load into the cvterm table when autocreating cvterms
           rank => force numeric rank. Be careful not to pass ranks that already exist
                   for the property type. The function will die in such case.
           allow_duplicate_values => default false.
              If true, allow duplicate instances of the same stock
              and value in the properties of the stock.  Duplicate
              values will have different ranks.
        }
Ret  : hashref of { propname => new stockprop object }
ADDITIONAL METHODS
stock_phenotypes_rs
Usage: $schema->resultset("Stock::Stock")->stock_phenotypes_rs($stock_rs);
Desc:  retrieve a resultset for stock(s) with phenotyping experiments with the following values mapped to [column name]
       stock_id [stock_id]
       phenotype.value [value]
       observable.name [observable] (the cvterm name for the phenotype.observable field)
       observable_cvterm_id [observable_id]
       observable.definition [definition]
       unit_name (from phenotype_cvterm)
       cv_name (the cv_name for the phenotype_cvterm)
       type_name (the cvterm name for the phenotype_cvterm)
       method_name (a phenotypeprop value)
       dbxref.accession [accession] of the observable cvterm
       db.name of the observable cvterm [db_name] (useful for constructing the ontology ID of the observable)
       project.description [project_description] (useful for grouping phenotype values by projects)
Args:  a L<Bio::Chado::Schema::Result::Stock::Stock>  resultset
Ret:   a resultset with the above columns. Access the data with e.g. $rs->get_column('stock_id')
recursive_phenotypes_rs
Usage: $schema->resultset("Stock::Stock")->recursive_phenotypes_rs($stock_rs, \@results)
Desc: Retrieve recursively phenotypes of stock objects and their subjects
Args: Stock resultSet and an arrayref with the results
Ret: listref of stock_phenotypes_rs (see function stock_phenotypes_rs for columns fetched)
stock_genotypes_rs
Usage: $schema->resultset("Stock::Stock")->stock_genotypes_rs($stock_rs);
Desc:  retrieve a resultset for stock(s) with genotyping experiments
       with the following values mapped to [column name]
       stock_id [stock_id]
       genotype.name [name]
       genotype.uniquname [uniquename]
       genotype.description [description]
       genotype.type.name [type_name] (the cvterm name for the genotype type)
       propvalue [propvalue] (a genotypeprop value)
Args:  a L<Bio::Chado::Schema::Result::Stock::Stock> resultset
Ret:   a resultset with the above columns. Access the data with e.g. $rs->get_column('stock_id')
stock_project_phenotypes
Usage: $schema->resultset("Stock::Stock")->stock_project_phenotypes($stock_rs);
Desc:  retrieve a list of phenotype resultsets by project name
Args:  a L<Bio::Chado::Schema::Result::Stock::Stock> object or a stock resultset
Ret:   hashref key = project descriptions, values = hash ref of
       {phenotypes} = phenotype resultset
       {project}   =  L<Bio::Chado::Schema::Result::Project::Project> object