文章作者:Jason Xia(夏建军)

Jerry: 今天的文章来自Jason Xia, 我的老同事,和我一样从2007年进入SAP成都研究院工作至今。这篇文章讲述了Jason是如何从一名SAP资深开发人员转型为SAP产品经理的,希望能对有同样志向的开发人员们一些启发。

Jason身上有很多优点,其中最让Jerry佩服的是以下两点。

在Jerry2007年刚进SAP没到一个月时间,就参加了一个BW305的内部培训。讲师是SAP成都同事,资深BW专家。当时我的专业技能只有Linux系统网络编程这一门技术,对于BW领域的Info cube, Info provider, info source, star schema这些概念听的一头雾水,BW305那本厚的像砖头的培训教材里每个单词我都懂,但是串成一句话我就不懂在说些什么。最后这个培训的内容我掌握的程度可想而知。从此,我对精通BW乃至Analytics的同事都分外崇拜,因为那些对我来说经过了培训后仍不知所云的概念们,在他们脑子里却组成了一套清晰的知识体系,并能用来帮客户解决实际问题。

那么这一切和Jason有什么关系?2007年到2012年,SAP成都研究院的开发团队大多工作于SAP Business by Design, 致力于四大内容的交付:Form, Report/Analytics, Field Extension和UI。每个内容都有一个负责人,SAP内部称为topic owner。项目上关于该内容的各种问题,不管是SAP成都研究院的同事,还是global团队的同事,都会找到该topic owner。江湖地位类似于射雕英雄传里的东邪西毒南帝北丐。到这里你可能已经猜到了,Jason就是Report/Analytics的topic owner。所以,他在这个领域的造诣无需多言。

我非常佩服Jason的第二点,就是他面对business complexity时有条不紊的处理方式和从容不迫的工作态度。在Jerry看来,编程技能容易从后天习得,而这种非技术层面的软技能,和一个人的性格也有一些关系,相对于纯技术层面的编程技能更难获得。

我2014年时曾经和Jason工作过一段时间,负责处理SAP CRM内一些模块的ticket处理。这些模块是SAP成都团队从SAP全球其他团队接过来的,交接时并没有原来团队的同事给我们做知识交接,所以当Jason和我收到这些模块的ticket时,我们是缺乏足够的知识去处理的,只能通过调试代码慢慢学习。运气不好的时候,一下子会来好几个高优先级的ticket,并且描述的问题对Jason和我都相当陌生。面对这种知识匮乏而带来的巨大挑战,在我印象中我从未看到过Jason有任何慌乱的神情。Jason总是很沉着地把ticket按照难易程度排序,然后和我分头去处理。他这种遇到挑战总是能冷静去面对的能力也鼓舞着我,确保了我总是能以100%清醒的头脑去分析问题。

以下的内容是Jason的正文。


前言: 回顾是最好的成长

SAP成都研究院的程序猿Jerry Wang向我约稿,要我谈一谈是如何从一名程序猿转型为产品经理的。正好2017年年末罗振宇的跨年演讲“时间的朋友”火爆朋友圈,很高兴有机会借用一下人生算法的概念,对过去进行回顾。而回顾,是一个人最好的成长方式。所以,故事就从我进入SAP成为程序猿开始吧。

程序猿:把一件事情做好

和SAP结缘,那是十年前了。那时候SAP成都分公司才成立一年多。

刚开始不会的东西太多,为了完成任务,需要不停地请教别人。不管是参加内部讲座,还是收看公司内的邮件,到处都是陌生的术语,到处都是一路深入都点不完的链接。有一种已经被信息和知识淹没的焦虑感,有点无所适从。

参加与外国同事的会议,也让我压力很大。虽然我只是一个无名小卒,即使外国同事的英语听不懂,也有团队里的前辈顶着。可是总不能什么事情都一直躲在别人身后吧。

好在团队里互相帮助、积极努力的氛围很浓。其中有个印象比较深的同事,我们叫他番茄。非常有活力,浑身充满能量,不仅聪明,还非常勤奋。

那时,我只有一个信念,加倍努力,站稳脚跟。我很用心地做好我该做的事情。慢慢的,我可以做比别人多的任务。再后来,就有人请教我问题了。

我想,努力就应该是一个年轻人的标配。那时候没去想那么多人生的大道理,也没有什么职业发展规划。我只是有个小目标:把一件事情做好,成为一个领域的专家。否则没有全力以赴过,怎么知道是否擅长、是否喜欢这份工作?!

