为什么我们需要自己写代码?为什么计算机无法自动为我们生成这些代码呢?很显然,我们应该可以利用这些共同点,从一个给定的数据库自动化构建系统——这就是“我”创建Magic的初衷。
作者
ThomasHansen
译者
弯月,责编
郭芮
以下为译文:
作为一名C#开发人员,我坦白虽然我很喜欢C#,喜欢它的强类型、编译器、泛型、LINQ等等,但有时我也会嫉妒PHP和Python开发人员。Python和PHP在本质上更为动态,而且还可以实现C#几乎不可能完成的任务。大约在一年前,我的一位朋友向我展示了Django,我羞愧地承认.NET没有类似的功能。因此,我决定通过自己的努力创造奇迹,于是我创建了Magic。
CRUD、HTTP和SQL
在软件开发人员眼中,很多问题都可以归结为将JSON从客户端传输到后端。这个问题是如此普遍,所以我们总结出了一个缩写CRUD:创建(Create)、读取(Read)、更新(Update)和删除(Delete)。HTTP请求的类型有post、put、delete和get。SQL拥有insert、update、delete和select。可以说,所有这些操作都基于相同的概念,即CRUD。
因此,很显然我们应该可以利用这些共同点,从一个给定的数据库自动化构建系统。为什么我们需要自己写代码?为什么计算机无法自动为我们生成这些代码呢?
Magic
我创建的Magic能够从数据库架构中读取元信息,并利用这些信息来创建HTTPREST端点的脚手架代码,并对数据库中的每个CRUD操作提供封装。我们的目的是在控制器端点和数据库之间建立一层薄薄的“Hyperlambda”,你只需轻轻点击一个按钮,就可以创建和公开数据库上所有的CRUD操作。
Hyperlambda是一种动态编程语言,也是一种DSL,它不需要编译,但是它能够快速处理这些类型的操作,因为每个Hyperlambda关键字只不过是C#中的类的封装。
因此,我们很容易创建Hyperlambda“关键字”,并通过这些关键字对客户端进行身份验证和授权、将记录插入到我们的数据库中、读取记录等,所有的操作只需几行代码即可实现。它的语法非常容易理解,而且计算机也很容易理解,这样用户可以通过对关键字的排列来创建代码的脚手架。
演示过程: