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