于是,两三年的时间里,我都把自己的精力聚焦在数据仓库和分析方面,不仅具备了可以为团队贡献自己知识的能力,也在驱动团队在这个领域相关工作的推进。

在这个过程中,非常感谢我的经理Henry,为我提出了富有挑战的目标,那就是不仅要自己优秀,还要帮助团队成员成长,在这个产品的全球组织中有能见度。于是,我组织了技术话题的学习小组,引导、帮助更年轻的同事一起探索最新的课题。我也积极接触德国同事,不仅从他们那里学到新的知识,也参与他们的讨论,为整个产品做出贡献,从而赢得对方的信任。

把一件事情做好,让我爬上了一座小山,从而有机会看到更多的山。其实,这就是专注,努力,这是一种人生态度。这是我在SAP实践的第一种人生算法。

Scrum Master:不低看自己的工作

接下来的几年,我经历了不同的产品和部门。虽然我依然能够又快又好的完成任务,也能勇敢面对未知的技术难题并找到办法攻克。但是,渐渐地我觉得成为技术牛人不能给我带来更多的满足,在深入钻研技术方面我难以做到持久。2011年的时候,正好公司正在推广Scrum这种软件项目管理方式,而我对管理有些兴趣。于是,很自然的,我尝试了Scrum Master这个角色。

简单来说,Scrum Master是负责一个团队按照Scrum方式运行的角色,相当于敏捷教练。Scrum当时对我和我的团队来说,都是一个新鲜事物。我又一次进入亢奋状态。从参加培训、四处找资料开始,参与公司内外论坛,组织Scrum Master圆桌会议,建立和其他团队Scrum Master的联系网络,从而建立更新自己知识库的生态系统。

从公司安排的Scrum导入培训当中,我知道了基本概念和流程。而在实践当中,我留意到了很多问题,比如如何避免反复的交付延迟,如何把Retrospective大会开好,如何有效管控项目风险,如何实现真正的快速迭代开发。带着这些问题,我在学习中去寻找答案。而在不断学习的过程中,我又能受到启发、得到很多新的想法。

那时候,我觉得最有自我满足感的事情就是,我又学到了新的东西,并把那些新想法引入团队。某种程度上,我是团队的改革引领者,有成就感。

可是,另外一方面,Scrum Master要做的事情很杂,难以专注提高自己的技术能力。所以,从事自己喜欢的工作固然重要,但是很多情况下,难以完全实现。这时,发现工作的价值与意义,就非常关键。我觉得我最深的一个体会就是,从别人看来也许普通的工作当中看到了巨大的、提升自我价值的机会。我想我没有辜负那段时间。

最初推动落实Scrum流程的过程中,如果只是满足于主持各种会议、当救火队员,我想那对团队和个人来讲价值太低了。但是当把好奇的眼光打开,会发现很多公司内外关于敏捷或大或小的最佳实践。比如Done Criteria workshop,就是我在学习中了解到的一种实践方法,用来解决团队中backlog关闭比较随意、关闭之后仍然不断有后续任务和问题冒出来的情况。我了解了一下其他团队的做法,整理了一些范例,成功地带领团队定义了自己的Done Criteria,并应用在实际工作中。其它思考并实践过的有Usable Software,结对编程、Ready Criteria、测试驱动、团队知识管理、持续改进、敏捷测试等等。了解、思考和尝试这些新方法论的过程,就是增加个人价值的过程。

后来,我思考更多的是如何带领团队并不断取得成绩。这是一个难得的锻炼机会。就算是叱咤商业领域的那些风云人物不都在强调带团队吗?给一个队伍,怎么带出战斗力?这是一个必须不断实践练习才能习得的能力。比如对于团队建设,我也有一个认识不断深入的过程。刚开始的时候,对于团队建设的理解也是停留在大家一起吃吃饭、玩一玩的层次上。后来,通过接触这方面的知识,才知道有很多团队建设的方法。另外,我也思考过如何打造学习型团队,如何提升团队的凝聚力,如何分析团队的成熟度并让团队成长为自组织团队,从而让Scrum Master的作用逐渐淡化。这些探索和学习都增加了我的经验和能力。

