sql >> Databáze >  >> RDS >> Oracle

Proč se mi zobrazuje chyba formátu:Vlastnost 'v$session.program' se připojuje k Oracle?

Přišli jsme na to. Název naší aplikace byl o jeden znak příliš dlouhý:byl 49 znaků místo 48 nebo méně.

Zde je seznam v$session vlastnosti a jejich omezení délky:

  • v$session.machine :64
  • v$session.iname :bez omezení
  • v$session.ename :bez omezení
  • v$session.process :24
  • v$session.program :48
  • v$session.terminal :30
  • v$session.osuer :30

Žádná z vlastností také nemůže odpovídat tomuto regulárnímu výrazu:.*[\00\(\)].* , což podle mě znamená žádné závorky.

Pokud se vám zobrazuje chyba a chcete vidět kód, přidejte do svého IDE zarážku výjimky pro SQLException . Měli byste skončit ve třídě s názvem T4CConnection.class .

Zde je dekompilovaný kód metody validateConnectionProperties() :

void validateConnectionProperties() throws SQLException {
    super.validateConnectionProperties();
    String var1 = ".*[\\00\\(\\)].*";
    SQLException var2;
    if(this.thinVsessionOsuser == null || !this.thinVsessionOsuser.matches(var1) && this.thinVsessionOsuser.length() <= 30) {
        if(this.thinVsessionTerminal == null || !this.thinVsessionTerminal.matches(var1) && this.thinVsessionTerminal.length() <= 30) {
            if(this.thinVsessionMachine != null && (this.thinVsessionMachine.matches(var1) || this.thinVsessionMachine.length() > 64)) {
                var2 = DatabaseError.createSqlException((OracleConnection)null, 190, "Property is \'v$session.machine\' and value is \'" + this.thinVsessionMachine + "\'");
                var2.fillInStackTrace();
                throw var2;
            } else if(this.thinVsessionProgram == null || !this.thinVsessionProgram.matches(var1) && this.thinVsessionProgram.length() <= 48) {
                if(this.thinVsessionProcess == null || !this.thinVsessionProcess.matches(var1) && this.thinVsessionProcess.length() <= 24) {
                    if(this.thinVsessionIname != null && this.thinVsessionIname.matches(var1)) {
                        var2 = DatabaseError.createSqlException((OracleConnection)null, 190, "Property is \'v$session.iname\' and value is \'" + this.thinVsessionIname + "\'");
                        var2.fillInStackTrace();
                        throw var2;
                    } else if(this.thinVsessionEname != null && this.thinVsessionEname.matches(var1)) {
                        var2 = DatabaseError.createSqlException((OracleConnection)null, 190, "Property is \'v$session.ename\' and value is \'" + this.thinVsessionEname + "\'");
                        var2.fillInStackTrace();
                        throw var2;
                    }
                } else {
                    var2 = DatabaseError.createSqlException((OracleConnection)null, 190, "Property is \'v$session.process\' and value is \'" + this.thinVsessionProcess + "\'");
                    var2.fillInStackTrace();
                    throw var2;
                }
            } else {
                var2 = DatabaseError.createSqlException((OracleConnection)null, 190, "Property is \'v$session.program\' and value is \'" + this.thinVsessionProgram + "\'");
                var2.fillInStackTrace();
                throw var2;
            }
        } else {
            var2 = DatabaseError.createSqlException((OracleConnection)null, 190, "Property is \'v$session.terminal\' and value is \'" + this.thinVsessionTerminal + "\'");
            var2.fillInStackTrace();
            throw var2;
        }
    } else {
        var2 = DatabaseError.createSqlException((OracleConnection)null, 190, "Property is \'v$session.osuser\' and value is \'" + this.thinVsessionOsuser + "\'");
        var2.fillInStackTrace();
        throw var2;
    }
}



  1. PDO ekvivalent mysql_num_rows nebo mssql_num_rows

  2. Pole datatimestamp automatické aktualizace serveru SQL Server

  3. Použití Levenshteinovy ​​funkce na každý prvek v tsvektoru?

  4. Seskupování časových razítek v MySQL s PHP