字段分解难题

yonghanyang 2009-07-07 10:59:49
表A
有字段
ID 主演
id (int) actor nvarchar(255)
1 郑元畅 林依晨 赵咏华 章柏翰
2 路飞 卓洛 奈美 乌索普 山治 乔巴
3 乌索普 林依晨
4 下野纮
求生成下列格式的mssql语句
id 演员
1 郑元畅
2 林依晨
3 赵咏华
4 章柏翰
5 路飞
6 卓洛
7 奈美
8 乌索普
9 山治
10 乔巴
11 下野纮
...全文
35 54 打赏 收藏 转发到动态 举报
写回复
用AI写文章
54 条回复
切换为时间正序
请发表友善的回复…
发表回复
htl258_Tony 2009-07-08
  • 打赏
  • 举报
回复

---------------------------------
-- Author: htl258(Tony)
-- Date : 2009-07-07 23:39:33
---------------------------------
--> 生成测试数据表-tb

if not object_id('tb') is null
drop table tb
Go
Create table tb([id] int,[actor] nvarchar(255))
Insert tb
select 1,'郑元畅 林依晨 赵咏华 章柏翰' union all
select 2,'路 飞 卓 洛 奈 美 乌索普 山 治 乔 巴' union all
select 3,'乌索普 林依晨' union all
select 4,'下野纮'
Go
--Select * from tb

-->SQL查询如下:
;with t as
(
select
rn=row_number() over(order by id),
演员= substring(replace(a.[actor],' ',','), b.number, charindex(',', replace(a.[actor],' ',',') + ',', b.number) - b.number)
from tb a,master..spt_values b
where b.type='p'
and substring(',' + replace(a.[actor],' ',','),b.number,1) = ','
) ,t1 as
(
select rn2=(row_number() over(order by rn)-1)/2,* from t where len(演员)=1
), t2 as
(
select distinct 演员=ltrim((select ' '+演员 from t1 where rn2=a.rn2 for xml path(''))) from t1 a
union
select 演员 from t where len(演员)<>1
)
select id=row_number() over(order by 演员),* from t2
/*
id 演员
-------------------- --------------------------------
1 林依晨
2 路 飞
3 奈 美
4 乔 巴
5 山 治
6 乌索普
7 下野纮
8 章柏翰
9 赵咏华
10 郑元畅
11 卓 洛

(11 行受影响)

*/
feixianxxx 2009-07-08
  • 打赏
  • 举报
回复
[Quote=引用 47 楼 yonghanyang 的回复:]
能执行,不过效率不高啊,我该下了,家里人不让我上了
[/Quote]
好的。。晚安。。。
做出来了
我好开心啊。。
超维电脑科技 2009-07-08
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 fredrickhu 的回复:]
SQL code--> 测试数据: #Tifobject_id('tempdb.dbo.#T')isnotnulldroptable #Tcreatetable #T (idint,namevarchar(8))insertinto #Tselect1,'jame,job'unionallselect2,'paul,mc'unionallselect3,'carl';--> 1. CTE 递归找分¡­
[/Quote]
学习下蹭分下
yonghanyang 2009-07-08
  • 打赏
  • 举报
回复
能执行,不过效率不高啊,我该下了,家里人不让我上了
feixianxxx 2009-07-08
  • 打赏
  • 举报
回复
[Quote=引用 45 楼 yonghanyang 的回复:]
呵呵,我是难为你了,我先不结贴,困了,明天再来看看,不过我一定会给分的,帮忙的人都有分,不多,但是很感谢啊
[/Quote]
你还没告诉我 我的方法行不 测试通过了么?
yonghanyang 2009-07-08
  • 打赏
  • 举报
回复
呵呵,我是难为你了,我先不结贴,困了,明天再来看看,不过我一定会给分的,帮忙的人都有分,不多,但是很感谢啊
feixianxxx 2009-07-08
  • 打赏
  • 举报
回复
[Quote=引用 41 楼 yonghanyang 的回复:]
能否用一条语句呢
[/Quote]
LZ又消失了。。
feixianxxx 2009-07-08
  • 打赏
  • 举报
回复
[Quote=引用 41 楼 yonghanyang 的回复:]
能否用一条语句呢
[/Quote]
嘻嘻 估计难啦
我可是花了好久才帮你想出这么个笨办法的。。
feixianxxx 2009-07-08
  • 打赏
  • 举报
回复
[Quote=引用 39 楼 yonghanyang 的回复:]
feixianxxx 能否帮忙精简下语句
[/Quote]