相对程序猿,Scrum Master有更多的机会和产品经理、直属领导以及其他团队打交道。如果有心,总是很容易就能发现比自己牛得多的人,从而从别人身上学到东西。我相信,如果一个人接触的高手很多,那他也成为高手的概率要大得多。退一步先不说能不能成为他们那样的人,即使能在个人水平的某个方面向他们靠拢一点点也足以激励自己。记得那时接触ThoughtWorks和其他在敏捷社区中很活跃的人,从他们的见解中受益匪浅那是必须的,我还能感觉到他们对从事并传播敏捷有传教士般的热情。对此,除了敬佩不已、自愧不如之外,我也深受鼓舞。

Scrum Master有非常多的机会锻炼并提高软技能。我需要考虑如何平衡来自团队内外不同方面的要求,如何在团队内外协调进度并解决复杂问题,如何处理自己繁杂的任务,如何提高自己和团队的工作效率,如何帮助团队并管理好项目。这些都需要倾听、有效沟通、时间管理、领导力、自我管理等软技能。这是我第一次深刻认识到,无论一个人的职业发展方向是什么,软技能在个人能力结构中占有如此重要的地位,以至于当你缺乏它的时候,你迟早会遇到向上发展的天花板。如果说硬技能的高低决定一个人能否完成某项任务,那么软技能则会决定一个人在职业生涯中往上发展的潜力。

我想,这是我在SAP历程中最重要的一个转折点。不低看工作,而是靠着挖掘工作的价值,另外一扇综合提升自己的大门开启了。就像那些厉害的程序猿,也善于在普通的工作当中提升价值一样,我们需要靠着这个强大的人生算法在日常忙碌的工作当中,思考如何在技术快速更新的时代不让自己的知识贬值,总结疑难问题分析思路和快速学习方法,发现不同编程语言、不同领域背后的共性。

实施顾问:找点更难、更挑战的事情

做了几年的Scrum Master,虽然还是有空间可以发挥、进步,但是,我觉得需要一点更难、更挑战的工作。我了解到实施顾问需要快速学习,压力大和加班是必不可少的。于是,2014年的时候,我转去做实施顾问。刚到杭州客户现场准备常驻的时候,还是有点忐忑,怕自己长期面临压力不能适应,怕自己难以应付客户的挑战,怕在和标准产品开发迥然不同的客户项目中难以立足。

果然,不久我就遇到一件比较棘手的事情。客户要求在SAP CRM的销售订单界面中进行大量的功能增强,并和ERP集成。由于我有开发背景,所以我既负责和客户谈需求并整理成需求描述文档,也参与部分方案设计和开发工作。很快我就了解到了技术方案的复杂性。如果贸然进行功能增强的开发,不仅要占用比较大的开发人力资源,未来系统升级也会面临风险。这当中是否有风险巨大的坑,我在研究各种相关资料并咨询德国专家之后,有了些眉目,但也依然拿不准。在我的坚持之下,这件事情很快就在整个项目组范围内讨论了,并在相关专家的参与下确定了最终的技术方案。

再后来,虽然任何时候都有一个长长的、做不完的任务列表,也经常不得不加班到深夜,但是,一旦做好吃苦和迎接挑战的准备,那就都不是事了。

甚至,我喜欢上了这种漂泊在外的生活。在工作累得像狗之后,坐在五星级酒店的会员酒廊里品着酒、眺望西湖,很容易就有把时间浪费在美好事物上的感觉了。我终于觉得这就是我想要的有意义的生活,在工作中拼搏,在生活中享受。除此之外,生命没有任何浪费。

后来由于项目意外终止,同时要顾及将要出生的小孩,我只好回到开发团队。因此,我非常珍视这段经历。我初步有了和客户打交道的经验,体验到了和项目团队其他背景各不相同的成员相处的微妙之处,知道了客户项目实施的过程,也接触到了企业的业务需求。最重要的是,我知道了另外一个人生算法:勇敢些,没有什么困难是征服不了的。

产品经理:抬头看天,打开格局

在做实施顾问期间,每天都要和客户讨论需求,将之转化为需求描述文档并最终参与实现。有了这段经历,我对产品经理这个职位有了更多了解,并产生了浓厚的兴趣。加上在开发和项目管理方面的积累,2015年我成为了产品经理。

《启示录》一书中这样描述“产品经理”这个职位:去交付有价值、可用且合理的产品。相应地,我开始从用户体验、技术和商务三个方面积累技能。

然而,刚开始的时候,很辛苦,但是不得要领。由于惯性的作用,不由自主的就想把过去的经验发挥出来。于是以一个有经验的过来人身份为团队排除难题和风险、为项目保驾护航,介入了项目筹备、设计、质量和开发工作的一些细节中。而对于产品需求管理这项重中之重的本职工作反而着力不够。

