Anonymous | Login | Signup for a new account | 12-17-2024 10:30 PST |
Main | My View | View Issues | Change Log | Docs |
Viewing Issue Advanced Details [ Jump to Notes ] | [ View Simple ] [ Issue History ] [ Print ] | ||||||||
ID | Category | Severity | Reproducibility | Date Submitted | Last Update | ||||
0001003 | [Resin] | major | always | 03-20-06 16:12 | 04-04-06 16:20 | ||||
Reporter | nquery | View Status | public | ||||||
Assigned To | ferg | ||||||||
Priority | normal | Resolution | fixed | Platform | |||||
Status | closed | OS | |||||||
Projection | none | OS Version | |||||||
ETA | none | Fixed in Version | 3.0.19 | Product Version | 3.0.18 | ||||
Product Build | |||||||||
Summary | 0001003: findByPrimaryKey with cached data | ||||||||
Description |
If I do a findByPrimaryKey on a bean that has been previously cached by resin and the cache period has expired, then resin will not actually do a re-load/select or check to see if it exists anymore until one of it's fields is accessed. It is only when something is done with one of it's fields or via cmr that an amber/ejb exception is thrown if the object has been removed from the db. Thus, the findByPrimaryKey method itself does not generate an ObjectNotFoundException if the object no longer exists and if the bean has been previously cached - but it will if it's the first time the key has been asked for and it's not cached. I am assuming that this is a bug ... or is this intended behaviour? eg. see attached .ejb file try { symbol = symbolHome.findByPrimaryKey(symbolId); } catch (FinderException e) { // if the object doesn't exist in the db then an objectnotfoundexception is only thrown *if* the bean specified by the key has not been cached previously by resin, *even if* the cache period has expired } String name = symbol.getLongName(); // if the symbol object no longer exists in the db and the cache period has expired, then this will cause an AmberObjectNotFoundException .... it's obviously incorrect for the findByPrimaryKey to not throw an exception if the object does not exist after the cache period has expired ... i need to be able to trap this. cheers christian |
||||||||
Steps To Reproduce | |||||||||
Additional Information |
<entity> <ejb-name>symbols</ejb-name> <local-home>com.quotemedia.lookup.ejb.SymbolHome</local-home> <local>com.quotemedia.lookup.ejb.Symbol</local> <ejb-class>com.quotemedia.lookup.ejb.SymbolBean</ejb-class> <persistence-type>Container</persistence-type> <reentrant>True</reentrant> <cache-size>300000</cache-size> <cache-timeout>5m</cache-timeout> <abstract-schema-name>symbol</abstract-schema-name> <sql-table>symbol</sql-table> <primkey-field>symbolId</primkey-field> <prim-key-class>java.lang.Long</prim-key-class> <cmp-field> <field-name>symbol</field-name> <sql-column>symbol</sql-column> </cmp-field> <cmp-field> <field-name>symbolId</field-name> <sql-column>symbolid</sql-column> </cmp-field> <cmp-field> <field-name>exchangeCode</field-name> <sql-column>excode</sql-column> </cmp-field> <cmp-field> <field-name>longName</field-name> <sql-column>name</sql-column> </cmp-field> <cmp-field> <field-name>shortName</field-name> <sql-column>shortname</sql-column> </cmp-field> <cmp-field> <field-name>marketId</field-name> <sql-column>marketid</sql-column> </cmp-field> <cmp-field> <field-name>expireDate</field-name> <sql-column>expire</sql-column> </cmp-field> <query> <query-method> <method-name>findAll</method-name> </query-method> <ejb-ql>SELECT object(s) from symbol s</ejb-ql> </query> <query> <query-method> <method-name>findBySymbol</method-name> </query-method> <ejb-ql>SELECT object(s) from symbol s where s.symbol=?1 and (s.expireDate is null or s.expireDate >= ?2)</ejb-ql> </query> <query> <query-method> <method-name>findByExchangeGroup</method-name> <method-params> <method-param>java.lang.String</method-param> <method-param>java.util.Date</method-param> <method-param>int</method-param> <method-param>int</method-param> </method-params> </query-method> <ejb-ql>SELECT object(s) from symbol s where s.exchange.exchangeGroup=?1 and (s.expireDate is null or s.expireDate >= ?2) order by s.symbol offset ?3 limit ?4</ejb-ql> </query> <query> <query-method> <method-name>findByExchangeGroup</method-name> <method-params> <method-param>java.lang.String</method-param> <method-param>java.util.Date</method-param> </method-params> </query-method> <ejb-ql>SELECT object(s) from symbol s where s.exchange.exchangeGroup=?1 and (s.expireDate is null or s.expireDate >= ?2) order by s.symbol</ejb-ql> </query> <query> <query-method> <method-name>ejbSelectOptionsInEntity</method-name> </query-method> <ejb-ql>SELECT OBJECT(o) FROM chain o WHERE o.rootSymbol.symbolId=?1 ORDER BY o.seq</ejb-ql> </query> </entity> |
||||||||
Attached Files | |||||||||
|
Mantis 1.0.0rc3[^]
Copyright © 2000 - 2005 Mantis Group
29 total queries executed. 26 unique queries executed. |