jdbc gets all table names and table fields in the database

fun connectDb() {
    Class.forName("com.mysql.jdbc.Driver")
    val url = "jdbc:mysql://xxx:3306/xxx?user=xxx&password=xxx"
    val conn = DriverManager.getConnection(url)

    val md = conn.metaData
    val rs = md.getTables(null, null, "%", null)
    while (rs.next()) {
        //Table Name
        val tableName = rs.getString(3)
        println("Start scanning table '$tableName'")
        val statement = conn.createStatement()
        val results = statement.executeQuery("SELECT * FROM $tableName limit 0")
        val metadata = results.metaData
        val columnCount = metadata.columnCount
        for (i in 1..columnCount) {
            val columnName = metadata.getColumnName(i);
            print(columnName)
            print(", ")
        }
        println()
    }
    conn.close()
}

fun main(args: Array<String>) {
    connectDb()
}

 

Guess you like

Origin http://43.154.161.224:23101/article/api/json?id=326176174&siteId=291194637