sql >> Databasteknik >  >> RDS >> Mysql

io.vertx.mysqlclient.MySQLPool.query ().execute körs aldrig riktigt och returnerar ingenting

Reactive MySQL-klienten exekverar frågor asynkront. Så om du vill läsa raderna du har infogat måste du göra det i återuppringningen:

client.query("INSERT INTO mytable('id','name') VALUES ('2','Jimis2')").execute { insert ->
    if (insert.succeeded()) {

        var rows = insert.result()
        var lastInsertId = rows.property(MySQLClient.LAST_INSERTED_ID)
        println("Last inserted id is: ${lastInsertId}")

        client.query("SELECT * FROM mytable WHERE id=1").execute { select ->
            if (select.succeeded()) {
                var result = select.result()
                println("Got ${result.size()} rows ")
            } else {
                select.cause().printStackTrace()
            }

            client.close()
        }

    } else {
        insert.cause().printStackTrace()
        client.close()
    }
}



  1. Förhindra dropptabell vid målschema i Oracle Streams

  2. Motsvarighet till Oracles RowID i MySQL

  3. Lagrade procedurer i Ruby on Rails

  4. MySQL 5.6 - tabell låser även när ALGORITHM=inplace används