|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
有了rowbase的binlog后,我们来分析一下怎么实现闪回。平时的DML无非三种操作,增删改,先说三种操作的日志格式。serverCASE多是SQL中被误用最多的关头字之一。固然你大概之前用过这个关头字来创立字段,可是它还具有更多用法。比方,你能够在WHERE子句中利用CASE。起首让我们看一下CASE的语法。在一样平常的SELECT中,其语法以下:SELECT<myColumnSpec>=CASEWHEN<A>THEN<somethingA>WHEN<B>THEN<somethingB>ELSE<somethingE>END在下面的代码中必要器具体的参数取代尖括号中的内容。上面是一个复杂的例子:USEpubsGOSELECTTitle,PriceRange=CASEWHENpriceISNULLTHENUnpricedWHENprice<10THENBargainWHENpriceBETWEEN10and20THENAverageELSEGifttoimpressrelativesENDFROMtitlesORDERBYpriceGO这是CASE的典范用法,可是利用CASE实在能够做更多的事变。例如说上面的GROUPBY子句中的CASE:SELECTNumberofTitles,Count(*)FROMtitlesGROUPBYCASEWHENpriceISNULLTHENUnpricedWHENprice<10THENBargainWHENpriceBETWEEN10and20THENAverageELSEGifttoimpressrelativesENDGO你乃至还能够组合这些选项,增加一个ORDERBY子句,以下所示:USEpubsGOSELECTCASEWHENpriceISNULLTHENUnpricedWHENprice<10THENBargainWHENpriceBETWEEN10and20THENAverageELSEGifttoimpressrelativesENDASRange,TitleFROMtitlesGROUPBYCASEWHENpriceISNULLTHENUnpricedWHENprice<10THENBargainWHENpriceBETWEEN10and20THENAverageELSEGifttoimpressrelativesEND,TitleORDERBYCASEWHENpriceISNULLTHENUnpricedWHENprice<10THENBargainWHENpriceBETWEEN10and20THENAverageELSEGifttoimpressrelativesEND,TitleGO注重,为了在GROUPBY块中利用CASE,查询语句必要在GROUPBY块中反复SELECT块中的CASE块。除选择自界说字段以外,在良多情形下CASE都十分有效。再深切一步,你还能够失掉你之前以为不成能失掉的分组排序了局集。转自:http://www.g22.net/Article/Show.asp?ID=688我们只需要把binlog文件反向执行,每个操作都执行逆操作即可。当然也不是所有的event都反转。Table_mapevent必须还是在Rows_log_event每个操作之前。 |
|