MSSQL网页编程之切磋SQL Server中Case 的分歧用法
有了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每个操作之前。 对于微软系列的东西除了一遍遍尝试还真没有太好的办法 总感觉自己还是不会SQL 这就引发了对varchar和char效率讨论的老问题。到底如何分配varchar的数据,是否会出现大规模的碎片? 备份方面可能还是一个老大难的问题。不能单独备份几个表总是感觉不爽。灵活备份的问题不知道什么时候才能解决。 其实可以做一下类比,Oracle等数据库产品老早就支持了java编程,而且提供了java池参数作为用户配置接口。但是现在有哪些系统大批使用了java存储过程?!连Oracle自己的应用都不用为什么?! 是要和操作系统进行Socket通讯的场景。否则建议慎重! where子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使用where条件显示特定的行。
页:
[1]