最后,附一张自己面试前准备的脑图:
面试前一定少不了刷题,为了方便大家复习,我分享一波个人整理的面试大全宝典
- Java核心知识整理
- Spring全家桶(实战系列)
Step3:刷题
既然是要面试,那么就少不了刷题,实际上春节回家后,哪儿也去不了,我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。
以下是我私藏的面试题库:
很多人感叹“学习无用”,实际上之所以产生无用论,是因为自己想要的与自己所学的匹配不上,这也就意味着自己学得远远不够。无论是学习还是工作,都应该有主动性,所以如果拥有大厂梦,那么就要自己努力去实现它。
最后祝愿各位身体健康,顺利拿到心仪的offer!
}
2. 查询表的元数据信息
//streaming.core.datasource.JDBCUtils
def queryTableWithColumnsInDriver(options: Map[String, String] ,tableList: List[String]) = {
val tableAndCols = mutable.HashMap.empty[String, mutable.HashMap[String ,String]]
val driver = options(“driver”)
val url = options(“url”)
Class.forName(driver)
val connection = java.sql.DriverManager.getConnection(url, options(“user”), options(“password”))
try {
val dbMetaData = connection.getMetaData()
tableList.foreach(table => {
val rs = dbMetaData.getColumns(null, null, table, “%”)
val value = tableAndCols.getOrElse(table, mutable.HashMap.empty[String ,String])
while(rs.next()){
value += (rs.getString(“COLUMN_NAME”) -> rs.getString(“TYPE_NAME”))
}
tableAndCols.update(table, value)
rs.close()
})
} finally {
if (connection != null)
connection.close()
}
tableAndCols
}
3. 根据表的元数据信息,构造表的创建语句,用于构造SchemaRepository
//streaming.core.datasource.JDBCUtils
def tableColumnsToCreateSql(tableClos: mutable.HashMap[String, mutable.HashMap[String, String]]) = {
val createSqlList = mutable.ArrayBuffer.empty[String]
tableClos.foreach(table => {
var createSql = “create table " + table._1 + " (” +
table._2.map(m => m._1 + " " + m._2)
.mkString(“,”) +
" )"
createSqlList += createSql
})
createSqlList.toList
}
4. 解析SQL的表和列
//tech.mlsql.sql.MLSQLSQLParser
def extractTableWithColumns(dbType :String ,sql :String ,createSchemaList :List[String]) = {
val tableAndCols = mutable.HashMap.empty[String, mutable.HashSet[String]]
val repository = new SchemaRepository(dbType)
createSchemaList.foreach(repository.console(_))
val stmtList = SQLUtils.parseStatements(sql, dbType)
val stmt = stmtList.get(0).asInstanceOf[SQLSelectStatement]
repository.resolve(stmt)
val statVisitor = SQLUtils.createSchemaStatVisitor(dbType)
stmt.accept(statVisitor)
val iter = statVisitor.getColumns().iterator()
while(iter.hasNext()){
val c = iter.next()
if(c.isSelect()){
val value = tableAndCols.getOrElse(c.getTable, mutable.HashSet.empty[String])
value.add(c.getName)
tableAndCols.update(c.getTable, value)
}
}
tableAndCols
}
下面来看一下整个流程:
val sql =
“”"
|select name ,country
| from c5_user a
| left join c5_country b
| on a.id = b.id
“”".stripMargin
val params = Map(“driver”->“com.mysql.jdbc.Driver” ,
“url”->“jdbc:mysql://127.0.0.1:3306/test” ,
“user”->“root” ,
“password”->“mlsql”)
val rest = extractTablesFromSQL(sql)
val tableList = extractTablesFromSQL(sql).map(_._1)
val tableColsMap = queryTableWithColumnsInDriver(params, tableList)
val createSqlList = tableColumnsToCreateSql(tableColsMap)
println(“创建SQL:”)
createSqlList.foreach(println(_))
val tableAndCols = extractTableWithColumns(JdbcConstants.MYSQL, sql, createSqlList)
println(“表列信息:”)
println(tableAndCols)
--------------------------------------------------------------------------------------
最后
我还通过一些渠道整理了一些大厂真实面试主要有:蚂蚁金服、拼多多、阿里云、百度、唯品会、携程、丰巢科技、乐信、软通动力、OPPO、银盛支付、中国平安等初,中级,高级Java面试题集合,附带超详细答案,希望能帮助到大家。
还有专门针对JVM、SPringBoot、SpringCloud、数据库、Linux、缓存、消息中间件、源码等相关面试题。
PringBoot、SpringCloud、数据库、Linux、缓存、消息中间件、源码等相关面试题。**
[外链图片转存中…(img-E10RaLAX-1715068597236)]