这当中同事对我的反馈帮助很大。尤其是这样一句话让我印象深刻:抬头看天,低头看路。换一个说法就是要眼高手低。“眼高”,就是视野要开阔,能够从更高的角度思考问题;“手低”,则是能够低下手来,脚踏实地做事情。后者我做到了。而前者则是我缺乏的。

所以我开始看书,看相关的新闻和文章,研究相关产品。我试图对所从事的客户交互领域有更宽的理解,对相关市场的发展趋势和公司内外的技术趋势有所把握,了解用户体验和商业模式相关的知识。我想,只有深刻地理解了这个领域的特点、背后的驱动力和用户痛点,才能把握住整个产品的发展方向。方向对了,产品至少成功了一半,方向一旦错了,所有的努力都白费了。

在观察宏观话题的过程中,我的思维升级了,几乎可以说世界观都变了。因为商业市场和专业领域实在太过喧嚣,有太多的现象,有太多的概念,诸如互联网经济红利,注意力经济,人工智能,长尾效应,共享经济等等。但是,这些概念和现象背后具有共性和本质的东西是什么?和我的工作有什么联系?这些问题无时无刻不在吸引着我去思考和探索。慢慢地,就有了自己的理解。比如,当讲到新零售、全渠道和线上线下融合的时候,其实是在讲用户体验,在讲场景,在讲拉近商品、服务与用户的距离。那我们做的客户交互解决方案最终就是要解决如何在场景中用户需要的时候恰好就能得到需要的服务。这其实就是在透过现象看本质,在用逻辑思维能力去重构自己的认知。

看得多、想得多了之后,就会有强烈的感觉:不同领域的知识,要么互相连接,要么有想通之处,到最后,总会有“哇, 原来如此!”的感觉。打开眼界和格局之后,再看我做的产品,就有了更丰满的理解。我相信,去看整个技术、经济、商业、社会、历史发展的脉络,就是在培养格局。这是一种重要的受益终生的人生算法。

结束语:油腻中年?

回过头看走过的路,虽然曾经也焦虑过油腻中年的危机,懊恼过财富自由的幻灭,迷茫过我究竟想要什么样的职业生涯。可是,我看到了自己的进步。我就是在不断迎接挑战和不断反思的过程中成长并完成转型的。

相信很多人和我一样,看过很多诸如XX是成功的关键,XX决定一切的鸡汤文,那个XX可以换成情商、信念、态度、习惯、执行力等等。一开始觉得很有道理,甚至会觉得像打了鸡血。但是,慢慢的,看过也就看过了,行动也沦为浅尝辄止。似乎只是水面上起过一些涟漪,最后什么也没改变。从过去的经历当中,我看到了在我身上发生一些改变的原因,那就是只要全力以赴、勇于突破自己,工作自然会和这些不同的人生信条发生连接,就会有无数个机会练习。

展望2018,波澜壮阔的技术和商业创新以及中国崛起,给了我仔细观察这个时代的冲动。毫无疑问,这是最好的时代!从工作相关的视角学习新的知识,从而去看懂它,连接它,并把灵感带回工作中,这是多么有意义的事情!

我相信,应对未来最好的方式就是把握现在,就是不断迭代、找到新的人生算法,重复它,强化它,专注于成为一个更好的自己!

要获取更多Jerry的原创技术文章,请关注公众号"汪子熙"或者扫描下面二维码:

