Skip to content
Snippets Groups Projects
FeatureDbXRef.xml 2.7 KiB
Newer Older
  • Learn to ignore specific revisions
  • tjc's avatar
    tjc committed
    <?xml version="1.0" encoding="UTF-8" ?> 
     
    <!DOCTYPE sqlMap 
        PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN" 
        "http://ibatis.apache.org/dtd/sql-map-2.dtd"> 
     
    
    <sqlMap namespace="FeatureDbXRef"> 
     
      <typeAlias alias="FeatureDbXRef"
            type="org.gmod.schema.sequence.FeatureDbXRef"/>
            
      <resultMap id="select-feature-dbxref" 
                   class="FeatureDbXRef">
        <result property="feature.featureId"  column="feature_id"/>
        <result property="dbXRef.db.name"     column="name"/>
        <result property="dbXRef.accession"   column="accession"/>
        <result property="dbXRef.version"     column="version"/>
        <result property="dbXRef.description" column="description"/>
        <result property="current"            column="is_current"/>
      </resultMap>
      
    
      <select id="getFeatureDbXRef" 
              parameterClass="org.gmod.schema.sequence.Feature"
              resultMap="select-feature-dbxref">
       	SELECT db.name, dbx.accession, dbx.version, dbx.description,
       	       dbx_f.feature_id, dbx_f.is_current
     	FROM feature_dbxref dbx_f 
            LEFT JOIN dbxref dbx ON dbx.dbxref_id=dbx_f.dbxref_id
            LEFT JOIN db ON db.db_id=dbx.db_id 
            LEFT JOIN feature f ON dbx_f.feature_id=f.feature_id
            <isNotNull property="uniqueName"> 
              WHERE f.uniquename=#uniqueName#
            </isNotNull>
            <isGreaterThan property="featureId" compareValue="0">
              WHERE dbx_f.feature_id=$featureId$
            </isGreaterThan>
            ORDER BY f.type_id,  uniquename
    
    tjc's avatar
    tjc committed
      </select>
    	
    
      <select id="getFeatureDbXRefsBySrcFeatureId" 
              parameterClass="java.lang.Integer"
              resultMap="select-feature-dbxref">
       	SELECT db.name, dbx.accession, dbx.version, dbx.description,
       	       dbx_f.feature_id, dbx_f.is_current
     	FROM feature_dbxref dbx_f 
        LEFT JOIN dbxref dbx ON dbx.dbxref_id=dbx_f.dbxref_id
        LEFT JOIN db ON db.db_id=dbx.db_id 
        LEFT JOIN feature f ON dbx_f.feature_id=f.feature_id
    	WHERE dbx_f.feature_id IN (SELECT feature_id FROM featureloc WHERE srcfeature_id=$value$)
        ORDER BY f.type_id,  uniquename
      </select>
    
    tjc's avatar
    tjc committed
      
      <!-- WRITE BACK -->
      <delete id="deleteFeatureDbXRef" parameterClass="FeatureDbXRef">
         DELETE FROM feature_dbxref 
         WHERE dbxref_id=
               (SELECT dbxref_id FROM dbxref WHERE accession=#dbXRef.accession#
                AND db_id=(SELECT db_id FROM db WHERE name=#dbXRef.db.name#))
         AND feature_id=
               (SELECT feature_id FROM feature WHERE uniquename=#feature.uniqueName#)
      </delete>
      
      <insert id="insertFeatureDbXRef" parameterClass="FeatureDbXRef">
        INSERT INTO feature_dbxref 
               (feature_id, dbxref_id, is_current)
               VALUES
               ($feature.featureId$, $dbXRef.dbXRefId$, $current$)
      </insert>
            
    </sqlMap>