Error message here!

Hide Error message here!

忘记密码?

Error message here!

请输入正确邮箱

Hide Error message here!

密码丢失?请输入您的电子邮件地址。您将收到一个重设密码链接。

Error message here!

返回登录

Close

容我缓缓神,记一次气的心脏病发作的经历

鱼丸粗面一碗 2019-01-28 08:56:00 阅读数:124 评论数:0 点赞数:0 收藏数:0

事情是这样的,前天晚上在家开着电脑抠着脚丫写着爬虫。然后接到了一个需求,一个学生想要做个东西,关于MongoDB的。这个东西我熟悉,可以做。经讨论客户的需求非常简单,一张表MongoDB中增删改查而已。商量好报价,交工时间,这还不简单吗,三两个小时的而已。

再确定需求的过程中,客户的需求也极为简单。他连自己要想的表结构都没有想法,完全我自定义,事情更简单了,但是在接下来的编码过程中,真的耗尽了我所有的耐心,真的有一种生不如死的感觉。

客户要求用vs2013版本。这都什么年代了,还用这上古的产品。而用户真的很倔强,商量了十几分钟,客户依然不肯妥协,一直以自己电脑装的2013为理由,拒绝接收其他版本。这都什么年代了,我都用2017了,你还抱着13不放。客户就是上帝,

客户强烈要求那能咋整,用呗。一个vs2013需要好几个G,安装配置也要不少时间。其实使用13版本也没啥问题,但是客户要求第二天下午功能演示,隔天早上交代码。而这么紧张的时间里我需要下载2013,配置mongodb,时间太过紧张了。

下载vs2013全下载好,然后安装完成,为了节省时间,多余的组件全不装,只保留winform功能。赚这两个钱我也真是拼了,环境搭好已经晚上11点多了,光配置环境超过2小时,一行代码都没有写。然而我白天还需要上班,加班加点的搞吧。除去界面之外增删改查全部搞定,再看看表,凌晨1点+,睡觉吧。

然而事情并没有这么简单,第二天一早。客户可发给我发来了几个类。我靠,嘛意思?让我按照这个类结构增删改查?昨晚你不是说什么都行吗?怎么现在又出来这些类结构。大不了我让一步吧,数据库的底层已经封装好,按照你的类结构操作表也不难。

也幸亏mongo没有Sql server,Oracle,mysql那种很强的表定义。

 public class AlarmGaugeRet : BaseEntity
{
public DateTime Time;
public int Status = 0; //复位=0,触发=1
public string LotNumber = "";
public AlarmNode Node;
}
public class AlarmNode : BaseEntity
{
public string AlarmName;
public int AlarmStaion;
public int AlarmLevel;
public int AlarmNum;
public string AlarmInfo;
public string Solution;
}
public class DataGaugeBase : BaseEntity
{
public DateTime Time;
public int RowID = -1;
public string Date = "";
public int Level = 0;
public string levelType = string.Empty;
public string levelDes = string.Empty;
public int BoxIdx = -1;
public string CutNum = string.Empty;
public string PosNum = string.Empty;
public string RecipeNum = string.Empty;
public string ProductNum = string.Empty;
public string MetNum = string.Empty;
public List<VisioBoxOutput> BoxList = new List<VisioBoxOutput>();
}
public class SystemGaugeRet : BaseEntity
{
public DateTime Time;
public int Status = 0;//StandBy=0;Running=1;Testing=2;Warnning=3;
public double Duration;
public string StatusDes;
}

于是问客户咨询,这几个类结构的业务关联是怎样的?毕竟需要作业面,如果搞不清业务关系,页面该如何显示?客户支支吾吾,支支吾吾。无论如何也说不明白,大家可能不信就这几个类的定义,磨叽了一个小时,最后得到结论

 

SystemGaugeRet 机台信息
DataGaugeBase 数据结构
AlarmGaugeRet 警告信息

墨迹了一个多小时,就得到这么几个结果。
DataGaugeBase 类里面有一个List<VisioBoxOutput> BoxList = new List<VisioBoxOutput>(),大家也都看到了,这几个类中并没有的VisioBoxOutput定义。
于是问客户VisioBoxOutput是怎么回事,客户说有问题,让我等等。 好嘛,这一个等等,足足从上午等到下午两点钟,然而事情并没有完。