从程序猿到SAP产品经理,我是如何转型的?的更多相关文章

  1. CSDN日报20170416 ——《为什么程序猿话少钱多死得早?》

    [程序人生]为什么程序猿话少钱多死得早? 作者:文奇 我在想,程序猿都是话少吗?不一定吧.像我和我的同学.都是话非常多啊. 可是经历过非常多事的如今.再想想,发现事实的确如此.程序猿确实话少. 我是一 ...

  2. 人人都是产品经理?关于PM你不知道的还有很多

    产品经理的职称最早出现在P&G宝洁公司,因效果非常显著,许多企业纷纷仿而效尤.硅谷知名的产品管理大师Marty Cagan在<Inspired: How To Create Produc ...

  3. 「给产品经理讲JVM」:垃圾收集算法

    纠结的我,给我的JVM系列终于起了第三个名字,害,我真是太难了.从 JVM 到 每日五分钟,玩转 JVM 再到现在的给产品经理讲 JVM ,虽然内容为王,但是标题可以让更多的人看到我的文章,所以,历经 ...

  4. 【总结整理】AI产品经理大会2017(转载)

    从企业大数据到企业 AI | 易观智慧院院长 李智 1.AI 不是目的,而是要了解 AI 是什么,真正意义上的强人工智能在前沿领域尚未取得突破,暂时只能在影视文学作品中去思考人机关系.机器人三定律在未 ...

  5. SAP成都研究院非典型程序猿,菜园子小哥:当我用UI5诊断工具时我用些什么

    身边有些年轻同事曾经向我表达过这种困扰:尽管完成日常工作没有任何问题,但是还想更进一步,把代码写得更好些,做到精益求精.现在写的代码能实现功能,但是不知道可以怎样写得更好. 除了阅读优秀的开源库开源框 ...

  6. SAP成都研究院飞机哥:程序猿和飞机的不解之缘

    今天的文章来自Jerry的老同事张航. 张航和Jerry一样于2007年毕业后加入SAP成都研究院工作至今.进入SAP后的第一个开发部门是SAP Business by Design Infrastr ...

  7. 产品经理与程序员矛盾&相处

    产品运营 - 知乎https://www.zhihu.com/topic/19551958/hot 产品经理与程序员矛盾的本质是什么? - 知乎https://www.zhihu.com/questi ...

  8. 前端,Java,产品经理,微信小程序,Python等资源合集大放送

    为了感恩大家长久以来的关注和支持,小编准备了一些福利,整理了包含前端,Java,产品经理,微信小程序,Python,网站源码,Android应用视频教程,微信公众平台开发教程及材料等资源合集大放送. ...

  9. 【产品经理】产品经理不懂API接口是什么,怎么和程序员做朋友?

    接口不是技术经理来写吗?没接过它,一脸不清楚地节奏 开放即共享,是互联网的一个重要属性和精神.它是一种服务模式,一个特殊的产品,目前较大规模的互联网企业都有自己的开放平台. 如果把自己局限为一个功能产 ...

随机推荐

  1. 《深入分析Java Web技术内幕》读后感(Tomcat)

    第11章 P286 Tomcat总体结构 1.service 2.server 3.组件的生命 Connector Container 1.容器的总体设计 2.Engine容器 3.Host容器 4. ...

  2. Automake使用说明

    说明 从零开始编写automake工程非常复杂也没有必要,我们只要能看懂开源项目的automake即可,然后根据自己实际情况进行修改即可,下面给出两个比较好的参考项目,其中spice-gtk涵盖了使用 ...

  3. DIV文字水平垂直居中的方法

    水平居中 text-align:center 垂直居中(vertical-align) vertical-align:middle; vertical-align时而没效果 然而真实使用的时候,我们会 ...

  4. Git 分支管理 解决冲突

    人生不如意之事十之八九,合并分支往往也不是一帆风顺的. 准备新的feature1分支,继续我们的新分支开发: $ git checkout -b feature1 -- 在feature1分支上修改r ...

  5. bzoj 2535: [Noi2010]Plane 航空管制2【拓扑排序+堆】

    有个容易混的概念就是第一问的答案不是k[i]字典序最小即可,是要求k[i]大的尽量靠后,因为这里前面选的时候是对后面有影响的(比如两条链a->b c->d,ka=4,kb=2,kc=3,k ...

  6. 非常实用的Sublime插件集合 – sublime推荐必备插件

    插件介绍 ***PackageControl*** 功能:安装包管理 简介:sublime插件控制台,提供添加.删除.禁用.查找插件等功能 使用方法: 1.安装好控制台,如有不能正常调用 Packag ...

  7. jmeter后置处理器之正则表达式

    一.基本用法——提取某个值 场景:提取某个值,保存成变量,供后面的接口使用 步骤: 1.运行脚本,从响应结果中查找要提取的值,找到左右边界. 例如要获取“patientInfoId”作为下一个请求的参 ...

  8. NOIp知识集合 By cellur925

    基本算法 快速幂 ll ksm(ll a,ll b) { ll ans=; while(b) { ) ans=ans*a%p; b>>=; a=a*a%p; } return ans; } ...

  9. git clone 指定新建本地库位置

  10. Vuex有哪些作用

    1.Vuex实现路由数据通讯 点击跳转路由的时候,把写入vuex,跳转后取出vuex