public class ch.qos.logback.classic.db.DBAppender extends ch.qos.logback.core.db.DBAppenderBase<ch.qos.logback.classic.spi.ILoggingEvent>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: ch.qos.logback.classic.db.DBAppender
  super_class: ch.qos.logback.core.db.DBAppenderBase
{
  protected java.lang.String insertPropertiesSQL;
    descriptor: Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED

  protected java.lang.String insertExceptionSQL;
    descriptor: Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED

  protected java.lang.String insertSQL;
    descriptor: Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED

  protected static final java.lang.reflect.Method GET_GENERATED_KEYS_METHOD;
    descriptor: Ljava/lang/reflect/Method;
    flags: (0x001c) ACC_PROTECTED, ACC_STATIC, ACC_FINAL

  private ch.qos.logback.classic.db.names.DBNameResolver dbNameResolver;
    descriptor: Lch/qos/logback/classic/db/names/DBNameResolver;
    flags: (0x0002) ACC_PRIVATE

  static final int TIMESTMP_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  static final int FORMATTED_MESSAGE_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 2

  static final int LOGGER_NAME_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 3

  static final int LEVEL_STRING_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 4

  static final int THREAD_NAME_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 5

  static final int REFERENCE_FLAG_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 6

  static final int ARG0_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 7

  static final int ARG1_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 8

  static final int ARG2_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 9

  static final int ARG3_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 10

  static final int CALLER_FILENAME_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 11

  static final int CALLER_CLASS_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 12

  static final int CALLER_METHOD_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 13

  static final int CALLER_LINE_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 14

  static final int EVENT_ID_INDEX;
    descriptor: I
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: 15

  static final java.lang.StackTraceElement EMPTY_CALLER_DATA;
    descriptor: Ljava/lang/StackTraceElement;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 67
            invokestatic ch.qos.logback.classic.spi.CallerData.naInstance:()Ljava/lang/StackTraceElement;
            putstatic ch.qos.logback.classic.db.DBAppender.EMPTY_CALLER_DATA:Ljava/lang/StackTraceElement;
         1: .line 74
            ldc Ljava/sql/PreparedStatement;
            ldc "getGeneratedKeys"
            aconst_null
            invokevirtual java.lang.Class.getMethod:(Ljava/lang/String;[Ljava/lang/Class;)Ljava/lang/reflect/Method;
            astore 0 /* getGeneratedKeysMethod */
        start local 0 // java.lang.reflect.Method getGeneratedKeysMethod
         2: .line 75
            goto 5
        end local 0 // java.lang.reflect.Method getGeneratedKeysMethod
      StackMap locals:
      StackMap stack: java.lang.Exception
         3: pop
         4: .line 76
            aconst_null
            astore 0 /* getGeneratedKeysMethod */
        start local 0 // java.lang.reflect.Method getGeneratedKeysMethod
         5: .line 78
      StackMap locals: java.lang.reflect.Method
      StackMap stack:
            aload 0 /* getGeneratedKeysMethod */
            putstatic ch.qos.logback.classic.db.DBAppender.GET_GENERATED_KEYS_METHOD:Ljava/lang/reflect/Method;
        end local 0 // java.lang.reflect.Method getGeneratedKeysMethod
         6: .line 79
            return
      LocalVariableTable:
        Start  End  Slot                    Name  Signature
            2    3     0  getGeneratedKeysMethod  Ljava/lang/reflect/Method;
            5    6     0  getGeneratedKeysMethod  Ljava/lang/reflect/Method;
      Exception table:
        from    to  target  type
           1     2       3  Class java.lang.Exception

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.classic.db.DBAppender this
         0: .line 43
            aload 0 /* this */
            invokespecial ch.qos.logback.core.db.DBAppenderBase.<init>:()V
            return
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/classic/db/DBAppender;

  public void setDbNameResolver(ch.qos.logback.classic.db.names.DBNameResolver);
    descriptor: (Lch/qos/logback/classic/db/names/DBNameResolver;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // ch.qos.logback.classic.db.names.DBNameResolver dbNameResolver
         0: .line 82
            aload 0 /* this */
            aload 1 /* dbNameResolver */
            putfield ch.qos.logback.classic.db.DBAppender.dbNameResolver:Lch/qos/logback/classic/db/names/DBNameResolver;
         1: .line 83
            return
        end local 1 // ch.qos.logback.classic.db.names.DBNameResolver dbNameResolver
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lch/qos/logback/classic/db/DBAppender;
            0    2     1  dbNameResolver  Lch/qos/logback/classic/db/names/DBNameResolver;
    MethodParameters:
                Name  Flags
      dbNameResolver  

  public void start();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // ch.qos.logback.classic.db.DBAppender this
         0: .line 87
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.dbNameResolver:Lch/qos/logback/classic/db/names/DBNameResolver;
            ifnonnull 2
         1: .line 88
            aload 0 /* this */
            new ch.qos.logback.classic.db.names.DefaultDBNameResolver
            dup
            invokespecial ch.qos.logback.classic.db.names.DefaultDBNameResolver.<init>:()V
            putfield ch.qos.logback.classic.db.DBAppender.dbNameResolver:Lch/qos/logback/classic/db/names/DBNameResolver;
         2: .line 89
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.dbNameResolver:Lch/qos/logback/classic/db/names/DBNameResolver;
            invokestatic ch.qos.logback.classic.db.SQLBuilder.buildInsertExceptionSQL:(Lch/qos/logback/classic/db/names/DBNameResolver;)Ljava/lang/String;
            putfield ch.qos.logback.classic.db.DBAppender.insertExceptionSQL:Ljava/lang/String;
         3: .line 90
            aload 0 /* this */
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.dbNameResolver:Lch/qos/logback/classic/db/names/DBNameResolver;
            invokestatic ch.qos.logback.classic.db.SQLBuilder.buildInsertPropertiesSQL:(Lch/qos/logback/classic/db/names/DBNameResolver;)Ljava/lang/String;
            putfield ch.qos.logback.classic.db.DBAppender.insertPropertiesSQL:Ljava/lang/String;
         4: .line 91
            aload 0 /* this */
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.dbNameResolver:Lch/qos/logback/classic/db/names/DBNameResolver;
            invokestatic ch.qos.logback.classic.db.SQLBuilder.buildInsertSQL:(Lch/qos/logback/classic/db/names/DBNameResolver;)Ljava/lang/String;
            putfield ch.qos.logback.classic.db.DBAppender.insertSQL:Ljava/lang/String;
         5: .line 92
            aload 0 /* this */
            invokespecial ch.qos.logback.core.db.DBAppenderBase.start:()V
         6: .line 93
            return
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lch/qos/logback/classic/db/DBAppender;

  protected void subAppend(ch.qos.logback.classic.spi.ILoggingEvent, java.sql.Connection, java.sql.PreparedStatement);
    descriptor: (Lch/qos/logback/classic/spi/ILoggingEvent;Ljava/sql/Connection;Ljava/sql/PreparedStatement;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=5, args_size=4
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // ch.qos.logback.classic.spi.ILoggingEvent event
        start local 2 // java.sql.Connection connection
        start local 3 // java.sql.PreparedStatement insertStatement
         0: .line 98
            aload 0 /* this */
            aload 3 /* insertStatement */
            aload 1 /* event */
            invokevirtual ch.qos.logback.classic.db.DBAppender.bindLoggingEventWithInsertStatement:(Ljava/sql/PreparedStatement;Lch/qos/logback/classic/spi/ILoggingEvent;)V
         1: .line 99
            aload 0 /* this */
            aload 3 /* insertStatement */
            aload 1 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getArgumentArray:()[Ljava/lang/Object;
            invokevirtual ch.qos.logback.classic.db.DBAppender.bindLoggingEventArgumentsWithPreparedStatement:(Ljava/sql/PreparedStatement;[Ljava/lang/Object;)V
         2: .line 102
            aload 0 /* this */
            aload 3 /* insertStatement */
            aload 1 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getCallerData:()[Ljava/lang/StackTraceElement;
            invokevirtual ch.qos.logback.classic.db.DBAppender.bindCallerDataWithPreparedStatement:(Ljava/sql/PreparedStatement;[Ljava/lang/StackTraceElement;)V
         3: .line 104
            aload 3 /* insertStatement */
            invokeinterface java.sql.PreparedStatement.executeUpdate:()I
            istore 4 /* updateCount */
        start local 4 // int updateCount
         4: .line 105
            iload 4 /* updateCount */
            iconst_1
            if_icmpeq 6
         5: .line 106
            aload 0 /* this */
            ldc "Failed to insert loggingEvent"
            invokevirtual ch.qos.logback.classic.db.DBAppender.addWarn:(Ljava/lang/String;)V
         6: .line 108
      StackMap locals: int
      StackMap stack:
            return
        end local 4 // int updateCount
        end local 3 // java.sql.PreparedStatement insertStatement
        end local 2 // java.sql.Connection connection
        end local 1 // ch.qos.logback.classic.spi.ILoggingEvent event
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    7     0             this  Lch/qos/logback/classic/db/DBAppender;
            0    7     1            event  Lch/qos/logback/classic/spi/ILoggingEvent;
            0    7     2       connection  Ljava/sql/Connection;
            0    7     3  insertStatement  Ljava/sql/PreparedStatement;
            4    7     4      updateCount  I
    Exceptions:
      throws java.lang.Throwable
    MethodParameters:
                 Name  Flags
      event            
      connection       
      insertStatement  

  protected void secondarySubAppend(ch.qos.logback.classic.spi.ILoggingEvent, java.sql.Connection, long);
    descriptor: (Lch/qos/logback/classic/spi/ILoggingEvent;Ljava/sql/Connection;J)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // ch.qos.logback.classic.spi.ILoggingEvent event
        start local 2 // java.sql.Connection connection
        start local 3 // long eventId
         0: .line 111
            aload 0 /* this */
            aload 1 /* event */
            invokevirtual ch.qos.logback.classic.db.DBAppender.mergePropertyMaps:(Lch/qos/logback/classic/spi/ILoggingEvent;)Ljava/util/Map;
            astore 5 /* mergedMap */
        start local 5 // java.util.Map mergedMap
         1: .line 112
            aload 0 /* this */
            aload 5 /* mergedMap */
            aload 2 /* connection */
            lload 3 /* eventId */
            invokevirtual ch.qos.logback.classic.db.DBAppender.insertProperties:(Ljava/util/Map;Ljava/sql/Connection;J)V
         2: .line 114
            aload 1 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getThrowableProxy:()Lch/qos/logback/classic/spi/IThrowableProxy;
            ifnull 4
         3: .line 115
            aload 0 /* this */
            aload 1 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getThrowableProxy:()Lch/qos/logback/classic/spi/IThrowableProxy;
            aload 2 /* connection */
            lload 3 /* eventId */
            invokevirtual ch.qos.logback.classic.db.DBAppender.insertThrowable:(Lch/qos/logback/classic/spi/IThrowableProxy;Ljava/sql/Connection;J)V
         4: .line 117
      StackMap locals: java.util.Map
      StackMap stack:
            return
        end local 5 // java.util.Map mergedMap
        end local 3 // long eventId
        end local 2 // java.sql.Connection connection
        end local 1 // ch.qos.logback.classic.spi.ILoggingEvent event
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    5     0        this  Lch/qos/logback/classic/db/DBAppender;
            0    5     1       event  Lch/qos/logback/classic/spi/ILoggingEvent;
            0    5     2  connection  Ljava/sql/Connection;
            0    5     3     eventId  J
            1    5     5   mergedMap  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
    Exceptions:
      throws java.lang.Throwable
    MethodParameters:
            Name  Flags
      event       
      connection  
      eventId     

  void bindLoggingEventWithInsertStatement(java.sql.PreparedStatement, ch.qos.logback.classic.spi.ILoggingEvent);
    descriptor: (Ljava/sql/PreparedStatement;Lch/qos/logback/classic/spi/ILoggingEvent;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // java.sql.PreparedStatement stmt
        start local 2 // ch.qos.logback.classic.spi.ILoggingEvent event
         0: .line 120
            aload 1 /* stmt */
            iconst_1
            aload 2 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getTimeStamp:()J
            invokeinterface java.sql.PreparedStatement.setLong:(IJ)V
         1: .line 121
            aload 1 /* stmt */
            iconst_2
            aload 2 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getFormattedMessage:()Ljava/lang/String;
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         2: .line 122
            aload 1 /* stmt */
            iconst_3
            aload 2 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getLoggerName:()Ljava/lang/String;
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         3: .line 123
            aload 1 /* stmt */
            iconst_4
            aload 2 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getLevel:()Lch/qos/logback/classic/Level;
            invokevirtual ch.qos.logback.classic.Level.toString:()Ljava/lang/String;
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         4: .line 124
            aload 1 /* stmt */
            iconst_5
            aload 2 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getThreadName:()Ljava/lang/String;
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         5: .line 125
            aload 1 /* stmt */
            bipush 6
            aload 2 /* event */
            invokestatic ch.qos.logback.classic.db.DBHelper.computeReferenceMask:(Lch/qos/logback/classic/spi/ILoggingEvent;)S
            invokeinterface java.sql.PreparedStatement.setShort:(IS)V
         6: .line 126
            return
        end local 2 // ch.qos.logback.classic.spi.ILoggingEvent event
        end local 1 // java.sql.PreparedStatement stmt
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    7     0   this  Lch/qos/logback/classic/db/DBAppender;
            0    7     1   stmt  Ljava/sql/PreparedStatement;
            0    7     2  event  Lch/qos/logback/classic/spi/ILoggingEvent;
    Exceptions:
      throws java.sql.SQLException
    MethodParameters:
       Name  Flags
      stmt   
      event  

  void bindLoggingEventArgumentsWithPreparedStatement(java.sql.PreparedStatement, java.lang.Object[]);
    descriptor: (Ljava/sql/PreparedStatement;[Ljava/lang/Object;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // java.sql.PreparedStatement stmt
        start local 2 // java.lang.Object[] argArray
         0: .line 130
            aload 2 /* argArray */
            ifnull 1
            aload 2 /* argArray */
            arraylength
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: istore 3 /* arrayLen */
        start local 3 // int arrayLen
         3: .line 132
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         4: goto 7
         5: .line 133
      StackMap locals: int int
      StackMap stack:
            aload 1 /* stmt */
            bipush 7
            iload 4 /* i */
            iadd
            aload 0 /* this */
            aload 2 /* argArray */
            iload 4 /* i */
            aaload
            invokevirtual ch.qos.logback.classic.db.DBAppender.asStringTruncatedTo254:(Ljava/lang/Object;)Ljava/lang/String;
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         6: .line 132
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
         7: iload 4 /* i */
            iload 3 /* arrayLen */
            if_icmpge 8
            iload 4 /* i */
            iconst_4
            if_icmplt 5
        end local 4 // int i
         8: .line 135
      StackMap locals:
      StackMap stack:
            iload 3 /* arrayLen */
            iconst_4
            if_icmpge 14
         9: .line 136
            iload 3 /* arrayLen */
            istore 4 /* i */
        start local 4 // int i
        10: goto 13
        11: .line 137
      StackMap locals: int
      StackMap stack:
            aload 1 /* stmt */
            bipush 7
            iload 4 /* i */
            iadd
            aconst_null
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
        12: .line 136
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
        13: iload 4 /* i */
            iconst_4
            if_icmplt 11
        end local 4 // int i
        14: .line 140
      StackMap locals:
      StackMap stack:
            return
        end local 3 // int arrayLen
        end local 2 // java.lang.Object[] argArray
        end local 1 // java.sql.PreparedStatement stmt
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   15     0      this  Lch/qos/logback/classic/db/DBAppender;
            0   15     1      stmt  Ljava/sql/PreparedStatement;
            0   15     2  argArray  [Ljava/lang/Object;
            3   15     3  arrayLen  I
            4    8     4         i  I
           10   14     4         i  I
    Exceptions:
      throws java.sql.SQLException
    MethodParameters:
          Name  Flags
      stmt      
      argArray  

  java.lang.String asStringTruncatedTo254(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // java.lang.Object o
         0: .line 143
            aconst_null
            astore 2 /* s */
        start local 2 // java.lang.String s
         1: .line 144
            aload 1 /* o */
            ifnull 3
         2: .line 145
            aload 1 /* o */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            astore 2 /* s */
         3: .line 148
      StackMap locals: java.lang.String
      StackMap stack:
            aload 2 /* s */
            ifnonnull 5
         4: .line 149
            aconst_null
            areturn
         5: .line 151
      StackMap locals:
      StackMap stack:
            aload 2 /* s */
            invokevirtual java.lang.String.length:()I
            sipush 254
            if_icmpgt 7
         6: .line 152
            aload 2 /* s */
            areturn
         7: .line 154
      StackMap locals:
      StackMap stack:
            aload 2 /* s */
            iconst_0
            sipush 254
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            areturn
        end local 2 // java.lang.String s
        end local 1 // java.lang.Object o
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lch/qos/logback/classic/db/DBAppender;
            0    8     1     o  Ljava/lang/Object;
            1    8     2     s  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      o     

  void bindCallerDataWithPreparedStatement(java.sql.PreparedStatement, java.lang.StackTraceElement[]);
    descriptor: (Ljava/sql/PreparedStatement;[Ljava/lang/StackTraceElement;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // java.sql.PreparedStatement stmt
        start local 2 // java.lang.StackTraceElement[] callerDataArray
         0: .line 160
            aload 0 /* this */
            aload 2 /* callerDataArray */
            invokevirtual ch.qos.logback.classic.db.DBAppender.extractFirstCaller:([Ljava/lang/StackTraceElement;)Ljava/lang/StackTraceElement;
            astore 3 /* caller */
        start local 3 // java.lang.StackTraceElement caller
         1: .line 162
            aload 1 /* stmt */
            bipush 11
            aload 3 /* caller */
            invokevirtual java.lang.StackTraceElement.getFileName:()Ljava/lang/String;
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         2: .line 163
            aload 1 /* stmt */
            bipush 12
            aload 3 /* caller */
            invokevirtual java.lang.StackTraceElement.getClassName:()Ljava/lang/String;
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         3: .line 164
            aload 1 /* stmt */
            bipush 13
            aload 3 /* caller */
            invokevirtual java.lang.StackTraceElement.getMethodName:()Ljava/lang/String;
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         4: .line 165
            aload 1 /* stmt */
            bipush 14
            aload 3 /* caller */
            invokevirtual java.lang.StackTraceElement.getLineNumber:()I
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         5: .line 166
            return
        end local 3 // java.lang.StackTraceElement caller
        end local 2 // java.lang.StackTraceElement[] callerDataArray
        end local 1 // java.sql.PreparedStatement stmt
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    6     0             this  Lch/qos/logback/classic/db/DBAppender;
            0    6     1             stmt  Ljava/sql/PreparedStatement;
            0    6     2  callerDataArray  [Ljava/lang/StackTraceElement;
            1    6     3           caller  Ljava/lang/StackTraceElement;
    Exceptions:
      throws java.sql.SQLException
    MethodParameters:
                 Name  Flags
      stmt             
      callerDataArray  

  private java.lang.StackTraceElement extractFirstCaller(java.lang.StackTraceElement[]);
    descriptor: ([Ljava/lang/StackTraceElement;)Ljava/lang/StackTraceElement;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // java.lang.StackTraceElement[] callerDataArray
         0: .line 169
            getstatic ch.qos.logback.classic.db.DBAppender.EMPTY_CALLER_DATA:Ljava/lang/StackTraceElement;
            astore 2 /* caller */
        start local 2 // java.lang.StackTraceElement caller
         1: .line 170
            aload 0 /* this */
            aload 1 /* callerDataArray */
            invokevirtual ch.qos.logback.classic.db.DBAppender.hasAtLeastOneNonNullElement:([Ljava/lang/StackTraceElement;)Z
            ifeq 3
         2: .line 171
            aload 1 /* callerDataArray */
            iconst_0
            aaload
            astore 2 /* caller */
         3: .line 172
      StackMap locals: java.lang.StackTraceElement
      StackMap stack:
            aload 2 /* caller */
            areturn
        end local 2 // java.lang.StackTraceElement caller
        end local 1 // java.lang.StackTraceElement[] callerDataArray
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    4     0             this  Lch/qos/logback/classic/db/DBAppender;
            0    4     1  callerDataArray  [Ljava/lang/StackTraceElement;
            1    4     2           caller  Ljava/lang/StackTraceElement;
    MethodParameters:
                 Name  Flags
      callerDataArray  

  private boolean hasAtLeastOneNonNullElement(java.lang.StackTraceElement[]);
    descriptor: ([Ljava/lang/StackTraceElement;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // java.lang.StackTraceElement[] callerDataArray
         0: .line 176
            aload 1 /* callerDataArray */
            ifnull 1
            aload 1 /* callerDataArray */
            arraylength
            ifle 1
            aload 1 /* callerDataArray */
            iconst_0
            aaload
            ifnull 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 1 // java.lang.StackTraceElement[] callerDataArray
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    2     0             this  Lch/qos/logback/classic/db/DBAppender;
            0    2     1  callerDataArray  [Ljava/lang/StackTraceElement;
    MethodParameters:
                 Name  Flags
      callerDataArray  

  java.util.Map<java.lang.String, java.lang.String> mergePropertyMaps(ch.qos.logback.classic.spi.ILoggingEvent);
    descriptor: (Lch/qos/logback/classic/spi/ILoggingEvent;)Ljava/util/Map;
    flags: (0x0000) 
    Code:
      stack=2, locals=5, args_size=2
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // ch.qos.logback.classic.spi.ILoggingEvent event
         0: .line 180
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 2 /* mergedMap */
        start local 2 // java.util.Map mergedMap
         1: .line 184
            aload 1 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getLoggerContextVO:()Lch/qos/logback/classic/spi/LoggerContextVO;
            invokevirtual ch.qos.logback.classic.spi.LoggerContextVO.getPropertyMap:()Ljava/util/Map;
            astore 3 /* loggerContextMap */
        start local 3 // java.util.Map loggerContextMap
         2: .line 185
            aload 1 /* event */
            invokeinterface ch.qos.logback.classic.spi.ILoggingEvent.getMDCPropertyMap:()Ljava/util/Map;
            astore 4 /* mdcMap */
        start local 4 // java.util.Map mdcMap
         3: .line 186
            aload 3 /* loggerContextMap */
            ifnull 5
         4: .line 187
            aload 2 /* mergedMap */
            aload 3 /* loggerContextMap */
            invokeinterface java.util.Map.putAll:(Ljava/util/Map;)V
         5: .line 189
      StackMap locals: java.util.Map java.util.Map java.util.Map
      StackMap stack:
            aload 4 /* mdcMap */
            ifnull 7
         6: .line 190
            aload 2 /* mergedMap */
            aload 4 /* mdcMap */
            invokeinterface java.util.Map.putAll:(Ljava/util/Map;)V
         7: .line 193
      StackMap locals:
      StackMap stack:
            aload 2 /* mergedMap */
            areturn
        end local 4 // java.util.Map mdcMap
        end local 3 // java.util.Map loggerContextMap
        end local 2 // java.util.Map mergedMap
        end local 1 // ch.qos.logback.classic.spi.ILoggingEvent event
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    8     0              this  Lch/qos/logback/classic/db/DBAppender;
            0    8     1             event  Lch/qos/logback/classic/spi/ILoggingEvent;
            1    8     2         mergedMap  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
            2    8     3  loggerContextMap  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
            3    8     4            mdcMap  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
    Signature: (Lch/qos/logback/classic/spi/ILoggingEvent;)Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
    MethodParameters:
       Name  Flags
      event  

  protected java.lang.reflect.Method getGeneratedKeysMethod();
    descriptor: ()Ljava/lang/reflect/Method;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.classic.db.DBAppender this
         0: .line 198
            getstatic ch.qos.logback.classic.db.DBAppender.GET_GENERATED_KEYS_METHOD:Ljava/lang/reflect/Method;
            areturn
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/classic/db/DBAppender;

  protected java.lang.String getInsertSQL();
    descriptor: ()Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // ch.qos.logback.classic.db.DBAppender this
         0: .line 203
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.insertSQL:Ljava/lang/String;
            areturn
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lch/qos/logback/classic/db/DBAppender;

  protected void insertProperties(java.util.Map<java.lang.String, java.lang.String>, java.sql.Connection, );
    descriptor: (Ljava/util/Map;Ljava/sql/Connection;J)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=11, args_size=4
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // java.util.Map mergedMap
        start local 2 // java.sql.Connection connection
        start local 3 // long eventId
         0: .line 207
            aload 1 /* mergedMap */
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            astore 5 /* propertiesKeys */
        start local 5 // java.util.Set propertiesKeys
         1: .line 208
            aload 5 /* propertiesKeys */
            invokeinterface java.util.Set.size:()I
            ifle 22
         2: .line 209
            aconst_null
            astore 6 /* insertPropertiesStatement */
        start local 6 // java.sql.PreparedStatement insertPropertiesStatement
         3: .line 211
            aload 2 /* connection */
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.insertPropertiesSQL:Ljava/lang/String;
            invokeinterface java.sql.Connection.prepareStatement:(Ljava/lang/String;)Ljava/sql/PreparedStatement;
            astore 6 /* insertPropertiesStatement */
         4: .line 213
            aload 5 /* propertiesKeys */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 8
            goto 14
      StackMap locals: ch.qos.logback.classic.db.DBAppender java.util.Map java.sql.Connection long java.util.Set java.sql.PreparedStatement top java.util.Iterator
      StackMap stack:
         5: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 7 /* key */
        start local 7 // java.lang.String key
         6: .line 214
            aload 1 /* mergedMap */
            aload 7 /* key */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 9 /* value */
        start local 9 // java.lang.String value
         7: .line 216
            aload 6 /* insertPropertiesStatement */
            iconst_1
            lload 3 /* eventId */
            invokeinterface java.sql.PreparedStatement.setLong:(IJ)V
         8: .line 217
            aload 6 /* insertPropertiesStatement */
            iconst_2
            aload 7 /* key */
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         9: .line 218
            aload 6 /* insertPropertiesStatement */
            iconst_3
            aload 9 /* value */
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
        10: .line 220
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.cnxSupportsBatchUpdates:Z
            ifeq 13
        11: .line 221
            aload 6 /* insertPropertiesStatement */
            invokeinterface java.sql.PreparedStatement.addBatch:()V
        12: .line 222
            goto 14
        13: .line 223
      StackMap locals: ch.qos.logback.classic.db.DBAppender java.util.Map java.sql.Connection long java.util.Set java.sql.PreparedStatement java.lang.String java.util.Iterator java.lang.String
      StackMap stack:
            aload 6 /* insertPropertiesStatement */
            invokeinterface java.sql.PreparedStatement.execute:()Z
            pop
        end local 9 // java.lang.String value
        end local 7 // java.lang.String key
        14: .line 213
      StackMap locals: ch.qos.logback.classic.db.DBAppender java.util.Map java.sql.Connection long java.util.Set java.sql.PreparedStatement top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        15: .line 227
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.cnxSupportsBatchUpdates:Z
            ifeq 21
        16: .line 228
            aload 6 /* insertPropertiesStatement */
            invokeinterface java.sql.PreparedStatement.executeBatch:()[I
            pop
        17: .line 230
            goto 21
      StackMap locals: ch.qos.logback.classic.db.DBAppender java.util.Map java.sql.Connection long java.util.Set java.sql.PreparedStatement
      StackMap stack: java.lang.Throwable
        18: astore 10
        19: .line 231
            aload 6 /* insertPropertiesStatement */
            invokestatic ch.qos.logback.core.db.DBHelper.closeStatement:(Ljava/sql/Statement;)V
        20: .line 232
            aload 10
            athrow
        21: .line 231
      StackMap locals:
      StackMap stack:
            aload 6 /* insertPropertiesStatement */
            invokestatic ch.qos.logback.core.db.DBHelper.closeStatement:(Ljava/sql/Statement;)V
        end local 6 // java.sql.PreparedStatement insertPropertiesStatement
        22: .line 234
      StackMap locals:
      StackMap stack:
            return
        end local 5 // java.util.Set propertiesKeys
        end local 3 // long eventId
        end local 2 // java.sql.Connection connection
        end local 1 // java.util.Map mergedMap
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot                       Name  Signature
            0   23     0                       this  Lch/qos/logback/classic/db/DBAppender;
            0   23     1                  mergedMap  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
            0   23     2                 connection  Ljava/sql/Connection;
            0   23     3                    eventId  J
            1   23     5             propertiesKeys  Ljava/util/Set<Ljava/lang/String;>;
            3   22     6  insertPropertiesStatement  Ljava/sql/PreparedStatement;
            6   14     7                        key  Ljava/lang/String;
            7   14     9                      value  Ljava/lang/String;
      Exception table:
        from    to  target  type
           3    18      18  any
    Exceptions:
      throws java.sql.SQLException
    Signature: (Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;Ljava/sql/Connection;J)V
    MethodParameters:
            Name  Flags
      mergedMap   
      connection  
      eventId     

  void updateExceptionStatement(java.sql.PreparedStatement, java.lang.String, short, long);
    descriptor: (Ljava/sql/PreparedStatement;Ljava/lang/String;SJ)V
    flags: (0x0000) 
    Code:
      stack=4, locals=6, args_size=5
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // java.sql.PreparedStatement exceptionStatement
        start local 2 // java.lang.String txt
        start local 3 // short i
        start local 4 // long eventId
         0: .line 241
            aload 1 /* exceptionStatement */
            iconst_1
            lload 4 /* eventId */
            invokeinterface java.sql.PreparedStatement.setLong:(IJ)V
         1: .line 242
            aload 1 /* exceptionStatement */
            iconst_2
            iload 3 /* i */
            invokeinterface java.sql.PreparedStatement.setShort:(IS)V
         2: .line 243
            aload 1 /* exceptionStatement */
            iconst_3
            aload 2 /* txt */
            invokeinterface java.sql.PreparedStatement.setString:(ILjava/lang/String;)V
         3: .line 244
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.cnxSupportsBatchUpdates:Z
            ifeq 6
         4: .line 245
            aload 1 /* exceptionStatement */
            invokeinterface java.sql.PreparedStatement.addBatch:()V
         5: .line 246
            goto 7
         6: .line 247
      StackMap locals:
      StackMap stack:
            aload 1 /* exceptionStatement */
            invokeinterface java.sql.PreparedStatement.execute:()Z
            pop
         7: .line 249
      StackMap locals:
      StackMap stack:
            return
        end local 4 // long eventId
        end local 3 // short i
        end local 2 // java.lang.String txt
        end local 1 // java.sql.PreparedStatement exceptionStatement
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    8     0                this  Lch/qos/logback/classic/db/DBAppender;
            0    8     1  exceptionStatement  Ljava/sql/PreparedStatement;
            0    8     2                 txt  Ljava/lang/String;
            0    8     3                   i  S
            0    8     4             eventId  J
    Exceptions:
      throws java.sql.SQLException
    MethodParameters:
                    Name  Flags
      exceptionStatement  
      txt                 
      i                   
      eventId             

  short buildExceptionStatement(ch.qos.logback.classic.spi.IThrowableProxy, short, java.sql.PreparedStatement, long);
    descriptor: (Lch/qos/logback/classic/spi/IThrowableProxy;SLjava/sql/PreparedStatement;J)S
    flags: (0x0000) 
    Code:
      stack=6, locals=11, args_size=5
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // ch.qos.logback.classic.spi.IThrowableProxy tp
        start local 2 // short baseIndex
        start local 3 // java.sql.PreparedStatement insertExceptionStatement
        start local 4 // long eventId
         0: .line 253
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 6 /* buf */
        start local 6 // java.lang.StringBuilder buf
         1: .line 254
            aload 6 /* buf */
            aload 1 /* tp */
            invokestatic ch.qos.logback.classic.spi.ThrowableProxyUtil.subjoinFirstLine:(Ljava/lang/StringBuilder;Lch/qos/logback/classic/spi/IThrowableProxy;)V
         2: .line 255
            aload 0 /* this */
            aload 3 /* insertExceptionStatement */
            aload 6 /* buf */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iload 2 /* baseIndex */
            dup
            iconst_1
            iadd
            i2s
            istore 2 /* baseIndex */
            lload 4 /* eventId */
            invokevirtual ch.qos.logback.classic.db.DBAppender.updateExceptionStatement:(Ljava/sql/PreparedStatement;Ljava/lang/String;SJ)V
         3: .line 257
            aload 1 /* tp */
            invokeinterface ch.qos.logback.classic.spi.IThrowableProxy.getCommonFrames:()I
            istore 7 /* commonFrames */
        start local 7 // int commonFrames
         4: .line 258
            aload 1 /* tp */
            invokeinterface ch.qos.logback.classic.spi.IThrowableProxy.getStackTraceElementProxyArray:()[Lch/qos/logback/classic/spi/StackTraceElementProxy;
            astore 8 /* stepArray */
        start local 8 // ch.qos.logback.classic.spi.StackTraceElementProxy[] stepArray
         5: .line 259
            iconst_0
            istore 9 /* i */
        start local 9 // int i
         6: goto 12
         7: .line 260
      StackMap locals: ch.qos.logback.classic.db.DBAppender ch.qos.logback.classic.spi.IThrowableProxy int java.sql.PreparedStatement long java.lang.StringBuilder int ch.qos.logback.classic.spi.StackTraceElementProxy[] int
      StackMap stack:
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 10 /* sb */
        start local 10 // java.lang.StringBuilder sb
         8: .line 261
            aload 10 /* sb */
            bipush 9
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         9: .line 262
            aload 10 /* sb */
            aload 8 /* stepArray */
            iload 9 /* i */
            aaload
            invokestatic ch.qos.logback.classic.spi.ThrowableProxyUtil.subjoinSTEP:(Ljava/lang/StringBuilder;Lch/qos/logback/classic/spi/StackTraceElementProxy;)V
        10: .line 263
            aload 0 /* this */
            aload 3 /* insertExceptionStatement */
            aload 10 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iload 2 /* baseIndex */
            dup
            iconst_1
            iadd
            i2s
            istore 2 /* baseIndex */
            lload 4 /* eventId */
            invokevirtual ch.qos.logback.classic.db.DBAppender.updateExceptionStatement:(Ljava/sql/PreparedStatement;Ljava/lang/String;SJ)V
        end local 10 // java.lang.StringBuilder sb
        11: .line 259
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
        12: iload 9 /* i */
            aload 8 /* stepArray */
            arraylength
            iload 7 /* commonFrames */
            isub
            if_icmplt 7
        end local 9 // int i
        13: .line 266
            iload 7 /* commonFrames */
            ifle 17
        14: .line 267
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 9 /* sb */
        start local 9 // java.lang.StringBuilder sb
        15: .line 268
            aload 9 /* sb */
            bipush 9
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            ldc "... "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 7 /* commonFrames */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " common frames omitted"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        16: .line 269
            aload 0 /* this */
            aload 3 /* insertExceptionStatement */
            aload 9 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iload 2 /* baseIndex */
            dup
            iconst_1
            iadd
            i2s
            istore 2 /* baseIndex */
            lload 4 /* eventId */
            invokevirtual ch.qos.logback.classic.db.DBAppender.updateExceptionStatement:(Ljava/sql/PreparedStatement;Ljava/lang/String;SJ)V
        end local 9 // java.lang.StringBuilder sb
        17: .line 272
      StackMap locals:
      StackMap stack:
            iload 2 /* baseIndex */
            ireturn
        end local 8 // ch.qos.logback.classic.spi.StackTraceElementProxy[] stepArray
        end local 7 // int commonFrames
        end local 6 // java.lang.StringBuilder buf
        end local 4 // long eventId
        end local 3 // java.sql.PreparedStatement insertExceptionStatement
        end local 2 // short baseIndex
        end local 1 // ch.qos.logback.classic.spi.IThrowableProxy tp
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot                      Name  Signature
            0   18     0                      this  Lch/qos/logback/classic/db/DBAppender;
            0   18     1                        tp  Lch/qos/logback/classic/spi/IThrowableProxy;
            0   18     2                 baseIndex  S
            0   18     3  insertExceptionStatement  Ljava/sql/PreparedStatement;
            0   18     4                   eventId  J
            1   18     6                       buf  Ljava/lang/StringBuilder;
            4   18     7              commonFrames  I
            5   18     8                 stepArray  [Lch/qos/logback/classic/spi/StackTraceElementProxy;
            6   13     9                         i  I
            8   11    10                        sb  Ljava/lang/StringBuilder;
           15   17     9                        sb  Ljava/lang/StringBuilder;
    Exceptions:
      throws java.sql.SQLException
    MethodParameters:
                          Name  Flags
      tp                        
      baseIndex                 
      insertExceptionStatement  
      eventId                   

  protected void insertThrowable(ch.qos.logback.classic.spi.IThrowableProxy, java.sql.Connection, long);
    descriptor: (Lch/qos/logback/classic/spi/IThrowableProxy;Ljava/sql/Connection;J)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=8, args_size=4
        start local 0 // ch.qos.logback.classic.db.DBAppender this
        start local 1 // ch.qos.logback.classic.spi.IThrowableProxy tp
        start local 2 // java.sql.Connection connection
        start local 3 // long eventId
         0: .line 277
            aconst_null
            astore 5 /* exceptionStatement */
        start local 5 // java.sql.PreparedStatement exceptionStatement
         1: .line 279
            aload 2 /* connection */
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.insertExceptionSQL:Ljava/lang/String;
            invokeinterface java.sql.Connection.prepareStatement:(Ljava/lang/String;)Ljava/sql/PreparedStatement;
            astore 5 /* exceptionStatement */
         2: .line 281
            iconst_0
            istore 6 /* baseIndex */
        start local 6 // short baseIndex
         3: .line 282
            goto 6
         4: .line 283
      StackMap locals: java.sql.PreparedStatement int
      StackMap stack:
            aload 0 /* this */
            aload 1 /* tp */
            iload 6 /* baseIndex */
            aload 5 /* exceptionStatement */
            lload 3 /* eventId */
            invokevirtual ch.qos.logback.classic.db.DBAppender.buildExceptionStatement:(Lch/qos/logback/classic/spi/IThrowableProxy;SLjava/sql/PreparedStatement;J)S
            istore 6 /* baseIndex */
         5: .line 284
            aload 1 /* tp */
            invokeinterface ch.qos.logback.classic.spi.IThrowableProxy.getCause:()Lch/qos/logback/classic/spi/IThrowableProxy;
            astore 1 /* tp */
         6: .line 282
      StackMap locals:
      StackMap stack:
            aload 1 /* tp */
            ifnonnull 4
         7: .line 287
            aload 0 /* this */
            getfield ch.qos.logback.classic.db.DBAppender.cnxSupportsBatchUpdates:Z
            ifeq 13
         8: .line 288
            aload 5 /* exceptionStatement */
            invokeinterface java.sql.PreparedStatement.executeBatch:()[I
            pop
        end local 6 // short baseIndex
         9: .line 290
            goto 13
      StackMap locals: ch.qos.logback.classic.db.DBAppender ch.qos.logback.classic.spi.IThrowableProxy java.sql.Connection long java.sql.PreparedStatement
      StackMap stack: java.lang.Throwable
        10: astore 7
        11: .line 291
            aload 5 /* exceptionStatement */
            invokestatic ch.qos.logback.core.db.DBHelper.closeStatement:(Ljava/sql/Statement;)V
        12: .line 292
            aload 7
            athrow
        13: .line 291
      StackMap locals:
      StackMap stack:
            aload 5 /* exceptionStatement */
            invokestatic ch.qos.logback.core.db.DBHelper.closeStatement:(Ljava/sql/Statement;)V
        14: .line 294
            return
        end local 5 // java.sql.PreparedStatement exceptionStatement
        end local 3 // long eventId
        end local 2 // java.sql.Connection connection
        end local 1 // ch.qos.logback.classic.spi.IThrowableProxy tp
        end local 0 // ch.qos.logback.classic.db.DBAppender this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   15     0                this  Lch/qos/logback/classic/db/DBAppender;
            0   15     1                  tp  Lch/qos/logback/classic/spi/IThrowableProxy;
            0   15     2          connection  Ljava/sql/Connection;
            0   15     3             eventId  J
            1   15     5  exceptionStatement  Ljava/sql/PreparedStatement;
            3    9     6           baseIndex  S
      Exception table:
        from    to  target  type
           1    10      10  any
    Exceptions:
      throws java.sql.SQLException
    MethodParameters:
            Name  Flags
      tp          
      connection  
      eventId     

  protected void subAppend(java.lang.Object, java.sql.Connection, java.sql.PreparedStatement);
    descriptor: (Ljava/lang/Object;Ljava/sql/Connection;Ljava/sql/PreparedStatement;)V
    flags: (0x1044) ACC_PROTECTED, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=4, locals=4, args_size=4
         0: .line 1
            aload 0
            aload 1
            checkcast ch.qos.logback.classic.spi.ILoggingEvent
            aload 2
            aload 3
            invokevirtual ch.qos.logback.classic.db.DBAppender.subAppend:(Lch/qos/logback/classic/spi/ILoggingEvent;Ljava/sql/Connection;Ljava/sql/PreparedStatement;)V
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.lang.Throwable

  protected void secondarySubAppend(java.lang.Object, java.sql.Connection, long);
    descriptor: (Ljava/lang/Object;Ljava/sql/Connection;J)V
    flags: (0x1044) ACC_PROTECTED, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=5, locals=5, args_size=4
         0: .line 1
            aload 0
            aload 1
            checkcast ch.qos.logback.classic.spi.ILoggingEvent
            aload 2
            lload 3
            invokevirtual ch.qos.logback.classic.db.DBAppender.secondarySubAppend:(Lch/qos/logback/classic/spi/ILoggingEvent;Ljava/sql/Connection;J)V
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.lang.Throwable
}
Signature: Lch/qos/logback/core/db/DBAppenderBase<Lch/qos/logback/classic/spi/ILoggingEvent;>;
SourceFile: "DBAppender.java"