src/jdk.incubator.adba/share/classes/jdk/incubator/sql2/OperationGroup.java
author lancea
Wed, 11 Jul 2018 19:36:23 -0400
branchJDK-8188051-branch
changeset 56828 64304e37e9b1
parent 56824 62e92191354d
child 56832 4f7713e6a308
permissions -rw-r--r--
JDK-8188051-branch javadoc updates and added TransactionCompletion.java
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
     1
/*
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
     2
 * Copyright (c)  2017, 2018, Oracle and/or its affiliates. All rights reserved.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
     4
 *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    10
 *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    15
 * accompanied this code).
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    16
 *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    20
 *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    23
 * questions.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    24
 */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    25
package jdk.incubator.sql2;
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    26
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    27
import java.time.Duration;
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    28
import java.util.concurrent.CompletionStage;
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    29
import java.util.function.Consumer;
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    30
import java.util.logging.Logger;
56828
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
    31
import java.util.regex.Pattern;
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    32
import java.util.stream.Collector;
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    33
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    34
/**
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    35
 * <p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    36
 * A set of {@link Operation}s that share certain properties, are managed as a
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    37
 * unit, and are executed as a unit. The {@link Operation}s created by an
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    38
 * {@link OperationGroup} and submitted are the member {@link Operation}s of
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    39
 * that {@link OperationGroup}. An {@link OperationGroup} is not a transaction
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    40
 * and is not related to a transaction in any way.</p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    41
 *
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    42
 * <p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    43
 * An {@link OperationGroup} conceptually has a collection of member
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    44
 * {@link Operation}s. When an {@link OperationGroup} is submitted it is placed
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    45
 * in the collection of the {@link OperationGroup} of which it is a member. The
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    46
 * member {@link OperationGroup} is executed according to the attributes of the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    47
 * {@link OperationGroup} of which it is a member. The member {@link Operation}s
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    48
 * of an {@link OperationGroup} are executed according to the attributes of that
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    49
 * {@link OperationGroup}.</p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    50
 *
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    51
 * <p>
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    52
 * How an {@link OperationGroup} is executed depends on its attributes.</p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    53
 *
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    54
 * <p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    55
 * If an {@link OperationGroup} has a condition and the value of that condition
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    56
 * is {@link Boolean#TRUE} then execute the member {@link Operation}s as below.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    57
 * If it is {@link Boolean#FALSE} then the {@link OperationGroup} is completed
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    58
 * with the value null. If the condition completed exceptionally then the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    59
 * {@link OperationGroup} is completed exceptionally with a
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    60
 * {@link SqlSkippedException} that has that exception as its cause.</p>
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    61
 * 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    62
 * <p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    63
 * If the {@link OperationGroup} is sequential the member {@link Operation}s are
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    64
 * executed in the order they were submitted. If it is parallel, they may be
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    65
 * executed in any order including simultaneously.</p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    66
 *
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    67
 * <p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    68
 * If an {@link OperationGroup} is dependent and a member {@link Operation}
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    69
 * completes exceptionally the remaining member {@link Operation}s in the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    70
 * collection are completed exceptionally with a {@link SqlSkippedException}
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    71
 * that has the initial {@link Exception} as its cause and the {@link OperationGroup}
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    72
 * is completed exceptionally with the initial {@link Exception}. A member
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    73
 * {@link Operation} in-flight may either complete normally or be completed
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    74
 * exceptionally but must complete one way or the other. [NOTE: Too strong?]</p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    75
 *
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    76
 * <p>
56479
045b7db933bd JDK-8188051-branch javadoc typo updates
lancea
parents: 56475
diff changeset
    77
 * After a call to {@link OperationGroup#submitHoldingForMoreMembers} the
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    78
 * {@link OperationGroup} is submitted and held. After a call to 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    79
 * {@link OperationGroup#releaseProhibitingMoreMembers} the {@link OperationGroup} 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    80
 * is no longer held and is still submitted. Holding permits member {@link Operation}s
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    81
 * to be executed at the same time additional member {@link Operation}s are
56479
045b7db933bd JDK-8188051-branch javadoc typo updates
lancea
parents: 56475
diff changeset
    82
 * submitted. Collecting the member {@link Operation}s' results does not begin
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    83
 * until the {@link OperationGroup} is no longer held.</p>
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    84
 * 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    85
 * <p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    86
 * If an {@link OperationGroup} is held additional member {@link Operation}s may
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    87
 * be submitted. If an {@link OperationGroup} is not held, no additional member 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    88
 * {@link Operation}s  may be submitted after the {@link OperationGroup} is 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    89
 * submitted. If an {@link OperationGroup} is held it will be completed only after 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    90
 * it is released or if conditional and the condition is not {@link Boolean#TRUE}. 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    91
 * If a {@link OperationGroup} is dependent, held, one of its member
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    92
 * {@link Operation}s completed exceptionally, and its queue is empty then the
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    93
 * {@link OperationGroup} is released.</p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    94
 *
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    95
 * <p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    96
 * The result of this {@link OperationGroup} is the result of collecting the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    97
 * results of its member {@link Operation}s. If the {@link OperationGroup} is 
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
    98
 * dependent and one of its member {@link Operation}s completes exceptionally,
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
    99
 * the {@link OperationGroup} is completed exceptionally.</p>
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   100
 * 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   101
 * <p>
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   102
 * An implementation of this class must be thread safe as result and error
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   103
 * handlers running asynchronously may be accessing an {@link OperationGroup} in
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   104
 * parallel with each other and with a user thread.</p>
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   105
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   106
* <p>
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   107
 * ISSUE: Currently no way to create a nested {@link OperationGroup}. That is an
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   108
 * intentional limitation but may be a simplification we can live with. Or not.</p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   109
 *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   110
 * @param <S> The type of the result of the member {@link Operation}s
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   111
 * @param <T> The type of the collected results the member {@link Operation}s
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   112
 */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   113
