【IT168 评论】近几年,被提到频率最高的一个词应该非“数据”莫属。各行各业都在提转型,转型靠的是什么?数据,所以无论是社交媒体还是智能设备或者是电子商务,都在向企业提出数据要求。
电子商务作为近年来高速发展的行业,其对数据更为依赖。NoSQL数据库不仅成本比其他选择更为低廉,而且它可以大幅提升性能进而刺激电子商务的创新,所以电子商务领域的下一个竞争优势很可能就是数据库。
竞争优势其实是一种很玄妙的东西。举个例子,几年前免运费可能是电子商务的竞争优势,但是现在包邮已经成为了行业标准。电子商务平台之前也是电子商务的竞争优势,其支持根据客户业务来进行功能集成。但现在几乎所有的电子商务平台都提供类似的功能。
在这种情况下,你想要崭露头角就必须寻找新的竞争优势,如客户体验。客户体验是最近大家都在提的一个话题,无论是零售商还是大企业,都在试图为消费者提供更多相关、个性化以及精准的购物体验。
要做到这一点,企业需要多种技术的助力,如大数据分析、机器学习、人工智能等等。
NoSQL数据库的竞争优势
围绕购物体验电子商务有几种方法可以提升竞争力,但是有一种总是被大家忽视,那就是数据库的选择。
大多数电子商务平台都依赖于关系数据库管理系统—RDBMS,这类数据库往往都有成熟的软件、应用程序和网站,从某种意义上来说,其对电子商务业务有很大助益。RDBMS虽好,但在很多应用中其并不适合电子商务。
RDBMS的表格结构并不能很好的管理产品信息。《MongoDB实战》的作者Kyle Banker曾说道:“如果你去查看在关系型数据库上运行的电子商务平台,那么你就会发现数据库中的很多表都在一起工作,顶尖的数据库系统根本无法展现其灵活性的优势。”
在RDBMS中处理产品数据时,开发人员必须使用相对复杂的数据模型,如实体、属性、价值;类表继承或字符大对象 (CLOB)。
而NoSQL则恰恰相反,其管理产品、订购和客户数据相对容易,可以让商家收集更多的购物者和销售数据。这样商家就可以更容易地分析数据,并实施真正改善购物体验的解决方案,获得竞争优势。
这也就意味着,如果一家公司看重电子商务平台或产品信息管理平台等软件解决方案,那么它更希望寻找一个基于NoSQL的解决方案。
NoSQL数据库的优势
与关系数据库相比,NoSQL可以提供更好的性能,可扩展性,可用性,可负担性和灵活性。
性能:NoSQL数据库通常对电子商务应用程序中常见查询的响应更快。 当访问者查看产品详细信息页面或运行站点搜索时,该访问者有效地与您的数据库进行交互。 因此,更快的数据库可以造就更好的站点性能。
可扩展性:RDBMS通常在单个服务器上运行。为了业务满足需求,企业往往需要购置一个很大、很昂贵的服务器。而NoSQL数据库通常构建在分布式和较便宜的服务器上运行。所以在“购物节”的运营高峰时段,NoSQL可以很容易的扩展。
可用性:通常在构建NoSQL数据库时都会考虑到服务器发生故障的问题,当出现问题时会立即切换到另一个服务器中。
NoSQL数据库倾向于使用小而便宜的服务器群集,因此当单个服务器出现故障时,NoSQL数据库可以继续工作。
负担能力:由于NoSQL数据库在相对使用经济的服务器集群上运行,而RDBMS则需相对较大和功能更强大的服务器,因此NoSQL可以减少您的业务费用。
灵活性:NoSQL文档数据库的数据结构是在代码中执行,而不是在数据库中执行,因此NoSQL可以以多种形式,结构化或非结构化方式获取数据。这就有助于从多个数据源中来收集产品信息。
NoSQL数据库的事务完整性
如果有人对电子商务使用NoSQL提出异议,那么一定是因为它的交易完整性和NoSQL的灵活性。如果你经常逛NoSQL与RDBMS的论坛,那么你可能会看到很多类似的评论。
使用MySQL或者是其它RDBMS的最大优势就在交易业务,使用事务可以确保业务按正确的顺序进行操作并完成,但是使用NoSQL则无法保证。
从表面来看,NoSQL数据库在这方面是不受约束,通常也不会以与RDBMS相同的方式执行事务或模式。但其实这并不是一个数据库事务完整性的问题,而是执行事务完整性的问题。典型的RDBMS,数据库可以确保事务完整性。而典型的NoSQL数据库,开发人员可以在代码中强制执行事务完整性。
举个不太恰当的例子,假设现在你想要买一辆汽车,有两个选择,一是花费100美元购买全新的法拉利,但是它不附带收音机,二是花费399美元购买带有收音机的1985 Yugo GV。笔者相信大部分人都明白法拉利即使没有收音机也是更具价值的。
这时,你再返回来想想,NoSQL就像那个没有收音机的法拉利,你会因为一个收音机而选择RDBMS吗?
虽然在本文发表时,很多电商企业还在使用RDBMS,但是像亚马逊,沃尔玛和eBay等行业领导者已经在其系统中开始使用NoSQL数据库,所以我们有理由相信NoSQL数据库可能是未来新的竞争优势所在。