爬虫数据采集接单,大小不限,欢迎各位科研教师,学生,企业相关人员咨询,QQ:739848314
再确定需求的过程中,客户的需求也极为简单。他连自己要想的表结构都没有想法,完全我自定义,事情更简单了,但是在接下来的编码过程中,真的耗尽了我所有的耐心,真的有一种生不如死的感觉。
客户要求用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 BoxList = new List();
}
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 BoxList = new List(),大家也都看到了,这几个类中并没有的VisioBoxOutput定义。
于是问客户VisioBoxOutput是怎么回事,客户说有问题,让我等等。 好嘛,这一个等等,足足从上午等到下午两点钟,然而事情并没有完。
你们根本猜不到接下来的事情,事情发生在下午的两点多钟,下午两点多钟客户终于联系我了。我真的火不打一处来,你要下午演示,然后上午临时该需求,你的代码有问题,让我等等你人不见了,然后到下午你又出现了。
你是找我来要演示的吗?但是客户也不是来解决VisioBoxOutput的问题。然而这次客户直接甩给我了一个接口。
复制代码
public interface IOperationDB
{
///
/// 如果不存在DB,则创建DB
///
/// DB全名称
/// DB表头,逗号分隔
///失败时返回错误信息
/// 返回实例
IOperationDB InitDB(string dbFullName, string tableHeads, ref string msg);
///
/// 插入数据
///
/// 数据,采用逗号分隔
/// 失败时返回错误信息
///
bool InsertDB(string data, ref string msg);
///
/// 删除数据
///
/// 开始时间
/// 终止时间
/// 指定列和对应的值
/// 失败时返回错误信息
/// 成功返回true,失败返回false
bool DeleteDB(DateTime startTime, DateTime endTime, Dictionary selectValue, ref string msg);
///
/// 查询数据
///
/// 开始时间
/// 终止时间
/// 指定列和对应的值
/// 失败时返回错误Q信息
/// 成功返回true,失败返回false
DataSet FindDB(DateTime startTime, DateTime endTime, Dictionary selectValue, ref string msg);
///
/// 修改数据库
///
/// 开始时间
/// 终止时间
/// 约束,指定列和对应的值
/// 修改指定列和对应的值
///
bool UpdateDB(DateTime startTime, DateTime endTime, Dictionary selectValue, Dictionary value);
}
复制代码
当时心里产生了一股不祥的预感,你要干啥、不会让我按照你接口的定义来吧?
但我还是怀着忐忑的心情
我:?
亲:你这是什么意思?
客户:接口
我:你啥意思?
我:你不会让我按照你的接口做吧?
客户:嗯。
当时心中的怒火真的压不住了,明确的跟客户表示。不行,绝对不行。
为啥不行?我的程序都让我写的七七八八的了,数据库操作都已经完全弄好了,你给我发这个接口啥意思?你是要我推翻了重写吗。你也是搞程序的,你不知道这其中的工作量,你跟我开玩笑呢?
然而客户犟的很,客户坚持要我实现接口,时间可以延一点。不行,绝对不做。你从昨晚折磨我到现在,不做了。我肯定不干了,都不如我一天工资,我犯得着么。
当时我的想法真的很坚决,不干绝对不干了。当时心里真的无比放松,好像自己赚了一大笔一样,事实上我只是回到了平时的生活而已。然而过了一会客户私聊我,好声好气的商量我还是要我继续做。我加钱的要求他也答应了,算了别跟钱过不去继续做吧。
然而,我真是后悔我的决定,那几个接口我一开始并没有仔细看,既然要做了,就去看一下接口的定义吧,发现。
完全看不懂
完全看不懂
完全看不懂
再贴一次接口的定义吧
复制代码
public interface IOperationDB
{
///
/// 如果不存在DB,则创建DB
///
/// DB全名称
/// DB表头,逗号分隔
///失败时返回错误信息
/// 返回实例
IOperationDB InitDB(string dbFullName, string tableHeads, ref string msg);
///
/// 插入数据
///
/// 数据,采用逗号分隔
/// 失败时返回错误信息
///
bool InsertDB(string data, ref string msg);
///
/// 删除数据
///
/// 开始时间
/// 终止时间
/// 指定列和对应的值
/// 失败时返回错误信息
/// 成功返回true,失败返回false
bool DeleteDB(DateTime startTime, DateTime endTime, Dictionary selectValue, ref string msg);
///
/// 查询数据
///
/// 开始时间
/// 终止时间
/// 指定列和对应的值
/// 失败时返回错误Q信息
/// 成功返回true,失败返回false
DataSet FindDB(DateTime startTime, DateTime endTime, Dictionary selectValue, ref string msg);
///
/// 修改数据库
///
/// 开始时间
/// 终止时间
/// 约束,指定列和对应的值
/// 修改指定列和对应的值
///
bool UpdateDB(DateTime startTime, DateTime endTime, Dictionary selectValue, Dictionary value);
}
复制代码
我当时真的好不解啊,initDB是干啥用的,难道是创建database的么,那tableheader咋用,为啥结构还有再返回当前接口?
复制代码
///
/// 如果不存在DB,则创建DB
///
/// DB全名称
/// DB表头,逗号分隔
///失败时返回错误信息
/// 返回实例
IOperationDB InitDB(string dbFullName, string tableHeads, ref string msg);
复制代码
insert ,你insert到哪啊?你一个string类型我怎么对应到数据表啊?那个是表名
复制代码
///
/// 插入数据
///
/// 数据,采用逗号分隔
/// 失败时返回错误信息
///
bool InsertDB(string data, ref string msg);
复制代码
还有这几个方法,删除。deleteDB,你是要删除整个数据库吗?starttime,endtime,selectvalue是干啥的,还是说删除表,那也没有指定那张表啊?你这玩意咋用?
下方的update,find都有相同问题。
复制代码
///
/// 删除数据
///
/// 开始时间
/// 终止时间
/// 指定列和对应的值
/// 失败时返回错误信息
/// 成功返回true,失败返回false
bool DeleteDB(DateTime startTime, DateTime endTime, Dictionary
///
/// 查询数据
///
/// 开始时间
/// 终止时间
/// 指定列和对应的值
/// 失败时返回错误Q信息
/// 成功返回true,失败返回false
DataSet FindDB(DateTime startTime, DateTime endTime, Dictionary selectValue, ref string msg);
///
/// 修改数据库
///
/// 开始时间
/// 终止时间
/// 约束,指定列和对应的值
/// 修改指定列和对应的值
///
bool UpdateDB(DateTime startTime, DateTime endTime, Dictionary selectValue, Dictionary value);
复制代码
实在猜不出,问客户。问了好久好久,双方你一言我一语沟通了近一小时无结果,客户都解释不清自己的接口到底是啥玩意,到底要怎么用,我实在要气疯了,我要求客户你写出一个接口的调用实例,然而客户也没给我。咋办?初步猜想,这个接口肯能是正在学习 的学生做的,经验不足导致。遂问,这个接口是谁定义的,最开始客户说不是自己。后来又说是他跟他一个学弟。算了,你们还是学生功力不够,我也不怪你们了,那这样,我好言好语的跟你商量下。
我:我说句实话你也别介意,实话实说,你们俩个还年轻,功力还差点。
客户:嗯嗯,你说的是实话。
我:那我免费帮你做个接口,给你,你可以学习下,不懂可以问我。
客户:不。
绝望了,他做的接口不能用,我给他定义接口还不要。。。。
行了,接口先放一放,慢慢研究。还有你那几个类的问题怎么解决,不知道业务逻辑,真的没法做,接下来真的更令我喷血,我按照那几个类做了那么久的更删改查,客户突然告诉我那三个类没啥用,跟我没关系,
我CNM,没关系!!!没关系的东西你给我干啥,上午你跟我研究那几个类研究那么久到底在干啥,贴几张图。
真的,怒火中烧。绝逼不做了,如果你站在我面前我不打死你算我脾气好,爱哪哪去,爱谁谁做!
总结下客户的奇葩需求:
一定要使用vs2013,熬夜下载配置
本来简单的增删改查,结果要按照他的结构来,改
类结构有错误,等
按照他的接口标准,改
接口定义不明,问。
解释不明白,艹。
按照类结构做的增删改查不用,cnm
总之一句话,程序员再接私活眼镜擦亮。我们不是什么样的客户都要伺候,程序很讲理,客户不讲理。