IF OBJECT_ID('c') IS NOT NULL 
DROP TABLE c
SELECT TOP 1000 id = IDENTITY(int, 1, 1) INTO c FROM syscolumns a, syscolumns b
select id = IDENTITY(int, 1, 1),* into ##
from(
SELECT distinct SUBSTRING(Aa.actor, B.id, CHARINDEX(',', Aa.actor + ',', B.id) - B.id) as value
FROM (select id,actor=REPLACE(actor,' ',',') from tb ) Aa, c B
WHERE SUBSTRING(',' + Aa.actor, B.id, 1) = ',' )r
go
--这部分实现的是单字的字段 组合成 双字 中间代空格的名字
select value from (
select case when len(value)=1 then value+' '+(select value from ## where id=#.id+1) else value end as value
from ## # )t where LEN(value)<=3

这个简化了。。
没有ID列的 只有明星姓名
yonghanyang 2009-07-08
  • 打赏
  • 举报
回复
能否用一条语句呢
feixianxxx 2009-07-08
  • 打赏
  • 举报
回复
[Quote=引用 37 楼 yonghanyang 的回复:]
feixianxxx 能否帮忙精简下语句
[/Quote]
IF OBJECT_ID('[tb]') IS NOT NULL 
DROP TABLE [tb]
Go
CREATE TABLE tb([id] INT,[actor] NVARCHAR(250))
Go
INSERT INTO tb
SELECT 1,'郑元畅 林依晨 赵咏华 章柏翰' UNION ALL
SELECT 2,'路飞 卓洛 奈 美 乌索普 山治 乔巴' UNION ALL
SELECT 3,'乌索普 林依晨' UNION ALL
SELECT 4,'下野纮'
GO
--这部实现的是字段的分离和去重复 效果如下
/*
1 林依晨
2 路飞
3 美
4 奈
5 乔巴
6 山治
7 乌索普
8 下野纮
9 章柏翰
10 赵咏华
11 郑元畅
12 卓洛
*/
IF OBJECT_ID('c') IS NOT NULL
DROP TABLE c
SELECT TOP 1000 id = IDENTITY(int, 1, 1) INTO c FROM syscolumns a, syscolumns b
select id = IDENTITY(int, 1, 1),* into ##
from(
SELECT distinct SUBSTRING(Aa.actor, B.id, CHARINDEX(',', Aa.actor + ',', B.id) - B.id) as value
FROM (select id,actor=REPLACE(actor,' ',',') from tb ) Aa, c B
WHERE SUBSTRING(',' + Aa.actor, B.id, 1) = ',' )r
go
--这部分实现的是单字的字段 组合成 双字 中间代空格的名字
select id = IDENTITY(int, 1, 1),* into ##### from (
select case when len(value)=1 then value+' '+(select value from ## where id=#.id+1) else value end as value
from ## #) #### where LEN(value)<=3
go
--显示效果
select * from #####


/*
1 林依晨
2 路飞
3 美 奈
4 乔巴
5 山治
6 乌索普
7 下野纮
8 章柏翰
9 赵咏华
10 郑元畅
11 卓洛
*/


yonghanyang 2009-07-08
  • 打赏
  • 举报
回复
feixianxxx 能否帮忙精简下语句
feixianxxx 2009-07-08
  • 打赏
  • 举报
回复
[Quote=引用 37 楼 yonghanyang 的回复:]
feixianxxx 能否帮忙精简下语句
[/Quote]
我试试 能行不 能实现不?这语句
yonghanyang 2009-07-08
  • 打赏
  • 举报
回复
feixianxxx 能否帮忙精简下语句
yonghanyang 2009-07-08
  • 打赏
  • 举报
回复
我在,我刚才在测试
yonghanyang 2009-07-08
  • 打赏
  • 举报
回复
我在,我刚才在测试
feixianxxx 2009-07-08
  • 打赏
  • 举报
回复
LZ人海在不
feixianxxx 2009-07-08
  • 打赏
  • 举报
回复
[Quote=引用 31 楼 yonghanyang 的回复:]
太感谢大家了,结贴拉,大家都有分!~
[/Quote]
喂。。先试试我的优化版 可以实现你的功能了
feixianxxx 2009-07-08
  • 打赏
  • 举报
回复
[Quote=引用 30 楼 feixianxxx 的回复:]
引用 27 楼 yonghanyang 的回复:
几万条数据啊,怎么找

SQL codeIFOBJECT_ID('[tb]')ISNOTNULLDROPTABLE[tb]GoCREATETABLE tb([id]INT,[actor]NVARCHAR(250))GoINSERTINTO tbSELECT1,'郑元畅 林依晨 赵咏华 章柏翰'UNIONALLSELECT2,'路飞 卓洛 奈 美 乌索普 山治 乔巴'UNIONALLSELECT3,'乌索普 林依晨'UNIONALLSELECT4,'下野纮'GOIFOBJECT_ID('c')ISNOTNULLDROPTABLE cSELECTTOP1000 id=IDENTITY(int,1,1)INTO cFROM syscolumns a, syscolumns bselect id=IDENTITY(int,1,1),*into ##from(SELECTdistinctSUBSTRING(Aa.actor, B.id,CHARINDEX(',', Aa.actor+',', B.id)- B.id)as valueFROM (select id,actor=REPLACE(actor,'',',')from tb ) Aa, c BWHERESUBSTRING(','+ Aa.actor, B.id,1)=',' )rgoselect id=IDENTITY(int,1,1),*into #####from (selectcasewhenlen(value)=1then value+''+(select valuefrom ##where id=#.id+1)else valueendas valuefrom ## #) ####goselect valueinto ktfrom #####goselect id=IDENTITY(int,1,1),*into ktcfrom ktwhereLEN(value)<=3goselect*from ktc/*
1 林依晨
2 路飞
3 美 奈
4 乔巴
5 山治
6 乌索普
7 下野纮
8 章柏翰
9 赵咏华
10 郑元畅
11 卓洛*/
[/Quote]
修改的简单了点
IF OBJECT_ID('[tb]') IS NOT NULL 
DROP TABLE [tb]
Go
CREATE TABLE tb([id] INT,[actor] NVARCHAR(250))
Go
INSERT INTO tb
SELECT 1,'郑元畅 林依晨 赵咏华 章柏翰' UNION ALL
SELECT 2,'路飞 卓洛 奈 美 乌索普 山治 乔巴' UNION ALL
SELECT 3,'乌索普 林依晨' UNION ALL
SELECT 4,'下野纮'
GO

IF OBJECT_ID('c') IS NOT NULL
DROP TABLE c
SELECT TOP 1000 id = IDENTITY(int, 1, 1) INTO c FROM syscolumns a, syscolumns b
select id = IDENTITY(int, 1, 1),* into ##
from(
SELECT distinct SUBSTRING(Aa.actor, B.id, CHARINDEX(',', Aa.actor + ',', B.id) - B.id) as value
FROM (select id,actor=REPLACE(actor,' ',',') from tb ) Aa, c B
WHERE SUBSTRING(',' + Aa.actor, B.id, 1) = ',' )r
go

select id = IDENTITY(int, 1, 1),* into ##### from (
select case when len(value)=1 then value+' '+(select value from ## where id=#.id+1) else value end as value
from ## #) #### where LEN(value)<=3
go
select * from #####


/*
1 林依晨
2 路飞
3 美 奈
4 乔巴
5 山治
6 乌索普
7 下野纮
8 章柏翰
9 赵咏华
10 郑元畅
11 卓洛
*/


yonghanyang 2009-07-08
  • 打赏
  • 举报
回复
太感谢大家了,结贴拉,大家都有分!~
加载更多回复(34)
第1章 重构,第一个案例   1.1 起点1   1.2 重构的第一步7   1.3 分解并重组statement()8   1.4 运用多态取代与价格相关的条件逻辑34   1.5 结语52 第2章 重构原则   2.1 何谓重构53   2.2 为何重构55   2.3 何时重构57   2.4 怎么对经理说60   2.5 重构的难题62   2.6 重构与设计66   2.7 重构与性能69   2.8 重构起源何处71 第3章 代码的坏味道   3.1 DuplicatedCode(重复代码)76   3.2 LongMethod(过长函数)76   3.3 LargeClass(过大的类)78   3.4 LongParameterList(过长参数列)78   3.5 DivergentChange(发散式变化)79   3.6 ShotgunSurgery(霰弹式修改)80   3.7 FeatureEnvy(依恋情结)80   3.8 DataClumps(数据泥团)81   3.9 PrimitiveObsession(基本类型偏执)81   3.10 SwitchStatements(switch惊悚现身)82   3.11 ParallelInheritanceHierarchies(平行继承体系)83   3.12 LazyClass(冗赘类)83   3.13 SpeculativeGenerality(夸夸其谈未来性)83   3.14 TemporaryField(令人迷惑的暂时字段)84   3.15 MessageChains(过度耦合的消息链)84   3.16 MiddleMan(中间人)85   3.17 InappropriateIntimacy(狎昵关系)85   3.18 AlternativeClasseswithDifferentInterfaces(异曲同工的类)85   3.19 IncompleteLibraryClass(不完美的库类)86   3.20 DataClass(纯稚的数据类)86   3.21 RefusedBequest(被拒绝的遗赠)87   3.22 Comments(过多的注释)87 第4章 构筑测试体系   4.1 自测试代码的价值89   4.2 JUnit测试框架91   4.3 添加更多测试97 第5章 重构列表   5.1 重构的记录格式103   5.2 寻找引用点105   5.3 这些重构手法有多成熟106 第6章 重新组织函数   6.1 ExtractMethod(提炼函数)110   6.2 InlineMethod(内联函数)117   6.3 InlineTemp(内联临时变量)119   6.4 ReplaceTempwithQuery(以查询取代临时变量)120   6.5 IntroduceExplainingVariable(引入解释性变量)124   6.6 SplitTemporaryVariable(分解临时变量)128   6.7 RemoveAssignmentstoParameters(移除对参数的赋值)131   6.8 ReplaceMethodwithMethodObject(以函数对象取代函数)135   6.9 SubstituteAlgorithm(替换算法)139 第7章 在对象之间搬移特性   7.1 MoveMethod(搬移函数)142   7.2 MoveField(搬移字段)146   7.3 ExtractClass(提炼类)149   7.4 InlineClass(将类内联化)154   7.5 HideDelegate(隐藏“委托关系”)157   7.6 RemoveMiddleMan(移除中间人)160   7.7 IntroduceForeignMethod(引入外加函数)162   7.8 IntroduceLocalExtension(引入本地扩展)164 第8章 重新组织数据   8.1 SelfEncapsulateField(自封装字段)171   8.2 ReplaceDataValuewithObject(以对象取代数据值)175   8.3 ChangeValuetoReference(将值对象改为引用对象)179   8.4 ChangeReferencetoValue(将引用对象改为值对象)183   8.5 ReplaceArraywithObject(以对象取代数组)186   8.6 DuplicateObservedData(复制“被监视数据”)189   8.7 ChangeUnidirectionalAssociationtoBidirectional(将单向关联改为双向关联)197   8.8 ChangeBidirectionalAssociationtoUnidirectional(将双向关联改为单向关联)200   8.9 ReplaceMagicNumberwithSymbolicConstant(以字面常量取代魔法数)204   8.10 EncapsulateField(封装字段)206   8.11 EncapsulateCollection(封装集合)208   8.12 ReplaceRecordwithDataClass(以数据类取代记录)217   8.13 ReplaceTypeCodewithClass(以类取代类型码)218   8.14 ReplaceTypeCodewithSubclasses(以子类取代类型码)223   8.15 ReplaceTypeCodewithState/Strategy(以State/Strategy取代类型码)227   8.16 ReplaceSubclasswithFields(以字段取代子类)232 第9章 简化条件表达式   9.1 DecomposeConditional(分解条件表达式)238   9.2 ConsolidateConditionalExpression(合并条件表达式)240   9.3 ConsolidateDuplicateConditionalFragments(合并重复的条件片段)243   9.4 RemoveControlFlag(移除控制标记)245   9.5 ReplaceNestedConditionalwithGuardClauses(以卫语句取代嵌套条件表达式)250   9.6 ReplaceConditionalwithPolymorphism(以多态取代条件表达式)255   9.7 IntroduceNullObject(引入Null对象)260   9.8 IntroduceAssertion(引入断言)267 第10章 简化函数调用   10.1 RenameMethod(函数改名)273   10.2 AddParameter(添加参数)275   10.3 RemoveParameter(移除参数)277   10.4 SeparateQueryfromModifier(将查询函数和修改函数分离)279   10.5 ParameterizeMethod(令函数携带参数)283   10.6 ReplaceParameterwithExplicitMethods(以明确函数取代参数)285   10.7 PreserveWholeObject(保持对象完整)288   10.8 ReplaceParameterwithMethods(以函数取代参数)292   10.9 IntroduceParameterObject(引入参数对象)295   10.10 RemoveSettingMethod(移除设值函数)300   10.11 HideMethod(隐藏函数)303   10.12 ReplaceConstructorwithFactoryMethod(以工厂函数取代构造函数)304   10.13 EncapsulateDowncast(封装向下转型)308   10.14 ReplaceErrorCodewithException(以异常取代错误码)310   10.15 ReplaceExceptionwithTest(以测试取代异常)315 第11章 处理概括关系   11.1 PullUpField(字段上移)320   11.2 PullUpMethod(函数上移)322   11.3 PullUpConstructorBody(构造函数本体上移)325   11.4 PushDownMethod(函数下移)328   11.5 PushDownField(字段下移)329   11.6 ExtractSubclass(提炼子类)330   …… 第12章 大型重构 第13章 重构,复用与现实 第14章 重构工具 第15章 总结
第1章 重构,第一个案例1 1.1 起点1 1.2 重构的第一步7 1.3 分解并重组statement()8 1.4 运用多态取代与价格相关的条件逻辑34 1.5 结语52 第2章 重构原则53 2.1 何谓重构53 2.2 为何重构55 2.3 何时重构57 2.4 怎么对经理说60 2.5 重构的难题62 2.6 重构与设计66 2.7 重构与性能69 2.8 重构起源何处71 第3章 代码的坏味道75 3.1 DuplicatedCode(重复代码)76 3.2 LongMethod(过长函数)76 3.3 LargeClass(过大的类)78 3.4 LongParameterList(过长参数列)78 3.5 DivergentChange(发散式变化)79 3.6 ShotgunSurgery(霰弹式修改)80 3.7 FeatureEnvy(依恋情结)80 3.8 DataClumps(数据泥团)81 3.9 PrimitiveObsession(基本类型偏执)81 3.10 SwitchStatements(switch惊悚现身)82 3.11 ParallelInheritanceHierarchies(平行继承体系)83 3.12 LazyClass(冗赘类)83 3.13 SpeculativeGenerality(夸夸其谈未来性)83 3.14 TemporaryField(令人迷惑的暂时字段)84 3.15 MessageChains(过度耦合的消息链)84 3.16 MiddleMan(中间人)85 3.17 InappropriateIntimacy(狎昵关系)85 3.18 AlternativeClasseswithDifferentInterfaces(异曲同工的类)85 3.19 IncompleteLibraryClass(不完美的库类)86 3.20 DataClass(纯稚的数据类)86 3.21 RefusedBequest(被拒绝的遗赠)87 3.22 Comments(过多的注释)87 第4章 构筑测试体系89 4.1 自测试代码的价值89 4.2 JUnit测试框架91 4.3 添加更多测试97 第5章 重构列表103 5.1 重构的记录格式103 5.2 寻找引用点105 5.3 这些重构手法有多成熟106 第6章 重新组织函数109 6.1 ExtractMethod(提炼函数)110 6.2 InlineMethod(内联函数)117 6.3 InlineTemp(内联临时变量)119 6.4 ReplaceTempwithQuery(以查询取代临时变量)120 6.5 IntroduceExplainingVariable(引入解释性变量)124 6.6 SplitTemporaryVariable(分解临时变量)128 6.7 RemoveAssignmentstoParameters(移除对参数的赋值)131 6.8 ReplaceMethodwithMethodObject(以函数对象取代函数)135 6.9 SubstituteAlgorithm(替换算法)139 第7章 在对象之间搬移特性141 7.1 MoveMethod(搬移函数)142 7.2 MoveField(搬移字段)146 7.3 ExtractClass(提炼类)149 7.4 InlineClass(将类内联化)154 7.5 HideDelegate(隐藏“委托关系”)157 7.6 RemoveMiddleMan(移除中间人)160 7.7 IntroduceForeignMethod(引入外加函数)162 7.8 IntroduceLocalExtension(引入本地扩展)164 第8章 重新组织数据169 8.1 SelfEncapsulateField(自封装字段)171 8.2 ReplaceDataValuewithObject(以对象取代数据值)175 8.3 ChangeValuetoReference(将值对象改为引用对象)179 8.4 ChangeReferencetoValue(将引用对象改为值对象)183 8.5 ReplaceArraywithObject(以对象取代数组)186 8.6 DuplicateObservedData(复制“被监视数据”)189 8.7 ChangeUnidirectionalAssociationtoBidirectional(将单向关联改为双向关联)197 8.8 ChangeBidirectionalAssociationtoUnidirectional(将双向关联改为单向关联)200 8.9 ReplaceMagicNumberwithSymbolicConstant(以字面常量取代魔法数)204 8.10 EncapsulateField(封装字段)206 8.11 EncapsulateCollection(封装集合)208 8.12 ReplaceRecordwithDataClass(以数据类取代记录)217 8.13 ReplaceTypeCodewithClass(以类取代类型码)218 8.14 ReplaceTypeCodewithSubclasses(以子类取代类型码)223 8.15 ReplaceTypeCodewithState/Strategy(以State/Strategy取代类型码)227 8.16 ReplaceSubclasswithFields(以字段取代子类)232 第9章 简化条件表达式237 9.1 DecomposeConditional(分解条件表达式)238 9.2 ConsolidateConditionalExpression(合并条件表达式)240 9.3 ConsolidateDuplicateConditionalFragments(合并重复的条件片段)243 9.4 RemoveControlFlag(移除控制标记)245 9.5 ReplaceNestedConditionalwithGuardClauses(以卫语句取代嵌套条件表达式)250 9.6 ReplaceConditionalwithPolymorphism(以多态取代条件表达式)255 9.7 IntroduceNullObject(引入Null对象)260 9.8 IntroduceAssertion(引入断言)267 第10章 简化函数调用271 10.1 RenameMethod(函数改名)273 10.2 AddParameter(添加参数)275 10.3 RemoveParameter(移除参数)277 10.4 SeparateQueryfromModifier(将查询函数和修改函数分离)279 10.5 ParameterizeMethod(令函数携带参数)283 10.6 ReplaceParameterwithExplicitMethods(以明确函数取代参数)285 10.7 PreserveWholeObject(保持对象完整)288 10.8 ReplaceParameterwithMethods(以函数取代参数)292 10.9 IntroduceParameterObject(引入参数对象)295 10.10 RemoveSettingMethod(移除设值函数)300 10.11 HideMethod(隐藏函数)303 10.12 ReplaceConstructorwithFactoryMethod(以工厂函数取代构造函数)304 10.13 EncapsulateDowncast(封装向下转型)308 10.14 ReplaceErrorCodewithException(以异常取代错误码)310 10.15 ReplaceExceptionwithTest(以测试取代异常)315 第11章 处理概括关系319 11.1 PullUpField(字段上移)320 11.2 PullUpMethod(函数上移)322 11.3 PullUpConstructorBody(构造函数本体上移)325 11.4 PushDownMethod(函数下移)328 11.5 PushDownField(字段下移)329 11.6 ExtractSubclass(提炼子类)330 …… 第12章 大型重构359 第13章 重构,复用与现实379 第14章 重构工具401 第15章 总结409 参考书目413 要点列表417 索引419
第1章 重构,第一个案例1 1.1 起点1 1.2 重构的第一步7 1.3 分解并重组statement()8 1.4 运用多态取代与价格相关的条件逻辑34 1.5 结语52 第2章 重构原则53 2.1 何谓重构53 2.2 为何重构55 2.3 何时重构57 2.4 怎么对经理说60 2.5 重构的难题62 2.6 重构与设计66 2.7 重构与性能69 2.8 重构起源何处71 第3章 代码的坏味道75 3.1 DuplicatedCode(重复代码)76 3.2 LongMethod(过长函数)76 3.3 LargeClass(过大的类)78 3.4 LongParameterList(过长参数列)78 3.5 DivergentChange(发散式变化)79 3.6 ShotgunSurgery(霰弹式修改)80 3.7 FeatureEnvy(依恋情结)80 3.8 DataClumps(数据泥团)81 3.9 PrimitiveObsession(基本类型偏执)81 3.10 SwitchStatements(switch惊悚现身)82 3.11 ParallelInheritanceHierarchies(平行继承体系)83 3.12 LazyClass(冗赘类)83 3.13 SpeculativeGenerality(夸夸其谈未来性)83 3.14 TemporaryField(令人迷惑的暂时字段)84 3.15 MessageChains(过度耦合的消息链)84 3.16 MiddleMan(中间人)85 3.17 InappropriateIntimacy(狎昵关系)85 3.18 AlternativeClasseswithDifferentInterfaces(异曲同工的类)85 3.19 IncompleteLibraryClass(不完美的库类)86 3.20 DataClass(纯稚的数据类)86 3.21 RefusedBequest(被拒绝的遗赠)87 3.22 Comments(过多的注释)87 第4章 构筑测试体系89 4.1 自测试代码的价值89 4.2 JUnit测试框架91 4.3 添加更多测试97 第5章 重构列表103 5.1 重构的记录格式103 5.2 寻找引用点105 5.3 这些重构手法有多成熟106 第6章 重新组织函数109 6.1 ExtractMethod(提炼函数)110 6.2 InlineMethod(内联函数)117 6.3 InlineTemp(内联临时变量)119 6.4 ReplaceTempwithQuery(以查询取代临时变量)120 6.5 IntroduceExplainingVariable(引入解释性变量)124 6.6 SplitTemporaryVariable(分解临时变量)128 6.7 RemoveAssignmentstoParameters(移除对参数的赋值)131 6.8 ReplaceMethodwithMethodObject(以函数对象取代函数)135 6.9 SubstituteAlgorithm(替换算法)139 第7章 在对象之间搬移特性141 7.1 MoveMethod(搬移函数)142 7.2 MoveField(搬移字段)146 7.3 ExtractClass(提炼类)149 7.4 InlineClass(将类内联化)154 7.5 HideDelegate(隐藏“委托关系”)157 7.6 RemoveMiddleMan(移除中间人)160 7.7 IntroduceForeignMethod(引入外加函数)162 7.8 IntroduceLocalExtension(引入本地扩展)164 第8章 重新组织数据169 8.1 SelfEncapsulateField(自封装字段)171 8.2 ReplaceDataValuewithObject(以对象取代数据值)175 8.3 ChangeValuetoReference(将值对象改为引用对象)179 8.4 ChangeReferencetoValue(将引用对象改为值对象)183 8.5 ReplaceArraywithObject(以对象取代数组)186 8.6 DuplicateObservedData(复制“被监视数据”)189 8.7 ChangeUnidirectionalAssociationtoBidirectional(将单向关联改为双向关联)197 8.8 ChangeBidirectionalAssociationtoUnidirectional(将双向关联改为单向关联)200 8.9 ReplaceMagicNumberwithSymbolicConstant(以字面常量取代魔法数)204 8.10 EncapsulateField(封装字段)206 8.11 EncapsulateCollection(封装集合)208 8.12 ReplaceRecordwithDataClass(以数据类取代记录)217 8.13 ReplaceTypeCodewithClass(以类取代类型码)218 8.14 ReplaceTypeCodewithSubclasses(以子类取代类型码)223 8.15 ReplaceTypeCodewithState/Strategy(以State/Strategy取代类型码)227 8.16 ReplaceSubclasswithFields(以字段取代子类)232 第9章 简化条件表达式237 9.1 DecomposeConditional(分解条件表达式)238 9.2 ConsolidateConditionalExpression(合并条件表达式)240 9.3 ConsolidateDuplicateConditionalFragments(合并重复的条件片段)243 9.4 RemoveControlFlag(移除控制标记)245 9.5 ReplaceNestedConditionalwithGuardClauses(以卫语句取代嵌套条件表达式)250 9.6 ReplaceConditionalwithPolymorphism(以多态取代条件表达式)255 9.7 IntroduceNullObject(引入Null对象)260 9.8 IntroduceAssertion(引入断言)267 第10章 简化函数调用271 10.1 RenameMethod(函数改名)273 10.2 AddParameter(添加参数)275 10.3 RemoveParameter(移除参数)277 10.4 SeparateQueryfromModifier(将查询函数和修改函数分离)279 10.5 ParameterizeMethod(令函数携带参数)283 10.6 ReplaceParameterwithExplicitMethods(以明确函数取代参数)285 10.7 PreserveWholeObject(保持对象完整)288 10.8 ReplaceParameterwithMethods(以函数取代参数)292 10.9 IntroduceParameterObject(引入参数对象)295 10.10 RemoveSettingMethod(移除设值函数)300 10.11 HideMethod(隐藏函数)303 10.12 ReplaceConstructorwithFactoryMethod(以工厂函数取代构造函数)304 10.13 EncapsulateDowncast(封装向下转型)308 10.14 ReplaceErrorCodewithException(以异常取代错误码)310 10.15 ReplaceExceptionwithTest(以测试取代异常)315 第11章 处理概括关系319 11.1 PullUpField(字段上移)320 11.2 PullUpMethod(函数上移)322 11.3 PullUpConstructorBody(构造函数本体上移)325 11.4 PushDownMethod(函数下移)328 11.5 PushDownField(字段下移)329 11.6 ExtractSubclass(提炼子类)330 …… 第12章 大型重构359 第13章 重构,复用与现实379 第14章 重构工具401 第15章 总结409 参考书目413 要点列表417 索引419
第1章 重构,第一个案例1 1.1 起点1 1.2 重构的第一步7 1.3 分解并重组statement()8 1.4 运用多态取代与价格相关的条件逻辑34 1.5 结语52 第2章 重构原则53 2.1 何谓重构53 2.2 为何重构55 2.3 何时重构57 2.4 怎么对经理说60 2.5 重构的难题62 2.6 重构与设计66 2.7 重构与性能69 2.8 重构起源何处71 第3章 代码的坏味道75 3.1 DuplicatedCode(重复代码)76 3.2 LongMethod(过长函数)76 3.3 LargeClass(过大的类)78 3.4 LongParameterList(过长参数列)78 3.5 DivergentChange(发散式变化)79 3.6 ShotgunSurgery(霰弹式修改)80 3.7 FeatureEnvy(依恋情结)80 3.8 DataClumps(数据泥团)81 3.9 PrimitiveObsession(基本类型偏执)81 3.10 SwitchStatements(switch惊悚现身)82 3.11 ParallelInheritanceHierarchies(平行继承体系)83 3.12 LazyClass(冗赘类)83 3.13 SpeculativeGenerality(夸夸其谈未来性)83 3.14 TemporaryField(令人迷惑的暂时字段)84 3.15 MessageChains(过度耦合的消息链)84 3.16 MiddleMan(中间人)85 3.17 InappropriateIntimacy(狎昵关系)85 3.18 AlternativeClasseswithDifferentInterfaces(异曲同工的类)85 3.19 IncompleteLibraryClass(不完美的库类)86 3.20 DataClass(纯稚的数据类)86 3.21 RefusedBequest(被拒绝的遗赠)87 3.22 Comments(过多的注释)87 第4章 构筑测试体系89 4.1 自测试代码的价值89 4.2 JUnit测试框架91 4.3 添加更多测试97 第5章 重构列表103 5.1 重构的记录格式103 5.2 寻找引用点105 5.3 这些重构手法有多成熟106 第6章 重新组织函数109 6.1 ExtractMethod(提炼函数)110 6.2 InlineMethod(内联函数)117 6.3 InlineTemp(内联临时变量)119 6.4 ReplaceTempwithQuery(以查询取代临时变量)120 6.5 IntroduceExplainingVariable(引入解释性变量)124 6.6 SplitTemporaryVariable(分解临时变量)128 6.7 RemoveAssignmentstoParameters(移除对参数的赋值)131 6.8 ReplaceMethodwithMethodObject(以函数对象取代函数)135 6.9 SubstituteAlgorithm(替换算法)139 第7章 在对象之间搬移特性141 7.1 MoveMethod(搬移函数)142 7.2 MoveField(搬移字段)146 7.3 ExtractClass(提炼类)149 7.4 InlineClass(将类内联化)154 7.5 HideDelegate(隐藏“委托关系”)157 7.6 RemoveMiddleMan(移除中间人)160 7.7 IntroduceForeignMethod(引入外加函数)162 7.8 IntroduceLocalExtension(引入本地扩展)164 第8章 重新组织数据169 8.1 SelfEncapsulateField(自封装字段)171 8.2 ReplaceDataValuewithObject(以对象取代数据值)175 8.3 ChangeValuetoReference(将值对象改为引用对象)179 8.4 ChangeReferencetoValue(将引用对象改为值对象)183 8.5 ReplaceArraywithObject(以对象取代数组)186 8.6 DuplicateObservedData(复制“被监视数据”)189 8.7 ChangeUnidirectionalAssociationtoBidirectional(将单向关联改为双向关联)197 8.8 ChangeBidirectionalAssociationtoUnidirectional(将双向关联改为单向关联)200 8.9 ReplaceMagicNumberwithSymbolicConstant(以字面常量取代魔法数)204 8.10 EncapsulateField(封装字段)206 8.11 EncapsulateCollection(封装集合)208 8.12 ReplaceRecordwithDataClass(以数据类取代记录)217 8.13 ReplaceTypeCodewithClass(以类取代类型码)218 8.14 ReplaceTypeCodewithSubclasses(以子类取代类型码)223 8.15 ReplaceTypeCodewithState/Strategy(以State/Strategy取代类型码)227 8.16 ReplaceSubclasswithFields(以字段取代子类)232 第9章 简化条件表达式237 9.1 DecomposeConditional(分解条件表达式)238 9.2 ConsolidateConditionalExpression(合并条件表达式)240 9.3 ConsolidateDuplicateConditionalFragments(合并重复的条件片段)243 9.4 RemoveControlFlag(移除控制标记)245 9.5 ReplaceNestedConditionalwithGuardClauses(以卫语句取代嵌套条件表达式)250 9.6 ReplaceConditionalwithPolymorphism(以多态取代条件表达式)255 9.7 IntroduceNullObject(引入Null对象)260 9.8 IntroduceAssertion(引入断言)267 第10章 简化函数调用271 10.1 RenameMethod(函数改名)273 10.2 AddParameter(添加参数)275 10.3 RemoveParameter(移除参数)277 10.4 SeparateQueryfromModifier(将查询函数和修改函数分离)279 10.5 ParameterizeMethod(令函数携带参数)283 10.6 ReplaceParameterwithExplicitMethods(以明确函数取代参数)285 10.7 PreserveWholeObject(保持对象完整)288 10.8 ReplaceParameterwithMethods(以函数取代参数)292 10.9 IntroduceParameterObject(引入参数对象)295 10.10 RemoveSettingMethod(移除设值函数)300 10.11 HideMethod(隐藏函数)303 10.12 ReplaceConstructorwithFactoryMethod(以工厂函数取代构造函数)304 10.13 EncapsulateDowncast(封装向下转型)308 10.14 ReplaceErrorCodewithException(以异常取代错误码)310 10.15 ReplaceExceptionwithTest(以测试取代异常)315 第11章 处理概括关系319 11.1 PullUpField(字段上移)320 11.2 PullUpMethod(函数上移)322 11.3 PullUpConstructorBody(构造函数本体上移)325 11.4 PushDownMethod(函数下移)328 11.5 PushDownField(字段下移)329 11.6 ExtractSubclass(提炼子类)330 …… 第12章 大型重构359 第13章 重构,复用与现实379 第14章 重构工具401 第15章 总结409 参考书目413 要点列表417 索引419

22,210

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