回答

收藏

数据库和函数式编程是否不一致?

技术问答 技术问答 77 人阅读 | 0 人回复 | 2023-09-13

我已经从事Web开发已有一段时间了,最??近开始学习一些函数式编程。像其他人一样,我在将许多这些概念应用于我的专业工作时遇到了很大的麻烦。对我来说,主要原因是我看到FP保持无状态的目标之间存在矛盾,这与我所做的大多数Web开发工作都与数据库紧密相关,而数据库是非常以数据为中心的。6 h4 D8 |$ t* J7 p6 }2 w2 r
使我成为OOP方面更具生产力的开发人员的一件事是发现了对象关系映射器,例如用于.Net的MyGeneration d00dads,用于perl的Class
7 A0 ?7 w7 ?* x::
" Q! C- V+ P1 eDBI,用于ruby的ActiveRecord等。这使我远离了从整天编写插入和选择语句开始,并专注于轻松地将数据作为对象来使用。当然,当需要SQL查询时,我仍然可以编写它们,但是在其他情况下,它却被很好地抽象了。: @, r8 r& g7 d2 M+ H4 G. @
现在,转向函数式编程,对于许多FP& L" O' K4 x1 d. ]! H8 y* F  h
Web框架(如Links)来说,似乎需要编写许多样板sql代码,如本例所示。Weblocks似乎更好一些,但是它似乎使用了一种OOP模型来处理数据,并且仍然需要为数据库中的每个表手动编写代码,如本例所示。我想您使用了一些代码生成来编写这些映射函数,但这似乎绝对不像lisp。
6 X! S* j+ G- g* g4 w3 G(请注意,我并未非常仔细地查看Weblocks或Links,可能只是误解了它们的用法)。
7 V+ {3 C! ]- E+ G所以问题是,对于Web应用程序的数据库访问部分(我认为这是相当大的),或者对于其他需要与sql数据库进行接口的开发,我们似乎被迫遵循以下路径之一:& i  _( e' H$ j
[ol]不要使用函数式编程! N$ R( E6 n# W* j9 ^) J- f, d
以一种烦人,轻松的方式访问数据,其中涉及手动编写许多SQL或类似SQL的代码ala链接% H% Q# t  Q/ K5 `& E/ h4 C0 Z
将我们的函数式语言强制为伪OOP范式,从而消除了真正的函数式编程的某些优雅和稳定性。
* k" m  J) d  D! f& N2 e; F[/ol]% c3 z! S, y; d9 C- t
显然,这些选择都不是理想的。是否找到了规避这些问题的方法?这里真的有一个问题吗?" R" ?  g" v4 V# ^1 V: L
注意:我个人最熟悉FP方面的LISP,因此,如果您要提供任何示例并了解多种FP语言,则Lisp可能是首选语言
6 z( K: S; E- i) s9 [- f               
/ W" Q  |3 w0 W; U解决方案:: S3 R5 G" B4 n& v
                : w. n0 ]1 u+ ^+ n! D
; {" r( x) e  L) }
4 [* n( d6 e& }$ J% z6 e$ C
                首先,我不会说CLOS(通用Lisp对象系统)是“ pseudo-OO”。这是一流的OO。* r0 w  d" h2 b' g2 G! g& e: }' c# i
第二,我相信您应该使用适合您需求的范例。5 r) l" v* D0 T' |. b, [0 b
当函数是数据流并且确实不需要状态时,就不能无状态地存储数据。* _! d% B- [* s* i# O, W3 \
如果您混合了几种需求,请混合使用您的范例。不要限制自己仅使用工具箱的右下角。
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则