不仅如此,日志中记录的信息还包括:数据库的更改历史、更改类型(insert、0update、0delete、ddl等)、更改对应的scn号、以及执行这些操作的用户信息等,logminer在分析日志时,将重构等价的sql语句和undo语句(分别记录在v$logmnr_contents视图的sql_redo和sql_undo中)。这里需要注意的是等价语句,而并非原始sql语句,例如:我们最初执行的是“0delete a where c1 <> cyx .”,而logminer重构的是等价的6条0delete语句。所以我们应该意识到v$logmnr_contents视图中显示的并非是原版的现实,从数据库角度来讲这是很容易理解的,它记录的是元操作,因为同样是“0delete a where c1 <> cyx .”语句,在不同的环境中,实际删除的记录数可能各不相同,因此记录这样的语句实际上并没有什么实际意义,logminer重构的是在实际情况下转化成元操作的多个单条语句。
另外由于oracle重做日志中记录的并非原始的对象(如表以及其中的列)名称,而只是它们在oracle数据库中的内部编号(对于表来说是它们在数据库中的对象id,而对于表中的列来说,对应的则是该列在表中的排列序号:col 1, col 2 等),因此为了使logminer重构出的sql语句易于识别,我们需要将这些编号转化成相应的名称,这就需要用到数据字典(也就说logminer本身是可以不用数据字典的,详见下面的分析过程),logminer利用dbms_logmnr_d.build()过程来提取数据字典信息。