你们根本猜不到接下来的事情,事情发生在下午的两点多钟,下午两点多钟客户终于联系我了。我真的火不打一处来,你要下午演示,然后上午临时该需求,你的代码有问题,让我等等你人不见了,然后到下午你又出现了。
你是找我来要演示的吗?但是客户也不是来解决VisioBoxOutput的问题。然而这次客户直接甩给我了一个接口。

 public interface IOperationDB
{
/// <summary>
/// 如果不存在DB,则创建DB
/// </summary>
/// <param name="dbFullName">DB全名称</param>
/// <param name="tableHeads">DB表头,逗号分隔</param>
///<param name="msg">失败时返回错误信息</param>
/// <returns>返回实例</returns>
IOperationDB InitDB(string dbFullName, string tableHeads, ref string msg);
/// <summary>
/// 插入数据
/// </summary>
/// <param name="data">数据,采用逗号分隔</param>
/// <param name="msg">失败时返回错误信息</param>
/// <returns></returns>
bool InsertDB(string data, ref string msg);
/// <summary>
/// 删除数据
/// </summary>
/// <param name="startTime">开始时间</param>
/// <param name="endTime">终止时间</param>
/// <param name="selectValue">指定列和对应的值</param>
/// <param name="msg">失败时返回错误信息</param>
/// <returns>成功返回true,失败返回false</returns>
bool DeleteDB(DateTime startTime, DateTime endTime, Dictionary<int, string> selectValue, ref string msg);
/// <summary>
/// 查询数据
/// </summary>
/// <param name="startTime">开始时间</param>
/// <param name="endTime">终止时间</param>
/// <param name="selectValue">指定列和对应的值</param>
/// <param name="msg">失败时返回错误Q信息</param>
/// <returns>成功返回true,失败返回false</returns>
DataSet FindDB(DateTime startTime, DateTime endTime, Dictionary<int, string> selectValue, ref string msg);
/// <summary>
/// 修改数据库
/// </summary>
/// <param name="startTime">开始时间</param>
/// <param name="endTime">终止时间</param>
/// <param name="selectValue">约束,指定列和对应的值</param>
/// <param name="value">修改指定列和对应的值</param>
/// <returns></returns>
bool UpdateDB(DateTime startTime, DateTime endTime, Dictionary<int, string> selectValue, Dictionary<int, string> value);
}

 

当时心里产生了一股不祥的预感,你要干啥、不会让我按照你接口的定义来吧?

但我还是怀着忐忑的心情

我:?

亲:你这是什么意思?

客户:接口

我:你啥意思?

我:你不会让我按照你的接口做吧?

客户:嗯。

当时心中的怒火真的压不住了,明确的跟客户表示。不行,绝对不行。

为啥不行?我的程序都让我写的七七八八的了,数据库操作都已经完全弄好了,你给我发这个接口啥意思?你是要我推翻了重写吗。你也是搞程序的,你不知道这其中的工作量,你跟我开玩笑呢?

然而客户犟的很,客户坚持要我实现接口,时间可以延一点。不行,绝对不做。你从昨晚折磨我到现在,不做了。我肯定不干了,都不如我一天工资,我犯得着么。

当时我的想法真的很坚决,不干绝对不干了。当时心里真的无比放松,好像自己赚了一大笔一样,事实上我只是回到了平时的生活而已。然而过了一会客户私聊我,好声好气的商量我还是要我继续做。我加钱的要求他也答应了,算了别跟钱过不去继续做吧。

然而,我真是后悔我的决定,那几个接口我一开始并没有仔细看,既然要做了,就去看一下接口的定义吧,发现。

完全看不懂

完全看不懂

完全看不懂

再贴一次接口的定义吧

 public interface IOperationDB
{
/// <summary>
/// 如果不存在DB,则创建DB
/// </summary>
/// <param name="dbFullName">DB全名称</param>
/// <param name="tableHeads">DB表头,逗号分隔</param>
///<param name="msg">失败时返回错误信息</param>
/// <returns>返回实例</returns>
IOperationDB InitDB(string dbFullName, string tableHeads, ref string msg);
/// <summary>
/// 插入数据
/// </summary>
/// <param name="data">数据,采用逗号分隔</param>
/// <param name="msg">失败时返回错误信息</param>
/// <returns></returns>
bool InsertDB(string data, ref string msg);
/// <summary>
/// 删除数据
/// </summary>
/// <param name="startTime">开始时间</param>
/// <param name="endTime">终止时间</param>
/// <param name="selectValue">指定列和对应的值</param>
/// <param name="msg">失败时返回错误信息</param>
/// <returns>成功返回true,失败返回false</returns>
bool DeleteDB(DateTime startTime, DateTime endTime, Dictionary<int, string> selectValue, ref string msg);
/// <summary>
/// 查询数据
/// </summary>
/// <param name="startTime">开始时间</param>
/// <param name="endTime">终止时间</param>
/// <param name="selectValue">指定列和对应的值</param>
/// <param name="msg">失败时返回错误Q信息</param>
/// <returns>成功返回true,失败返回false</returns>
DataSet FindDB(DateTime startTime, DateTime endTime, Dictionary<int, string> selectValue, ref string msg);
/// <summary>
/// 修改数据库
/// </summary>
/// <param name="startTime">开始时间</param>
/// <param name="endTime">终止时间</param>
/// <param name="selectValue">约束,指定列和对应的值</param>
/// <param name="value">修改指定列和对应的值</param>
/// <returns></returns>
bool UpdateDB(DateTime startTime, DateTime endTime, Dictionary<int, string> selectValue, Dictionary<int, string> value);
}

 

