001// --------------------------------------------------------------------------------
002// Copyright 2002-2026 Echo Three, LLC
003//
004// Licensed under the Apache License, Version 2.0 (the "License");
005// you may not use this file except in compliance with the License.
006// You may obtain a copy of the License at
007//
008//     http://www.apache.org/licenses/LICENSE-2.0
009//
010// Unless required by applicable law or agreed to in writing, software
011// distributed under the License is distributed on an "AS IS" BASIS,
012// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013// See the License for the specific language governing permissions and
014// limitations under the License.
015// --------------------------------------------------------------------------------
016// Generated File -- DO NOT EDIT BY HAND
017// --------------------------------------------------------------------------------
018
019/**
020 * ShippingMethodDetailFactory.java
021 */
022
023package com.echothree.model.data.shipping.server.factory;
024
025import com.echothree.model.data.shipping.common.pk.ShippingMethodPK;
026import com.echothree.model.data.selector.common.pk.SelectorPK;
027
028import com.echothree.model.data.shipping.server.entity.ShippingMethod;
029import com.echothree.model.data.selector.server.entity.Selector;
030
031import com.echothree.model.data.shipping.common.ShippingMethodDetailConstants;
032import com.echothree.model.data.shipping.common.pk.ShippingMethodDetailPK;
033import com.echothree.model.data.shipping.server.value.ShippingMethodDetailValue;
034import com.echothree.model.data.shipping.server.entity.ShippingMethodDetail;
035import com.echothree.util.common.exception.PersistenceDatabaseException;
036import com.echothree.util.common.exception.PersistenceDatabaseUpdateException;
037import com.echothree.util.common.exception.PersistenceNotNullException;
038import com.echothree.util.server.persistence.BaseFactory;
039import com.echothree.util.server.persistence.EntityIdGenerator;
040import com.echothree.util.server.persistence.EntityPermission;
041import com.echothree.util.server.persistence.PersistenceDebugFlags;
042import com.echothree.util.server.persistence.Session;
043import java.sql.PreparedStatement;
044import java.sql.ResultSet;
045import java.sql.SQLException;
046import java.sql.Types;
047import java.io.ByteArrayInputStream;
048import java.io.StringReader;
049import java.util.ArrayList;
050import java.util.Collection;
051import java.util.HashSet;
052import java.util.List;
053import java.util.Map;
054import java.util.Set;
055import javax.enterprise.context.ApplicationScoped;
056import javax.enterprise.inject.spi.CDI;
057import javax.inject.Inject;
058import org.slf4j.Logger;
059import org.slf4j.LoggerFactory;
060
061@ApplicationScoped
062public class ShippingMethodDetailFactory
063        implements BaseFactory<ShippingMethodDetailPK, ShippingMethodDetail> {
064    
065    @Inject
066    Session session;
067    
068    //private static final Logger log = LoggerFactory.getLogger(ShippingMethodDetailFactory.class);
069    
070    final private static String SQL_SELECT_READ_ONLY = "SELECT shmdt_shippingmethoddetailid, shmdt_shm_shippingmethodid, shmdt_shippingmethodname, shmdt_geocodeselectorid, shmdt_itemselectorid, shmdt_sortorder, shmdt_fromtime, shmdt_thrutime FROM shippingmethoddetails WHERE shmdt_shippingmethoddetailid = ?";
071    final private static String SQL_SELECT_READ_WRITE = "SELECT shmdt_shippingmethoddetailid, shmdt_shm_shippingmethodid, shmdt_shippingmethodname, shmdt_geocodeselectorid, shmdt_itemselectorid, shmdt_sortorder, shmdt_fromtime, shmdt_thrutime FROM shippingmethoddetails WHERE shmdt_shippingmethoddetailid = ? FOR UPDATE";
072    final private static String SQL_INSERT = "INSERT INTO shippingmethoddetails (shmdt_shippingmethoddetailid, shmdt_shm_shippingmethodid, shmdt_shippingmethodname, shmdt_geocodeselectorid, shmdt_itemselectorid, shmdt_sortorder, shmdt_fromtime, shmdt_thrutime) VALUES (?, ?, ?, ?, ?, ?, ?, ?)";
073    final private static String SQL_UPDATE = "UPDATE shippingmethoddetails SET shmdt_shm_shippingmethodid = ?, shmdt_shippingmethodname = ?, shmdt_geocodeselectorid = ?, shmdt_itemselectorid = ?, shmdt_sortorder = ?, shmdt_fromtime = ?, shmdt_thrutime = ? WHERE shmdt_shippingmethoddetailid = ?";
074    final private static String SQL_DELETE = "DELETE FROM shippingmethoddetails WHERE shmdt_shippingmethoddetailid = ?";
075    final private static String SQL_VALID = "SELECT COUNT(*) FROM shippingmethoddetails WHERE shmdt_shippingmethoddetailid = ?";
076    
077    final private static String PK_COLUMN = "shmdt_shippingmethoddetailid";
078    final private static String ALL_COLUMNS = "shmdt_shippingmethoddetailid, shmdt_shm_shippingmethodid, shmdt_shippingmethodname, shmdt_geocodeselectorid, shmdt_itemselectorid, shmdt_sortorder, shmdt_fromtime, shmdt_thrutime";
079    final public static String TABLE_NAME = "shippingmethoddetails";
080    
081    final public static String SHMDT_SHIPPINGMETHODDETAILID = "shmdt_shippingmethoddetailid";
082    final public static String SHMDT_SHM_SHIPPINGMETHODID = "shmdt_shm_shippingmethodid";
083    final public static String SHMDT_SHIPPINGMETHODNAME = "shmdt_shippingmethodname";
084    final public static String SHMDT_GEOCODESELECTORID = "shmdt_geocodeselectorid";
085    final public static String SHMDT_ITEMSELECTORID = "shmdt_itemselectorid";
086    final public static String SHMDT_SORTORDER = "shmdt_sortorder";
087    final public static String SHMDT_FROMTIME = "shmdt_fromtime";
088    final public static String SHMDT_THRUTIME = "shmdt_thrutime";
089    
090    final private static EntityIdGenerator entityIdGenerator = new EntityIdGenerator(ShippingMethodDetailConstants.COMPONENT_VENDOR_NAME, ShippingMethodDetailConstants.ENTITY_TYPE_NAME);
091    
092    /** Creates a new instance of ShippingMethodDetailFactory */
093    protected ShippingMethodDetailFactory() {
094        super();
095    }
096    
097    public static ShippingMethodDetailFactory getInstance() {
098        return CDI.current().select(ShippingMethodDetailFactory.class).get();
099    }
100    
101    @Override
102    public String getPKColumn() {
103        return PK_COLUMN;
104    }
105    
106    @Override
107    public String getAllColumns() {
108        return ALL_COLUMNS;
109    }
110    
111    @Override
112    public String getTableName() {
113        return TABLE_NAME;
114    }
115    
116    @Override
117    public String getComponentVendorName() {
118        return ShippingMethodDetailConstants.COMPONENT_VENDOR_NAME;
119    }
120    
121    @Override
122    public String getEntityTypeName() {
123        return ShippingMethodDetailConstants.ENTITY_TYPE_NAME;
124    }
125    
126    public PreparedStatement prepareStatement(String query) {
127        return session.prepareStatement(ShippingMethodDetailFactory.class, query);
128    }
129    
130    public ShippingMethodDetailPK getNextPK() {
131        return new ShippingMethodDetailPK(entityIdGenerator.getNextEntityId());
132    }
133    
134    public Set<ShippingMethodDetailPK> getPKsFromResultSetAsSet(ResultSet rs)
135            throws PersistenceDatabaseException {
136        Set<ShippingMethodDetailPK> _result = new HashSet<>();
137        
138        try {
139            while(rs.next()) {
140                _result.add(getPKFromResultSet(rs));
141            }
142        } catch (SQLException se) {
143            throw new PersistenceDatabaseException(se);
144        }
145        
146        return _result;
147    }
148    
149    public java.util.List<ShippingMethodDetailPK> getPKsFromResultSetAsList(ResultSet rs)
150            throws PersistenceDatabaseException {
151        java.util.List<ShippingMethodDetailPK> _result = new ArrayList<>();
152        
153        try {
154            while(rs.next()) {
155                _result.add(getPKFromResultSet(rs));
156            }
157        } catch (SQLException se) {
158            throw new PersistenceDatabaseException(se);
159        }
160        
161        return _result;
162    }
163    
164    public ShippingMethodDetailPK getPKFromResultSet(ResultSet rs)
165            throws PersistenceDatabaseException {
166        ShippingMethodDetailPK _result;
167        
168        try {
169            long shmdt_shippingmethoddetailid = rs.getLong(SHMDT_SHIPPINGMETHODDETAILID);
170            Long _entityId = rs.wasNull() ? null : shmdt_shippingmethoddetailid;
171            
172            _result = new ShippingMethodDetailPK(_entityId);
173        } catch (SQLException se) {
174            throw new PersistenceDatabaseException(se);
175        }
176        
177        return _result;
178    }
179    
180    public java.util.List<ShippingMethodDetailValue> getValuesFromPKs(Collection<ShippingMethodDetailPK> pks)
181            throws PersistenceDatabaseException {
182        java.util.List<ShippingMethodDetailValue> _values = new ArrayList<>(pks.size());
183        
184        for(ShippingMethodDetailPK _pk: pks) {
185            _values.add(getValueFromPK(_pk));
186        }
187        
188        return _values;
189    }
190    
191    public ShippingMethodDetailValue getValueFromPK(ShippingMethodDetailPK pk)
192            throws PersistenceDatabaseException {
193        ShippingMethodDetailValue _value;
194        
195        // See if we already have the entity in the session cache
196        ShippingMethodDetail _entity = (ShippingMethodDetail)session.getEntity(pk);
197        if(_entity == null)
198            _value = getEntityFromPK(EntityPermission.READ_ONLY, pk).getShippingMethodDetailValue();
199        else
200            _value = _entity.getShippingMethodDetailValue();
201        
202        return _value;
203    }
204    
205    public java.util.List<ShippingMethodDetailValue> getValuesFromResultSet(ResultSet rs)
206            throws PersistenceDatabaseException {
207        java.util.List<ShippingMethodDetailValue> _result = new ArrayList<>();
208        
209        try {
210            while(rs.next()) {
211                _result.add(getValueFromResultSet(rs));
212            }
213        } catch (SQLException se) {
214            throw new PersistenceDatabaseException(se);
215        }
216        
217        return _result;
218    }
219    
220    public ShippingMethodDetailValue getValueFromResultSet(ResultSet rs)
221            throws PersistenceDatabaseException {
222        ShippingMethodDetailValue _value;
223        
224        try {
225            Long shmdt_shippingmethoddetailid = rs.getLong(SHMDT_SHIPPINGMETHODDETAILID);
226            ShippingMethodDetailPK _pk = new ShippingMethodDetailPK(shmdt_shippingmethoddetailid);
227            
228            // See if we already have the entity in the session cache
229            ShippingMethodDetail _entity = (ShippingMethodDetail)session.getEntity(_pk);
230            
231            if(_entity == null) {
232                Long shmdt_shm_shippingmethodid = rs.getLong(SHMDT_SHM_SHIPPINGMETHODID);
233                if(rs.wasNull())
234                    shmdt_shm_shippingmethodid = null;
235                
236                String shmdt_shippingmethodname = rs.getString(SHMDT_SHIPPINGMETHODNAME);
237                if(rs.wasNull())
238                    shmdt_shippingmethodname = null;
239                
240                Long shmdt_geocodeselectorid = rs.getLong(SHMDT_GEOCODESELECTORID);
241                if(rs.wasNull())
242                    shmdt_geocodeselectorid = null;
243                
244                Long shmdt_itemselectorid = rs.getLong(SHMDT_ITEMSELECTORID);
245                if(rs.wasNull())
246                    shmdt_itemselectorid = null;
247                
248                Integer shmdt_sortorder = rs.getInt(SHMDT_SORTORDER);
249                if(rs.wasNull())
250                    shmdt_sortorder = null;
251                
252                Long shmdt_fromtime = rs.getLong(SHMDT_FROMTIME);
253                if(rs.wasNull())
254                    shmdt_fromtime = null;
255                
256                Long shmdt_thrutime = rs.getLong(SHMDT_THRUTIME);
257                if(rs.wasNull())
258                    shmdt_thrutime = null;
259                
260                _value = new ShippingMethodDetailValue(_pk, new ShippingMethodPK(shmdt_shm_shippingmethodid), shmdt_shippingmethodname, new SelectorPK(shmdt_geocodeselectorid), new SelectorPK(shmdt_itemselectorid), shmdt_sortorder, shmdt_fromtime, shmdt_thrutime);
261            } else
262                _value = _entity.getShippingMethodDetailValue();
263        } catch (SQLException se) {
264            throw new PersistenceDatabaseException(se);
265        }
266        
267        return _value;
268    }
269    
270    public java.util.List<ShippingMethodDetail> getEntitiesFromPKs(EntityPermission entityPermission, Collection<ShippingMethodDetailPK> pks)
271            throws PersistenceDatabaseException {
272        java.util.List<ShippingMethodDetail> _entities = new ArrayList<>(pks.size());
273        
274        for(ShippingMethodDetailPK _pk: pks) {
275            _entities.add(getEntityFromPK(entityPermission, _pk));
276        }
277        
278        return _entities;
279    }
280    
281    public ShippingMethodDetail getEntityFromValue(EntityPermission entityPermission, ShippingMethodDetailValue value) {
282        return getEntityFromPK(entityPermission, value.getPrimaryKey());
283    }
284    
285    public ShippingMethodDetail getEntityFromCache(ShippingMethodDetailPK pk) {
286        ShippingMethodDetailValue _value = (ShippingMethodDetailValue)session.getValueCache().get(pk);
287    
288        return _value == null ? null : new ShippingMethodDetail(_value, EntityPermission.READ_ONLY);
289    }
290    
291    public ShippingMethodDetail getEntityFromPK(EntityPermission entityPermission, ShippingMethodDetailPK pk)
292            throws PersistenceDatabaseException {
293        ShippingMethodDetail _entity;
294        
295        // See if we already have the entity in the session cache
296        _entity = (ShippingMethodDetail)session.getEntity(pk);
297        if(_entity != null) {
298            // If the requested permission is READ_WRITE, and the cached permission is
299            // READ_ONLY, then pretend that the cached object wasn't found, and create
300            // a new entity that is READ_WRITE.
301            if(entityPermission.equals(EntityPermission.READ_WRITE)) {
302                if(_entity.getEntityPermission().equals(EntityPermission.READ_ONLY))
303                    _entity = null;
304            }
305        }
306        
307        if(_entity == null && entityPermission.equals(EntityPermission.READ_ONLY)) {
308            _entity = getEntityFromCache(pk);
309        }
310        
311        if(_entity == null) {
312            PreparedStatement _ps = session.prepareStatement(entityPermission.equals(EntityPermission.READ_ONLY)? SQL_SELECT_READ_ONLY: SQL_SELECT_READ_WRITE);
313            long _entityId = pk.getEntityId();
314            ResultSet _rs = null;
315            
316            try {
317                _ps.setLong(1, _entityId);
318                _rs = _ps.executeQuery();
319                if(_rs.next()) {
320                    _entity = getEntityFromResultSet(entityPermission, _rs);
321                }
322            } catch (SQLException se) {
323                throw new PersistenceDatabaseException(se);
324            } finally {
325                if(_rs != null) {
326                    try {
327                        _rs.close();
328                    } catch (SQLException se) {
329                        // do nothing
330                    }
331                }
332            }
333        }
334        
335        return _entity;
336    }
337    
338    public Set<ShippingMethodDetailPK> getPKsFromQueryAsSet(PreparedStatement ps, final Object... params)
339            throws PersistenceDatabaseException {
340        Set<ShippingMethodDetailPK> _pks;
341        ResultSet _rs = null;
342        
343        try {
344            if(params.length != 0) {
345                Session.setQueryParams(ps, params);
346            }
347            
348            _rs = ps.executeQuery();
349            _pks = getPKsFromResultSetAsSet(_rs);
350            _rs.close();
351        } catch (SQLException se) {
352            throw new PersistenceDatabaseException(se);
353        } finally {
354            if(_rs != null) {
355                try {
356                    _rs.close();
357                } catch (SQLException se) {
358                    // do nothing
359                }
360            }
361        }
362        
363        return _pks;
364    }
365    
366    public java.util.List<ShippingMethodDetailPK> getPKsFromQueryAsList(PreparedStatement ps, final Object... params)
367            throws PersistenceDatabaseException {
368        java.util.List<ShippingMethodDetailPK> _pks;
369        ResultSet _rs = null;
370        
371        try {
372            if(params.length != 0) {
373                Session.setQueryParams(ps, params);
374            }
375            
376            _rs = ps.executeQuery();
377            _pks = getPKsFromResultSetAsList(_rs);
378            _rs.close();
379        } catch (SQLException se) {
380            throw new PersistenceDatabaseException(se);
381        } finally {
382            if(_rs != null) {
383                try {
384                    _rs.close();
385                } catch (SQLException se) {
386                    // do nothing
387                }
388            }
389        }
390        
391        return _pks;
392    }
393    
394    public ShippingMethodDetailPK getPKFromQuery(PreparedStatement ps, final Object... params)
395            throws PersistenceDatabaseException {
396        ShippingMethodDetailPK _pk = null;
397        ResultSet _rs = null;
398        
399        try {
400            if(params.length != 0) {
401                Session.setQueryParams(ps, params);
402            }
403            
404            _rs = ps.executeQuery();
405            if(_rs.next()) {
406                _pk = getPKFromResultSet(_rs);
407            }
408            _rs.close();
409        } catch (SQLException se) {
410            throw new PersistenceDatabaseException(se);
411        } finally {
412            if(_rs != null) {
413                try {
414                    _rs.close();
415                } catch (SQLException se) {
416                    // do nothing
417                }
418            }
419        }
420        
421        return _pk;
422    }
423    
424    public java.util.List<ShippingMethodDetail> getEntitiesFromQuery(EntityPermission entityPermission, Map<EntityPermission, String>queryMap, final Object... params)
425            throws PersistenceDatabaseException {
426        PreparedStatement ps = session.prepareStatement(ShippingMethodDetailFactory.class, queryMap.get(entityPermission));
427        
428        return getEntitiesFromQuery(entityPermission, ps, params);
429    }
430    
431    public java.util.List<ShippingMethodDetail> getEntitiesFromQuery(EntityPermission entityPermission, Map<EntityPermission, String>queryMap)
432            throws PersistenceDatabaseException {
433        PreparedStatement ps = session.prepareStatement(ShippingMethodDetailFactory.class, queryMap.get(entityPermission));
434        
435        return getEntitiesFromQuery(entityPermission, ps);
436    }
437    
438    public java.util.List<ShippingMethodDetail> getEntitiesFromQuery(EntityPermission entityPermission, PreparedStatement ps, final Object... params)
439            throws PersistenceDatabaseException {
440        java.util.List<ShippingMethodDetail> _entities;
441        ResultSet _rs = null;
442        
443        try {
444            if(params.length != 0) {
445                Session.setQueryParams(ps, params);
446            }
447            
448            _rs = ps.executeQuery();
449            _entities = getEntitiesFromResultSet(entityPermission, _rs);
450            _rs.close();
451        } catch (SQLException se) {
452            throw new PersistenceDatabaseException(se);
453        } finally {
454            if(_rs != null) {
455                try {
456                    _rs.close();
457                } catch (SQLException se) {
458                    // do nothing
459                }
460            }
461        }
462        
463        return _entities;
464    }
465    
466    public ShippingMethodDetail getEntityFromQuery(EntityPermission entityPermission, Map<EntityPermission, String>queryMap, final Object... params)
467            throws PersistenceDatabaseException {
468        PreparedStatement ps = session.prepareStatement(ShippingMethodDetailFactory.class, queryMap.get(entityPermission));
469        
470        return getEntityFromQuery(entityPermission, ps, params);
471    }
472    
473    public ShippingMethodDetail getEntityFromQuery(EntityPermission entityPermission, Map<EntityPermission, String>queryMap)
474            throws PersistenceDatabaseException {
475        PreparedStatement ps = session.prepareStatement(ShippingMethodDetailFactory.class, queryMap.get(entityPermission));
476        
477        return getEntityFromQuery(entityPermission, ps);
478    }
479    
480    public ShippingMethodDetail getEntityFromQuery(EntityPermission entityPermission, PreparedStatement ps, final Object... params)
481            throws PersistenceDatabaseException {
482        ShippingMethodDetail _entity = null;
483        ResultSet _rs = null;
484        
485        try {
486            if(params.length != 0) {
487                Session.setQueryParams(ps, params);
488            }
489            
490            _rs = ps.executeQuery();
491            if(_rs.next()) {
492                _entity = getEntityFromResultSet(entityPermission, _rs);
493            }
494            _rs.close();
495        } catch (SQLException se) {
496            throw new PersistenceDatabaseException(se);
497        } finally {
498            if(_rs != null) {
499                try {
500                    _rs.close();
501                } catch (SQLException se) {
502                    // do nothing
503                }
504            }
505        }
506        
507        return _entity;
508    }
509    
510    public java.util.List<ShippingMethodDetail> getEntitiesFromResultSet(EntityPermission entityPermission, ResultSet rs)
511            throws PersistenceDatabaseException {
512        java.util.List<ShippingMethodDetail> _result = new ArrayList<>();
513        
514        try {
515            while(rs.next()) {
516                _result.add(getEntityFromResultSet(entityPermission, rs));
517            }
518        } catch (SQLException se) {
519            throw new PersistenceDatabaseException(se);
520        }
521        
522        return _result;
523    }
524    
525    public ShippingMethodDetail getEntityFromResultSet(EntityPermission entityPermission, ResultSet rs)
526            throws PersistenceDatabaseException {
527        ShippingMethodDetail _entity;
528        
529        try {
530            Long shmdt_shippingmethoddetailid = rs.getLong(SHMDT_SHIPPINGMETHODDETAILID);
531            ShippingMethodDetailPK _pk = new ShippingMethodDetailPK(shmdt_shippingmethoddetailid);
532            
533            // See if we already have the entity in the session cache
534            _entity = (ShippingMethodDetail)session.getEntity(_pk);
535            if(_entity != null) {
536                // If the requested permission is READ_WRITE, and the cached permission is
537                // READ_ONLY, then pretend that the cached object wasn't found, and create
538                // a new entity that is READ_WRITE.
539                if(entityPermission.equals(EntityPermission.READ_WRITE)) {
540                    if(_entity.getEntityPermission().equals(EntityPermission.READ_ONLY))
541                        _entity = null;
542                }
543            }
544            boolean foundInSessionCache = _entity != null;
545            
546            if(_entity == null && entityPermission.equals(EntityPermission.READ_ONLY)) {
547                _entity = getEntityFromCache(_pk);
548            }
549            
550            if(_entity == null) {
551                Long shmdt_shm_shippingmethodid = rs.getLong(SHMDT_SHM_SHIPPINGMETHODID);
552                if(rs.wasNull())
553                    shmdt_shm_shippingmethodid = null;
554                
555                String shmdt_shippingmethodname = rs.getString(SHMDT_SHIPPINGMETHODNAME);
556                if(rs.wasNull())
557                    shmdt_shippingmethodname = null;
558                
559                Long shmdt_geocodeselectorid = rs.getLong(SHMDT_GEOCODESELECTORID);
560                if(rs.wasNull())
561                    shmdt_geocodeselectorid = null;
562                
563                Long shmdt_itemselectorid = rs.getLong(SHMDT_ITEMSELECTORID);
564                if(rs.wasNull())
565                    shmdt_itemselectorid = null;
566                
567                Integer shmdt_sortorder = rs.getInt(SHMDT_SORTORDER);
568                if(rs.wasNull())
569                    shmdt_sortorder = null;
570                
571                Long shmdt_fromtime = rs.getLong(SHMDT_FROMTIME);
572                if(rs.wasNull())
573                    shmdt_fromtime = null;
574                
575                Long shmdt_thrutime = rs.getLong(SHMDT_THRUTIME);
576                if(rs.wasNull())
577                    shmdt_thrutime = null;
578                
579                ShippingMethodDetailValue _value = new ShippingMethodDetailValue(_pk, shmdt_shm_shippingmethodid == null? null: new ShippingMethodPK(shmdt_shm_shippingmethodid), shmdt_shippingmethodname, shmdt_geocodeselectorid == null? null: new SelectorPK(shmdt_geocodeselectorid), shmdt_itemselectorid == null? null: new SelectorPK(shmdt_itemselectorid), shmdt_sortorder, shmdt_fromtime, shmdt_thrutime);
580                _entity = new ShippingMethodDetail(_value, entityPermission);
581            }
582            
583            if(!foundInSessionCache) {
584                if(entityPermission.equals(EntityPermission.READ_ONLY)) {
585                    session.putReadOnlyEntity(_pk, _entity);
586                    session.getValueCache().put(_entity.getShippingMethodDetailValue());
587                } else {
588                    session.putReadWriteEntity(_pk, _entity);
589                }
590            }
591        } catch (SQLException se) {
592            throw new PersistenceDatabaseException(se);
593        }
594        
595        return _entity;
596    }
597    
598    public ShippingMethodDetail create(ShippingMethod shippingMethod, String shippingMethodName, Selector geoCodeSelector, Selector itemSelector, Integer sortOrder, Long fromTime, Long thruTime)
599            throws PersistenceDatabaseException, PersistenceNotNullException {
600        return create(shippingMethod == null ? null : shippingMethod.getPrimaryKey(), shippingMethodName, geoCodeSelector == null ? null : geoCodeSelector.getPrimaryKey(), itemSelector == null ? null : itemSelector.getPrimaryKey(), sortOrder, fromTime, thruTime);
601    }
602    
603    private void bindForCreate(PreparedStatement _ps, ShippingMethodDetailValue _value)
604            throws SQLException {
605        _ps.setLong(1, _value.getEntityId());
606        
607        ShippingMethodPK shmdt_shm_shippingmethodid = _value.getShippingMethodPK();
608        if(shmdt_shm_shippingmethodid == null)
609            _ps.setNull(2, Types.BIGINT);
610        else
611            _ps.setLong(2, shmdt_shm_shippingmethodid.getEntityId());
612            
613        String shmdt_shippingmethodname = _value.getShippingMethodName();
614        if(shmdt_shippingmethodname == null)
615            _ps.setNull(3, Types.VARCHAR);
616        else
617            _ps.setString(3, shmdt_shippingmethodname);
618            
619        SelectorPK shmdt_geocodeselectorid = _value.getGeoCodeSelectorPK();
620        if(shmdt_geocodeselectorid == null)
621            _ps.setNull(4, Types.BIGINT);
622        else
623            _ps.setLong(4, shmdt_geocodeselectorid.getEntityId());
624            
625        SelectorPK shmdt_itemselectorid = _value.getItemSelectorPK();
626        if(shmdt_itemselectorid == null)
627            _ps.setNull(5, Types.BIGINT);
628        else
629            _ps.setLong(5, shmdt_itemselectorid.getEntityId());
630            
631        Integer shmdt_sortorder = _value.getSortOrder();
632        if(shmdt_sortorder == null)
633            _ps.setNull(6, Types.INTEGER);
634        else
635            _ps.setInt(6, shmdt_sortorder);
636            
637        Long shmdt_fromtime = _value.getFromTime();
638        if(shmdt_fromtime == null)
639            _ps.setNull(7, Types.BIGINT);
640        else
641            _ps.setLong(7, shmdt_fromtime);
642            
643        Long shmdt_thrutime = _value.getThruTime();
644        if(shmdt_thrutime == null)
645            _ps.setNull(8, Types.BIGINT);
646        else
647            _ps.setLong(8, shmdt_thrutime);
648            
649    }
650    
651    public ShippingMethodDetail create(ShippingMethodPK shippingMethodPK, String shippingMethodName, SelectorPK geoCodeSelectorPK, SelectorPK itemSelectorPK, Integer sortOrder, Long fromTime, Long thruTime)
652            throws PersistenceDatabaseException, PersistenceNotNullException {
653        ShippingMethodDetailPK _pk = getNextPK();
654        ShippingMethodDetailValue _value = new ShippingMethodDetailValue(_pk, shippingMethodPK, shippingMethodName, geoCodeSelectorPK, itemSelectorPK, sortOrder, fromTime, thruTime);
655        
656        PreparedStatement _ps = session.prepareStatement(SQL_INSERT);
657        
658        try {
659            bindForCreate(_ps, _value);
660            
661            if(PersistenceDebugFlags.CheckEntityInsertRowCount) {
662                int _count = _ps.executeUpdate();
663                
664                if(_count != 1) {
665                    throw new PersistenceDatabaseUpdateException("insert failed, _count = " + _count);
666                }
667            } else {
668                 _ps.executeUpdate();
669            }
670            
671            session.getValueCache().put(_value);
672        } catch (SQLException se) {
673            throw new PersistenceDatabaseException(se);
674        }
675        
676        ShippingMethodDetail _entity = new ShippingMethodDetail(_value, EntityPermission.READ_ONLY);
677        session.putReadOnlyEntity(_pk, _entity);
678        
679        return _entity;
680    }
681    
682    public void create(Collection<ShippingMethodDetailValue> _values)
683            throws PersistenceDatabaseException, PersistenceNotNullException {
684        int _size = _values.size();
685        
686        if(_size > 0) {
687            PreparedStatement _ps = session.prepareStatement(SQL_INSERT);
688            List<ShippingMethodDetailValue> _cacheValues = new ArrayList<>(_size);
689            
690            try {
691                for(ShippingMethodDetailValue _value : _values) {
692                    _value.setEntityId(entityIdGenerator.getNextEntityId());
693                    bindForCreate(_ps, _value);
694                    
695                    _ps.addBatch();
696                    
697                    _cacheValues.add(_value);
698                }
699                
700                if(PersistenceDebugFlags.CheckEntityInsertRowCount) {
701                    int[] _counts = _ps.executeBatch();
702                    
703                    for(int _countOffset = 0 ; _countOffset < _size ; _countOffset++) {
704                        if(_counts[_countOffset] != 1 && _counts[_countOffset] != PreparedStatement.SUCCESS_NO_INFO) {
705                            throw new PersistenceDatabaseUpdateException("batch insert failed, _counts[" + _countOffset + "] = " + _counts[_countOffset]);
706                        }
707                    }
708                } else {
709                     _ps.executeBatch();
710                }
711                
712                _ps.clearBatch();
713            } catch (SQLException se) {
714                throw new PersistenceDatabaseException(se);
715            }
716            
717            _cacheValues.forEach((_cacheValue) -> {
718                ShippingMethodDetail _cacheEntity = new ShippingMethodDetail(_cacheValue, EntityPermission.READ_ONLY);
719                
720                session.putReadOnlyEntity(_cacheValue.getPrimaryKey(), _cacheEntity);
721            });
722        }
723    }
724    
725    private boolean bindForStore(PreparedStatement _ps, ShippingMethodDetailValue _value)
726            throws SQLException {
727        boolean _hasBeenModified = _value.hasBeenModified();
728        
729        if(_hasBeenModified) {
730            ShippingMethodPK shmdt_shm_shippingmethodid = _value.getShippingMethodPK();
731            if(shmdt_shm_shippingmethodid == null)
732                _ps.setNull(1, Types.BIGINT);
733            else
734                _ps.setLong(1, shmdt_shm_shippingmethodid.getEntityId());
735            
736            String shmdt_shippingmethodname = _value.getShippingMethodName();
737            if(shmdt_shippingmethodname == null)
738                _ps.setNull(2, Types.VARCHAR);
739            else
740                _ps.setString(2, shmdt_shippingmethodname);
741            
742            SelectorPK shmdt_geocodeselectorid = _value.getGeoCodeSelectorPK();
743            if(shmdt_geocodeselectorid == null)
744                _ps.setNull(3, Types.BIGINT);
745            else
746                _ps.setLong(3, shmdt_geocodeselectorid.getEntityId());
747            
748            SelectorPK shmdt_itemselectorid = _value.getItemSelectorPK();
749            if(shmdt_itemselectorid == null)
750                _ps.setNull(4, Types.BIGINT);
751            else
752                _ps.setLong(4, shmdt_itemselectorid.getEntityId());
753            
754            Integer shmdt_sortorder = _value.getSortOrder();
755            if(shmdt_sortorder == null)
756                _ps.setNull(5, Types.INTEGER);
757            else
758                _ps.setInt(5, shmdt_sortorder);
759            
760            Long shmdt_fromtime = _value.getFromTime();
761            if(shmdt_fromtime == null)
762                _ps.setNull(6, Types.BIGINT);
763            else
764                _ps.setLong(6, shmdt_fromtime);
765            
766            Long shmdt_thrutime = _value.getThruTime();
767            if(shmdt_thrutime == null)
768                _ps.setNull(7, Types.BIGINT);
769            else
770                _ps.setLong(7, shmdt_thrutime);
771            
772            _ps.setLong(8, _value.getPrimaryKey().getEntityId());
773            
774            _value.clearHasBeenModified();
775        }
776        
777        return _hasBeenModified;
778    }
779    
780    @Override
781    public void store(ShippingMethodDetail entity)
782            throws PersistenceDatabaseException {
783        PreparedStatement _ps = session.prepareStatement(SQL_UPDATE);
784        
785        try {
786            ShippingMethodDetailValue _value = entity.getShippingMethodDetailValue();
787            
788            if(bindForStore(_ps, _value)) {
789                if(PersistenceDebugFlags.CheckEntityUpdateRowCount) {
790                    int _count = _ps.executeUpdate();
791                    
792                    if(_count != 1) {
793                        throw new PersistenceDatabaseUpdateException("update failed, _count = " + _count);
794                    }
795                } else {
796                     _ps.executeUpdate();
797                }
798                
799                session.getValueCache().put(_value);
800            }
801        } catch (SQLException se) {
802            throw new PersistenceDatabaseException(se);
803        }
804    }
805    
806    @Override
807    public void store(Collection<ShippingMethodDetail> entities)
808            throws PersistenceDatabaseException {
809        if(entities.size() > 0) {
810            PreparedStatement _ps = session.prepareStatement(SQL_UPDATE);
811            int _modifiedEntities = 0;
812            
813            try {
814                for(ShippingMethodDetail entity : entities) {
815                    if(bindForStore(_ps, entity.getShippingMethodDetailValue())) {
816                        _ps.addBatch();
817                        _modifiedEntities++;
818                    }
819                }
820                
821                if(_modifiedEntities != 0) {
822                    if(PersistenceDebugFlags.CheckEntityUpdateRowCount) {
823                        int[] _counts = _ps.executeBatch();
824                        
825                        for(int _countOffset = 0 ; _countOffset < _modifiedEntities  ; _countOffset++) {
826                            if(_counts[_countOffset] != 1 && _counts[_countOffset] != PreparedStatement.SUCCESS_NO_INFO) {
827                                throw new PersistenceDatabaseUpdateException("batch update failed, _counts[" + _countOffset + "] = " + _counts[_countOffset]);
828                            }
829                        }
830                    } else {
831                         _ps.executeBatch();
832                    }
833                    
834                    _ps.clearBatch();
835                    
836                    entities.forEach((entity) -> {
837                        session.getValueCache().put(entity.getShippingMethodDetailValue());
838                    });
839                }
840            } catch (SQLException se) {
841                throw new PersistenceDatabaseException(se);
842            }
843        }
844    }
845    
846    @Override
847    public void remove(ShippingMethodDetail entity)
848            throws PersistenceDatabaseException {
849        remove(entity.getPrimaryKey());
850    }
851    
852    @Override
853    public void remove(ShippingMethodDetailPK pk)
854            throws PersistenceDatabaseException {
855        PreparedStatement _ps = session.prepareStatement(SQL_DELETE);
856        long _entityId = pk.getEntityId();
857        
858        try {
859            _ps.setLong(1, _entityId);
860            
861            if(PersistenceDebugFlags.CheckEntityDeleteRowCount) {
862                int _count = _ps.executeUpdate();
863                
864                if(_count != 1) {
865                    throw new PersistenceDatabaseUpdateException("remove failed, _count = " + _count);
866                }
867            } else {
868                 _ps.executeUpdate();
869            }
870            
871            session.getValueCache().remove(pk);
872        } catch (SQLException se) {
873            throw new PersistenceDatabaseException(se);
874        }
875        
876        session.removed(pk, false);
877    }
878    
879    @Override
880    public void remove(Collection<ShippingMethodDetailPK> pks)
881            throws PersistenceDatabaseException {
882        if(pks.size() > 0) {
883            PreparedStatement _ps = session.prepareStatement(SQL_DELETE);
884            int _modifiedEntities = 0;
885            
886            try {
887                for(ShippingMethodDetailPK pk : pks) {
888                    long _entityId = pk.getEntityId();
889                    
890                    _ps.setLong(1, _entityId);
891                    
892                    _ps.addBatch();
893                    _modifiedEntities++;
894                }
895                
896                if(_modifiedEntities != 0) {
897                    if(PersistenceDebugFlags.CheckEntityDeleteRowCount) {
898                        int[] _counts = _ps.executeBatch();
899                        
900                        for(int _countOffset = 0 ; _countOffset < _modifiedEntities  ; _countOffset++) {
901                            if(_counts[_countOffset] != 1 && _counts[_countOffset] != PreparedStatement.SUCCESS_NO_INFO) {
902                                throw new PersistenceDatabaseUpdateException("batch remove failed, _counts[" + _countOffset + "] = " + _counts[_countOffset]);
903                            }
904                        }
905                    } else {
906                        _ps.executeBatch();
907                    }
908                    
909                    _ps.clearBatch();
910                    
911                    pks.forEach((pk) -> {
912                        session.getValueCache().remove(pk);
913                    });
914                }
915            } catch (SQLException se) {
916                throw new PersistenceDatabaseException(se);
917            }
918            
919            pks.forEach((pk) -> {
920                session.removed(pk, true);
921            });
922        }
923    }
924    
925    @Override
926    public boolean validPK(ShippingMethodDetailPK pk)
927            throws PersistenceDatabaseException {
928        boolean valid = false;
929        PreparedStatement _ps = session.prepareStatement(SQL_VALID);
930        ResultSet _rs = null;
931        
932        try {
933            _ps.setLong(1, pk.getEntityId());
934            
935            _rs = _ps.executeQuery();
936            if(_rs.next()) {
937                long _count = _rs.getLong(1);
938                if(_rs.wasNull())
939                    _count = 0;
940                
941                if(_count == 1)
942                    valid = true;
943            }
944        } catch (SQLException se) {
945            throw new PersistenceDatabaseException(se);
946        } finally {
947            if(_rs != null) {
948                try {
949                    _rs.close();
950                } catch (SQLException se) {
951                    // do nothing
952                }
953            }
954        }
955        
956        return valid;
957    }
958    
959}