public interface OperationGroup<S, T> extends Operation<T> {
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   114
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   115
  /**
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   116
   * Mark this {@link OperationGroup} as parallel. If this method is not called
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   117
   * the {@link OperationGroup} is sequential. If an {@link OperationGroup} is
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   118
   * parallel, member {@link Operation}s may be executed in any order including
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   119
   * in parallel. If an {@link OperationGroup} is sequential, the default,
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   120
   * member {@link Operation}s are executed strictly in the order they are
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   121
   * submitted.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   122
   *
56824
62e92191354d JDK-8188051-branch latest updates
lancea
parents: 56797
diff changeset
   123
   * Note: There is no covariant override of this method in {@link Session}
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   124
   * as there is only a small likelihood of needing it.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   125
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   126
   * @return this {@link OperationGroup}
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   127
   * @throws IllegalStateException if this {@link OperationGroup} has been
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   128
   * submitted, any member {@link Operation}s have been created, or this method
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   129
   * has been called previously
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   130
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   131
  public OperationGroup<S, T> parallel();
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   132
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   133
  /**
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   134
   * Mark this {@link OperationGroup} as independent. If this method is not
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   135
   * called the {@link OperationGroup} is dependent, the default. If an
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   136
   * {@link OperationGroup} is independent then failure of one member
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   137
   * {@link Operation} does not affect the execution of other member
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   138
   * {@link Operation}s. If an {@link OperationGroup} is dependent then failure
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   139
   * of one member {@link Operation} will cause all member {@link Operation}s
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   140
   * remaining in the queue to be completed exceptionally with a
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   141
   * {@link SqlSkippedException} with the cause set to the original exception.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   142
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   143
   * The result of this {@link OperationGroup}'s execution is the result of collecting the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   144
   * results of the member {@link Operation}s that complete normally. 
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   145
   *
56824
62e92191354d JDK-8188051-branch latest updates
lancea
parents: 56797
diff changeset
   146
   * Note: There is no covariant override of this method in {@link Session}
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   147
   * as there is only a small likelihood of needing it.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   148
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   149
   * @return this {@link OperationGroup}
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   150
   * @throws IllegalStateException if this {@link OperationGroup} has been 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   151
   * submitted, any member {@link Operation}s have been created, or this method
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   152
   * has been called previously
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   153
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   154
  public OperationGroup<S, T> independent();
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   155
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   156
  /**
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   157
   * Define a condition that determines whether the member {@link Operation}s of
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   158
   * this {@link OperationGroup} are executed or not. If and when this
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   159
   * {@link OperationGroup} is executed then if the condition argument is
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   160
   * completed with {@link Boolean#TRUE} the member {@link Operation}s are
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   161
   * executed. If {@link Boolean#FALSE} or if it is completed exceptionally the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   162
   * member {@link Operation}s are not executed but are removed from the queue.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   163
   * After all member {@link Operation}s have been removed from the queue this
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   164
   * {@link OperationGroup} is completed with {@code null}.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   165
   *
56824
62e92191354d JDK-8188051-branch latest updates
lancea
parents: 56797
diff changeset
   166
   * Note: There is no covariant override of this method in Session as there
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   167
   * is only a small likelihood of needing it.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   168
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   169
   * ISSUE: Should the member Operations be skipped or otherwise completed
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   170
   * exceptionally?
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   171
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   172
   * @param condition a {@link CompletionStage} the value of which determines
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   173
   * whether this {@link OperationGroup} is executed or not
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   174
   * @return this OperationGroup
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   175
   * @throws IllegalStateException if this {@link OperationGroup} has been
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   176
   * submitted, any member {@link Operation}s have been created, or this method
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   177
   * has been called previously
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   178
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   179
  public OperationGroup<S, T> conditional(CompletionStage<Boolean> condition);
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   180
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   181
  /**
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   182
   * Mark this {@link OperationGroup} as submitted and held. It can be executed but cannot be
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   183
   * completed. A {@link OperationGroup} that is held remains in the queue even
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   184
   * if all of its current member {@link Operation}s have completed. So long as
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   185
   * the {@link OperationGroup} is held new member {@link Operation}s can be
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   186
   * submitted. A {@link OperationGroup} that is held must be released before it
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   187
   * can be completed and removed from the queue.
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   188
   * 
56479
045b7db933bd JDK-8188051-branch javadoc typo updates
lancea
parents: 56475
diff changeset
   189
   * If the {@link OperationGroup} is dependent and one of its member {@link Operation}s
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   190
   * completes exceptionally and its queue is empty the {@link OperationGroup}
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   191
   * is completed.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   192
   *
56824
62e92191354d JDK-8188051-branch latest updates
lancea
parents: 56797
diff changeset
   193
   * Note: There is no covariant override of this method in Session as there
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   194
   * is only a small likelihood of needing it.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   195
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   196
   * ISSUE: Need a better name.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   197
   *
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   198
   * @return a Submission for this OperationGroup
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   199
   * @throws IllegalStateException if this {@link OperationGroup} has been
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   200
   * submitted
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   201
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   202
  public Submission<T> submitHoldingForMoreMembers();
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   203
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   204
  /**
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   205
   * Allow this {@link OperationGroup} to be completed and removed from the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   206
   * queue once all of its member {@link Operation}s have been completed. After
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   207
   * this method is called no additional member {@link Operation}s can be
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   208
   * submitted. Once all member {@link Operation}s have been removed from the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   209
   * queue this {@link OperationGroup} will be completed and removed from the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   210
   * queue.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   211
   *
56824
62e92191354d JDK-8188051-branch latest updates
lancea
parents: 56797
diff changeset
   212
   * Note: There is no covariant override of this method in Session as there
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   213
   * is only a small likelihood of needing it.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   214
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   215
   * ISSUE: Need a better name.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   216
   *
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   217
   * @return the same Submission that was returned by {@link OperationGroup#submitHoldingForMoreMembers}
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   218
   * @throws IllegalStateException if this {@link OperationGroup} has been
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   219
   * completed or is not held.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   220
   */
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   221
  public Submission<T> releaseProhibitingMoreMembers();
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   222
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   223
  /**
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   224
   * Provides a {@link Collector} to reduce the results of the member
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   225
   * {@link Operation}s. The result of this {@link OperationGroup} is the result
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   226
   * of calling finisher on the final accumulated result.If the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   227
   * {@link Collector} is {@link Collector.Characteristics#UNORDERED} the member
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   228
   * {@link Operation} results may be accumulated out of order.If the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   229
   * {@link Collector} is {@link Collector.Characteristics#CONCURRENT} then the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   230
   * member {@link Operation} results may be split into subsets that are reduced
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   231
   * separately and then combined. If this {@link OperationGroup} is sequential,
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   232
   * the characteristics of the {@link Collector} only affect how the results of
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   233
   * the member {@link Operation}s are collected; the member {@link Operation}s
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   234
   * are executed sequentially regardless. If this {@link OperationGroup} is
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   235
   * parallel the characteristics of the {@link Collector} may influence the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   236
   * execution order of the member {@link Operation}s.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   237
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   238
   * The default value is
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   239
   * {@code Collector.of(()->null, (a,t)->{}, (l,r)->null, a->null)}.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   240
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   241
   * @param c the Collector. Not null.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   242
   * @return This OperationGroup
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   243
   * @throws IllegalStateException if called more than once or if this
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   244
   * {@link OperationGroup} has been submitted
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   245
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   246
  public OperationGroup<S, T> collect(Collector<S, ?, T> c);
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   247
  
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   248
  /**
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   249
   * Return a new member {@link PrimitiveOperation} that is never skipped.
56479
045b7db933bd JDK-8188051-branch javadoc typo updates
lancea
parents: 56475
diff changeset
   250
   * Skipping of member {@link Operation}s stops with a catchOperation and the
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   251
   * subsequent {@link Operation} is executed normally. The value of a
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   252
   * catchOperation is always null. Since a catchOperation is never completed
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   253
   * exceptionally, it has no error handler or timeout.
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   254
   *
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   255
   * @return an {@link PrimitiveOperation} that is never skipped;
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   256
   * @throws IllegalStateException if the {@link OperationGroup} has been
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   257
   * submitted and is not held or if the {@link OperationGroup} is parallel or
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   258
   * independent.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   259
   */
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   260
  public PrimitiveOperation<S> catchOperation();
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   261
  
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   262
  /**
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   263
   * Creates and submits a catch Operation. Convenience method.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   264
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   265
   * @return this OperationGroup
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   266
   * @throws IllegalStateException if the {@link OperationGroup} has been
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   267
   * submitted and is not held or if the {@link OperationGroup} is parallel or
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   268
   * independent.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   269
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   270
  public default OperationGroup<S, T> catchErrors() {
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   271
    catchOperation().submit();
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   272
    return this;
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   273
  }
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   274
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   275
  /**
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   276
   * Return a new {@link ArrayRowCountOperation}.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   277
   * <p>
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   278
   * Usage Note: Frequently use of this method will require a type witness to
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   279
   * enable correct type inferencing.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   280
   * <pre><code>
56824
62e92191354d JDK-8188051-branch latest updates
lancea
parents: 56797
diff changeset
   281
   *   session.<b>&lt;List&lt;Integer&gt;&gt;</b>arrayCountOperation(sql)
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   282
   *     .set ...
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   283
   *     .collect ...
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   284
   *     .submit ...
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   285
   * </code></pre>
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   286
   *
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   287
   * @param <R> the result type of the returned {@link ArrayRowCountOperation}
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   288
   * @param sql SQL to be executed. Must return an update count.
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   289
   * @return a new {@link ArrayRowCountOperation} that is a member of this
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   290
   * {@link OperationGroup}
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   291
   * @throws IllegalStateException if the {@link OperationGroup} has been
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   292
   * submitted and is not held
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   293
   */
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   294
  public <R extends S> ArrayRowCountOperation<R> arrayRowCountOperation(String sql);
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   295
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   296
  /**
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   297
   * Return a new {@link ParameterizedRowCountOperation}.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   298
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   299
   * @param <R> the result type of the returned {@link CountOperation}
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   300
   * @param sql SQL to be executed. Must return an update count.
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   301
   * @return an new {@link ParameterizedRowCountOperation} that is a member of this
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   302
   * {@link OperationGroup}
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   303
   * @throws IllegalStateException if the {@link OperationGroup} has been
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   304
   * submitted and is not held
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   305
   */
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   306
  public <R extends S> ParameterizedRowCountOperation<R> rowCountOperation(String sql);
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   307
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   308
  /**
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   309
   * Return a new {@link Operation} for a SQL that doesn't return any result,
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   310
   * for example DDL. The result of this Operation is always null.
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   311
   * 
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   312
   * The result of the returned Operation must be Void but specifying that here
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   313
   * causes problems.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   314
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   315
   * @param sql SQL for the {@link Operation}.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   316
   * @return a new {@link Operation} that is a member of this
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   317
   * {@link OperationGroup}
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   318
   * @throws IllegalStateException if the {@link OperationGroup} has been
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   319
   * submitted and is not held
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   320
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   321
  public Operation<S> operation(String sql);
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   322
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   323
  /**
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   324
   * Return a new {@link OutOperation} that is a member {@link Operation} of this 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   325
   * {@link OperationGroup}. The SQL must return a set of zero or more out 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   326
   * parameters or function results.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   327
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   328
   * @param <R> the result type of the returned {@link OutOperation}
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   329
   * @param sql SQL for the {@link Operation}. Must return zero or more out
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   330
   * parameters or function results.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   331
   * @return a new {@link OutOperation} that is a member of this
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   332
   * {@link OperationGroup}
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   333
   * @throws IllegalStateException if the {@link OperationGroup} has been
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   334
   * submitted and is not held
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   335
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   336
  public <R extends S> OutOperation<R> outOperation(String sql);
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   337
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   338
  /**
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   339
   * Return a new {@link ParameterizedRowOperation} that is a member 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   340
   * {@link Operation} of this {@link OperationGroup}.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   341
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   342
   * @param <R> the type of the result of the returned
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   343
   * {@link ParameterizedRowOperation}
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   344
   * @param sql SQL for the {@link Operation}. Must return a row sequence.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   345
   * @return a new {@link ParameterizedRowOperation} that is a member of this
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   346
   * {@link OperationGroup}
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   347
   * @throws IllegalStateException if the {@link OperationGroup} has been
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   348
   * submitted and is not held
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   349
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   350
  public <R extends S> ParameterizedRowOperation<R> rowOperation(String sql);
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   351
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   352
  /**
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   353
   * Return a new {@link ParameterizedRowPublisherOperation} that is a member
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   354
   * {@link Operation} of this {@link OperationGroup}.
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   355
   *
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   356
   * @param <R> the type of the result of the returned
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   357
   * {@link ParameterizedRowPublisherOperation}
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   358
   * @param sql SQL for the {@link Operation}. Must return a row sequence.
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   359
   * @return a new {@link ParameterizedRowPublisherOperation} that is a member
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   360
   * of this {@link OperationGroup}
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   361
   * @throws IllegalStateException if the {@link OperationGroup} has been
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   362
   * submitted and is not held
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   363
   */
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   364
  public <R extends S> ParameterizedRowPublisherOperation<R> rowPublisherOperation(String sql);
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   365
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   366
  /**
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   367
   * Return a new {@link MultiOperation} that is a member 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   368
   * {@link Operation} of this {@link OperationGroup}.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   369
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   370
   * @param <R> the type of the result of the returned
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   371
   * {@link MultiOperation}
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   372
   * @param sql SQL for the {@link Operation}
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   373
   * @return a new {@link MultiOperation} that is a member of this
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   374
   * {@link OperationGroup}
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   375
   * @throws IllegalStateException if the {@link OperationGroup} has been
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   376
   * submitted and is not held
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   377
   */
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   378
  public <R extends S> MultiOperation<R> multiOperation(String sql);
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   379
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   380
  /**
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   381
   * Return a new {@link Operation} that ends the database transaction.  This
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   382
   * {@link Operation} is a member of the {@link OperationGroup}. The
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   383
   * transaction is ended with a commit unless the {@link Transaction} has been
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   384
   * {@link Transaction#setRollbackOnly} in which case the transaction is ended
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   385
   * with a rollback.
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   386
   * 
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   387
   * <p>
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   388
   * An endTransaction Operation may be skipped. To insure that it will not be
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   389
   * skipped it should immediately follow a catch Operation. All end transaction
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   390
   * convenience methods do so.</p>
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   391
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   392
   * The type argument {@link S} of the containing {@link OperationGroup} must
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   393
   * be a supertype of {@link TransactionOutcome}.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   394
   *
56828
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   395
   * @param trans the TransactionCompletion that determines whether the Operation does a 
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   396
 database commit or a database rollback.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   397
   * @return an {@link Operation} that will end the database transaction.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   398
   * @throws IllegalStateException if this {@link OperationGroup} has been
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   399
   * submitted and is not held or is parallel.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   400
   */
56828
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   401
  public Operation<TransactionOutcome> endTransactionOperation(TransactionCompletion trans);
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   402
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   403
  /**
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   404
   * Convenience method that creates and submits a endTransaction
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   405
   * {@link Operation} that commits by default but can be set to rollback by
56828
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   406
   * calling {@link TransactionCompletion#setRollbackOnly}. The endTransaction Operation
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   407
   * is never skipped.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   408
   *
56828
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   409
   * @param trans the TransactionCompletion that determines whether the {@link Operation} is a
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   410
   * database commit or a database rollback.
56824
62e92191354d JDK-8188051-branch latest updates
lancea
parents: 56797
diff changeset
   411
   * @return a {@link CompletionStage} that is completed with the outcome of the 
62e92191354d JDK-8188051-branch latest updates
lancea
parents: 56797
diff changeset
   412
   * transaction
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   413
   * @throws IllegalStateException if this {@link OperationGroup} has been
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   414
   * submitted and is not held or is parallel.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   415
   */
56828
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   416
  public default CompletionStage<TransactionOutcome> commitMaybeRollback(TransactionCompletion trans) {
56797
fb523d4d9185 JDK-8188051-branch updates
lancea
parents: 56479
diff changeset
   417
    catchErrors();
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   418
    return this.endTransactionOperation(trans).submit().getCompletionStage();
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   419
  }
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   420
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   421
  /**
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   422
   * Return a new {@link LocalOperation} that is a member {@link Operation} of 
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   423
   * this {@link OperationGroup}.
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   424
   *
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   425
   * @param <R> value type of the returned local {@link Operation}
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   426
   * @return a LocalOperation
56475
e700edfac7ad JDK-8188051-branch: Updates to sync with AOJ
lancea
parents: 56397
diff changeset
   427
   * @throws IllegalStateException if this {@link OperationGroup} has been submitted and
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   428
   * is not held
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   429
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   430
  public <R extends S> LocalOperation<R> localOperation();
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   431
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   432
  /**
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   433
   * Supply a {@link Logger} for the implementation of this
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   434
   * {@link OperationGroup} to use to log significant events. Exactly what
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   435
   * events are logged, at what Level the events are logged and with what
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   436
   * parameters is implementation dependent. All member {@link Operation}s of
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   437
   * this {@link OperationGroup} will use the same {@link Logger} except a
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   438
   * member {@link OperationGroup} that is supplied with a different
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   439
   * {@link Logger} uses that {@link Logger}.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   440
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   441
   * Supplying a {@link Logger} configured with a
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   442
   * {@link java.util.logging.MemoryHandler} with the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   443
   * {@link java.util.logging.MemoryHandler#pushLevel} set to
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   444
   * {@link java.util.logging.Level#WARNING} will result in no log output in
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   445
   * normal operation. In the event of an error the actions leading up to the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   446
   * error will be logged.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   447
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   448
   * Implementation Note: Implementations are encouraged to log the creation of
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   449
   * this {@link OperationGroup} set to {@link java.util.logging.Level#INFO},
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   450
   * the creation of member {@link Operation}s at the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   451
   * {@link java.util.logging.Level#CONFIG} level, and execution of member
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   452
   * {@link Operation}s at the {@link java.util.logging.Level#FINE} level.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   453
   * Detailed information about the execution of member {@link Operation}s may
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   454
   * be logged at the {@link java.util.logging.Level#FINER} and
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   455
   * {@link java.util.logging.Level#FINEST} levels. Errors in the execution of
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   456
   * user code should be logged at the {@link java.util.logging.Level#WARNING}
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   457
   * Level. Errors in the implementation code should be logged at the
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   458
   * {@link java.util.logging.Level#SEVERE} Level.
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   459
   *
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   460
   * @param logger used by the implementation to log significant events
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   461
   * @return this {@link OperationGroup}
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   462
   */
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   463
  public OperationGroup<S, T> logger(Logger logger);
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   464
56828
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   465
  /**
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   466
   * Returns a {@code String} enclosed in single quotes. Any occurrence of a
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   467
   * single quote within the string will be replaced by two single quotes.
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   468
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   469
   * <blockquote>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   470
   * <table class="striped">
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   471
   * <caption>Examples of the conversion:</caption>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   472
   * <thead>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   473
   * <tr><th scope="col">Value</th><th scope="col">Result</th></tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   474
   * </thead>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   475
   * <tbody style="text-align:center">
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   476
   * <tr> <th scope="row">Hello</th> <td>'Hello'</td> </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   477
   * <tr> <th scope="row">G'Day</th> <td>'G''Day'</td> </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   478
   * <tr> <th scope="row">'G''Day'</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   479
   * <td>'''G''''Day'''</td> </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   480
   * <tr> <th scope="row">I'''M</th> <td>'I''''''M'</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   481
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   482
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   483
   * </tbody>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   484
   * </table>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   485
   * </blockquote>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   486
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   487
   * @implNote JDBC driver implementations may need to provide their own
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   488
   * implementation of this method in order to meet the requirements of the
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   489
   * underlying datasource.
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   490
   * @param val a character string. Not null
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   491
   * @return A string enclosed by single quotes with every single quote
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   492
   * converted to two single quotes. Not null
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   493
   * @throws NullPointerException if {@code val} is {@code null}
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   494
   * @throws IllegalArgumentException if {@code val} cannot be enquoted
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   495
   */
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   496
  default String enquoteLiteral(String val) {
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   497
    return "'" + val.replace("'", "''") + "'";
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   498
  }
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   499
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   500
  /**
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   501
   * Returns a SQL identifier. If {@code identifier} is a simple SQL identifier:
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   502
   * <ul>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   503
   * <li>Return the original value if {@code alwaysQuote} is {@code false}</li>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   504
   * <li>Return a delimited identifier if {@code alwaysQuote} is
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   505
   * {@code true}</li>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   506
   * </ul>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   507
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   508
   * If {@code identifier} is not a simple SQL identifier, {@code identifier}
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   509
   * will be enclosed in double quotes if not already present. If the datasource
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   510
   * does not support double quotes for delimited identifiers, the identifier
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   511
   * should be enclosed by the string returned from
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   512
   * {@link DatabaseMetaData#getIdentifierQuoteString}. If the datasource does
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   513
   * not support delimited identifiers, a
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   514
   * {@code SQLFeatureNotSupportedException} should be thrown.
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   515
   * <p>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   516
   * A {@code SQLException} will be thrown if {@code identifier} contains any
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   517
   * characters invalid in a delimited identifier or the identifier length is
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   518
   * invalid for the datasource.
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   519
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   520
   * @implSpec The default implementation uses the following criteria to
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   521
   * determine a valid simple SQL identifier:
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   522
   * <ul>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   523
   * <li>The string is not enclosed in double quotes</li>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   524
   * <li>The first character is an alphabetic character from a through z, or
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   525
   * from A through Z</li>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   526
   * <li>The name only contains alphanumeric characters or the character
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   527
   * "_"</li>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   528
   * </ul>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   529
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   530
   * The default implementation will throw a {@code SQLException} if:
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   531
   * <ul>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   532
   * <li>{@code identifier} contains a {@code null} character or double quote
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   533
   * and is not a simple SQL identifier.</li>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   534
   * <li>The length of {@code identifier} is less than 1 or greater than 128
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   535
   * characters
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   536
   * </ul>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   537
   * <blockquote>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   538
   * <table class="striped" >
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   539
   * <caption>Examples of the conversion:</caption>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   540
   * <thead>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   541
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   542
   * <th scope="col">identifier</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   543
   * <th scope="col">alwaysQuote</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   544
   * <th scope="col">Result</th></tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   545
   * </thead>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   546
   * <tbody>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   547
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   548
   * <th scope="row">Hello</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   549
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   550
   * <td>Hello</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   551
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   552
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   553
   * <th scope="row">Hello</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   554
   * <td>true</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   555
   * <td>"Hello"</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   556
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   557
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   558
   * <th scope="row">G'Day</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   559
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   560
   * <td>"G'Day"</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   561
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   562
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   563
   * <th scope="row">"Bruce Wayne"</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   564
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   565
   * <td>"Bruce Wayne"</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   566
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   567
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   568
   * <th scope="row">"Bruce Wayne"</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   569
   * <td>true</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   570
   * <td>"Bruce Wayne"</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   571
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   572
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   573
   * <th scope="row">GoodDay$</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   574
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   575
   * <td>"GoodDay$"</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   576
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   577
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   578
   * <th scope="row">Hello"World</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   579
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   580
   * <td>SQLException</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   581
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   582
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   583
   * <th scope="row">"Hello"World"</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   584
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   585
   * <td>SQLException</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   586
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   587
   * </tbody>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   588
   * </table>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   589
   * </blockquote>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   590
   * @implNote JDBC driver implementations may need to provide their own
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   591
   * implementation of this method in order to meet the requirements of the
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   592
   * underlying datasource.
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   593
   * @param identifier a SQL identifier. Not null
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   594
   * @param alwaysQuote indicates if a simple SQL identifier should be returned
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   595
   * as a quoted identifier
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   596
   * @return A simple SQL identifier or a delimited identifier. Not null
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   597
   * @throws NullPointerException if identifier is {@code null}
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   598
   * @throws IllegalArgumentException if {@code identifier} can not be converted 
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   599
   * to a valid identifier
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   600
   */
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   601
  default String enquoteIdentifier(String identifier, boolean alwaysQuote) {
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   602
    int len = identifier.length();
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   603
    if (len < 1 || len > 128) {
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   604
      throw new IllegalArgumentException("Invalid name");
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   605
    }
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   606
    if (Pattern.compile("[\\p{Alpha}][\\p{Alnum}_]*").matcher(identifier).matches()) {
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   607
      return alwaysQuote ? "\"" + identifier + "\"" : identifier;
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   608
    }
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   609
    if (identifier.matches("^\".+\"$")) {
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   610
      identifier = identifier.substring(1, len - 1);
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   611
    }
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   612
    if (Pattern.compile("[^\u0000\"]+").matcher(identifier).matches()) {
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   613
      return "\"" + identifier + "\"";
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   614
    }
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   615
    else {
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   616
      throw new IllegalArgumentException("Invalid name");
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   617
    }
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   618
  }
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   619
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   620
  /**
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   621
   * Retrieves whether {@code identifier} is a simple SQL identifier.
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   622
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   623
   * @implSpec The default implementation uses the following criteria to
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   624
   * determine a valid simple SQL identifier:
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   625
   * <ul>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   626
   * <li>The string is not enclosed in double quotes</li>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   627
   * <li>The first character is an alphabetic character from a through z, or
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   628
   * from A through Z</li>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   629
   * <li>The string only contains alphanumeric characters or the character
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   630
   * "_"</li>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   631
   * <li>The string is between 1 and 128 characters in length inclusive</li>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   632
   * </ul>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   633
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   634
   * <blockquote>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   635
   * <table class="striped" >
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   636
   * <caption>Examples of the conversion:</caption>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   637
   * <thead>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   638
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   639
   * <th scope="col">identifier</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   640
   * <th scope="col">Simple Identifier</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   641
   * </thead>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   642
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   643
   * <tbody>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   644
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   645
   * <th scope="row">Hello</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   646
   * <td>true</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   647
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   648
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   649
   * <th scope="row">G'Day</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   650
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   651
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   652
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   653
   * <th scope="row">"Bruce Wayne"</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   654
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   655
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   656
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   657
   * <th scope="row">GoodDay$</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   658
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   659
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   660
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   661
   * <th scope="row">Hello"World</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   662
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   663
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   664
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   665
   * <th scope="row">"Hello"World"</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   666
   * <td>false</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   667
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   668
   * </tbody>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   669
   * </table>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   670
   * </blockquote>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   671
   * @implNote JDBC driver implementations may need to provide their own
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   672
   * implementation of this method in order to meet the requirements of the
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   673
   * underlying datasource.
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   674
   * @param identifier a SQL identifier. Not null
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   675
   * @return true if a simple SQL identifier, false otherwise
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   676
   * @throws NullPointerException if identifier is {@code null}
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   677
   */
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   678
  default boolean isSimpleIdentifier(String identifier) {
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   679
    int len = identifier.length();
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   680
    return len >= 1 && len <= 128
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   681
            && Pattern.compile("[\\p{Alpha}][\\p{Alnum}_]*").matcher(identifier).matches();
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   682
  }
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   683
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   684
  /**
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   685
   * Returns a {@code String} representing a National Character Set Literal
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   686
   * enclosed in single quotes and prefixed with a upper case letter N. Any
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   687
   * occurrence of a single quote within the string will be replaced by two
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   688
   * single quotes.
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   689
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   690
   * <blockquote>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   691
   * <table class="striped">
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   692
   * <caption>Examples of the conversion:</caption>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   693
   * <thead>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   694
   * <tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   695
   * <th scope="col">Value</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   696
   * <th scope="col">Result</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   697
   * </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   698
   * </thead>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   699
   * <tbody>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   700
   * <tr> <th scope="row">Hello</th> <td>N'Hello'</td> </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   701
   * <tr> <th scope="row">G'Day</th> <td>N'G''Day'</td> </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   702
   * <tr> <th scope="row">'G''Day'</th>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   703
   * <td>N'''G''''Day'''</td> </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   704
   * <tr> <th scope="row">I'''M</th> <td>N'I''''''M'</td>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   705
   * <tr> <th scope="row">N'Hello'</th> <td>N'N''Hello'''</td> </tr>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   706
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   707
   * </tbody>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   708
   * </table>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   709
   * </blockquote>
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   710
   *
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   711
   * @implNote JDBC driver implementations may need to provide their own
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   712
   * implementation of this method in order to meet the requirements of the
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   713
   * underlying datasource. An implementation of enquoteNCharLiteral may accept
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   714
   * a different set of characters than that accepted by the same drivers
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   715
   * implementation of enquoteLiteral.
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   716
   * @param val a character string. Not null
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   717
   * @return the result of replacing every single quote character in the
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   718
   * argument by two single quote characters where this entire result is then
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   719
   * prefixed with 'N'. Not null.
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   720
   * @throws NullPointerException if {@code val} is {@code null}
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   721
   * @throws IllegalArgumentException if {@code val} cannot be enquoted
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   722
   */
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   723
  default String enquoteNCharLiteral(String val) {
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   724
    return "N'" + val.replace("'", "''") + "'";
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   725
  }
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   726
64304e37e9b1 JDK-8188051-branch javadoc updates and added TransactionCompletion.java
lancea
parents: 56824
diff changeset
   727
    // Covariant overrides
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   728
  @Override
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   729
  public OperationGroup<S, T> timeout(Duration minTime);
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   730
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   731
  @Override
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   732
  public OperationGroup<S, T> onError(Consumer<Throwable> handler);
56824
62e92191354d JDK-8188051-branch latest updates
lancea
parents: 56797
diff changeset
   733
  
56380
f06946e00a26 JDK-8188051-branch: add jdk.incubator.adba
lancea
parents:
diff changeset
   734
}