我当时真的好不解啊,initDB是干啥用的,难道是创建database的么,那tableheader咋用,为啥结构还有再返回当前接口?

 /// <summary>
/// 如果不存在DB,则创建DB
/// </summary>
/// <param name="dbFullName">DB全名称</param>
/// <param name="tableHeads">DB表头,逗号分隔</param>
///<param name="msg">失败时返回错误信息</param>
/// <returns>返回实例</returns>
IOperationDB InitDB(string dbFullName, string tableHeads, ref string msg);

 

insert ,你insert到哪啊?你一个string类型我怎么对应到数据表啊?那个是表名

 /// <summary>
/// 插入数据
/// </summary>
/// <param name="data">数据,采用逗号分隔</param>
/// <param name="msg">失败时返回错误信息</param>
/// <returns></returns>
bool InsertDB(string data, ref string msg);

 

  还有这几个方法,删除。deleteDB,你是要删除整个数据库吗?starttime,endtime,selectvalue是干啥的,还是说删除表,那也没有指定那张表啊?你这玩意咋用?

  下方的update,find都有相同问题。

 /// <summary>
/// 删除数据
/// </summary>
/// <param name="startTime">开始时间</param>
/// <param name="endTime">终止时间</param>
/// <param name="selectValue">指定列和对应的值</param>
/// <param name="msg">失败时返回错误信息</param>
/// <returns>成功返回true,失败返回false</returns>
bool DeleteDB(DateTime startTime, DateTime endTime, Dictionary<int, string> selectValue, ref string msg);
/// <summary>
/// 查询数据
/// </summary>
/// <param name="startTime">开始时间</param>
/// <param name="endTime">终止时间</param>
/// <param name="selectValue">指定列和对应的值</param>
/// <param name="msg">失败时返回错误Q信息</param>
/// <returns>成功返回true,失败返回false</returns>
DataSet FindDB(DateTime startTime, DateTime endTime, Dictionary<int, string> selectValue, ref string msg);
/// <summary>
/// 修改数据库
/// </summary>
/// <param name="startTime">开始时间</param>
/// <param name="endTime">终止时间</param>
/// <param name="selectValue">约束,指定列和对应的值</param>
/// <param name="value">修改指定列和对应的值</param>
/// <returns></returns>
bool UpdateDB(DateTime startTime, DateTime endTime, Dictionary<int, string> selectValue, Dictionary<int, string> value);

 

实在猜不出,问客户。问了好久好久,双方你一言我一语沟通了近一小时无结果,客户都解释不清自己的接口到底是啥玩意,到底要怎么用,我实在要气疯了,我要求客户你写出一个接口的调用实例,然而客户也没给我。咋办?初步猜想,这个接口肯能是正在学习           的学生做的,经验不足导致。遂问,这个接口是谁定义的,最开始客户说不是自己。后来又说是他跟他一个学弟。算了,你们还是学生功力不够,我也不怪你们了,那这样,我好言好语的跟你商量下。

我:我说句实话你也别介意,实话实说,你们俩个还年轻,功力还差点。

客户:嗯嗯,你说的是实话。

我:那我免费帮你做个接口,给你,你可以学习下,不懂可以问我。

客户:不。

绝望了,他做的接口不能用,我给他定义接口还不要。。。。

 

行了,接口先放一放,慢慢研究。还有你那几个类的问题怎么解决,不知道业务逻辑,真的没法做,接下来真的更令我喷血,我按照那几个类做了那么久的更删改查,客户突然告诉我那三个类没啥用,跟我没关系,

我CNM,没关系!!!没关系的东西你给我干啥,上午你跟我研究那几个类研究那么久到底在干啥,贴几张图。

 

 

真的,怒火中烧。绝逼不做了,如果你站在我面前我不打死你算我脾气好,爱哪哪去,爱谁谁做!

总结下客户的奇葩需求:

  • 一定要使用vs2013,熬夜下载配置
  • 本来简单的增删改查,结果要按照他的结构来,改
  • 类结构有错误,等
  • 按照他的接口标准,改
  • 接口定义不明,问。
  • 解释不明白,艹。
  • 按照类结构做的增删改查不用,cnm

 

总之一句话,程序员再接私活眼镜擦亮。我们不是什么样的客户都要伺候,程序很讲理,客户不讲理。

版权声明
本文为[鱼丸粗面一碗]所创,转载请带上原文链接,感谢
https://www.cnblogs.com/abountme/p/10319185.html

编程之旅,人生之路,不止于编程,还有诗和远方。
阅代码原理,看框架知识,学企业实践;
赏诗词,读日记,踏人生之路,观世界之行;

支付宝红包,每日可领