DLang、Rust 以及 Golang 对比数据库操作方式
我们使用 DLang / Rust / Golang 在服务端开发的时候对数据库操作是家常便饭,而对于所谓的系统级编译型语言来说操作数据库可能没那么方便,不像 PHP 和 JAVA 那样,对于比较新的三个编译型语言我们来看看效果,刚好这三个语言的语法差异比较大。
一、数据插入 - INSERT
1.1 : DLang 插入数据
import std.stdio; import hunt.database; void main() { auto db = new Database("mysql://root:123456@localhost:3306/test?charset=utf8mb4"); int result = db.execute(`INSERT INTO user(username) VALUES("test")`); // 打印插入数量 writeln(result); db.close(); }
1.2 : Rust 插入数据
extern crate postgres; use postgres::{Connection, SslMode}; fn main() { let conn = Connection::connect("postgres://postgres@localhost", SslMode::None).unwrap(); conn.execute("INSERT INTO user (username) VALUES (\"test\")", &[]).unwrap(); }
1.3 : Golang 插入数据
import ( "database/sql" "fmt" _ "github.com/lib/pq" "time" "log" ) func main() { db, err := sql.Open("postgres", "user=portgres password=123456 dbname=test sslmode=disable") if err != nil { log.Fatal(err) return nil } stmt := db.Prepare("INSERT INTO user (username) VALUES (\"test\")") stmt.Exec() stmt.Close() }
二、数据查询 - SELECT
2.1 : DLang 查询数据
import std.stdio; import hunt.database; void main() { auto db = new Database("mysql://root:123456@localhost:3306/test?charset=utf8mb4"); foreach(row; db.query("SELECT * FROM user LIMIT 10")) { writeln(row["username"]); } db.close(); }
2.2 : Rust 查询数据
extern crate postgres; use postgres::{Connection, SslMode}; fn main() { let conn = Connection::connect("postgres://postgres@localhost", SslMode::None).unwrap(); for row in &conn.query("SELECT * FROM user", &[]).unwrap(); println!("Found person {}", row.get(0)); } }
2.3 : Golang 查询数据
import ( "database/sql" "fmt" _ "github.com/lib/pq" "time" "log" ) type User struct { UserName string } func main() { db, err := sql.Open("postgres", "user=portgres password=123456 dbname=test sslmode=disable") if err != nil { log.Fatal(err) return nil } user := User{} stmt := db.Query("SELECT * FROM user") for rows.Next() { rows.Scan(&user.UserName) fmt.Println(user.UserName) } stmt.Close() }
三、总结
对于操作数据库来说静态类型语言的确不是很容易操作,类似 C++ 这么多年还没有相对容易使用的数据库操作的 library,但无论 Dlang / Rust 和 Golang 都能比较全面的操作数据库。
这三个语言的语法还有比较大的差异,DLang 语法可读性比较好(的确简单的像PHP一样方便了),Rust 相对来说操作符会多一些,而 golang 在执行 SELECT 之后需要创建对象绑定,不支持字段作为 key 的操作形式?(可能是我功课没做好)
在包引入方面 Dlang 最简单,Rust 相对来说颗粒度控制的更细,而 Golang 相对繁琐一些,需要几个包同时引入才可以操作数据库;相对 Rust 和 Golang 来说 Dlang 可以更方便的切换不同数据库而不需要修改业务逻辑代码。
总而言之系统级语言在服务端的应用日益增多,更多有意思的对比还需要大家一起来挖掘,不要沉浸在单一的脚本语言如 PHP、虚拟机语言 JAVA 和 C#,多多学习,现在语言的学习成本已经非常低,我们应该在不同的应用场景使用更适合的开发语言。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Kafka连接器深度解读之JDBC源连接器
在现实业务中,Kafka经常会遇到的一个集成场景就是,从数据库获取数据,因为关系数据库是一个非常丰富的事件源。数据库中的现有数据以及对该数据的任何更改都可以流式传输到Kafka主题中,在这里这些事件可用于驱动应用,也可以流式传输到其它数据存储(比如搜索引擎或者缓存)用于分析等。 实现这个需求有很多种做法,但是在本文中,会聚焦其中的一个解决方案,即Kafka连接器中的JDBC连接器,讲述如何进行配置,以及一些问题排查的技巧,至于更多的细节,请参见Kafka的文档。 介绍 Kafka连接器中的JDBC连接器包含在Confluent Platform中,也可以与Confluent Hub分开安装。它可以作为源端从数据库提取数据到Kafka,也可以作为接收端从一个Kafka主题中将数据推送到数据库。几乎所有关系数据库都提供JDBC驱动,包括Oracle、Microsoft SQL Server、DB2、MySQL和Postgres。 下面将从最简单的Kafka连接器配置开始,然后进行构建。本文中的示例是从MySQL数据库中提取数据,该数据库有两个模式,每个模式都有几张表: mysql> ...
- 下一篇
一个线程罢工的诡异事件
背景 事情(事故)是这样的,突然收到报警,线上某个应用里业务逻辑没有执行,导致的结果是数据库里的某些数据没有更新。 虽然是前人写的代码,但作为 Bug maker&killer 只能咬着牙上了。 因为之前没有接触过出问题这块的逻辑,所以简单理了下如图: 有一个生产线程一直源源不断的往队列写数据。 消费线程也一直不停的取出数据后写入后续的业务线程池。 业务线程池里的线程会对每个任务进行入库操作。 整个过程还是比较清晰的,就是一个典型的生产者消费者模型。 尝试定位 接下来便是尝试定位这个问题,首先例行检查了以下几项: 是否内存有内存溢出? 应用 GC 是否有异常? 通过日志以及监控发现以上两项都是正常的。 紧接着便 dump 了线程快照查看业务线程池中的线程都在干啥。 结果发现所有业务线程池都处于 waiting 状态,队列也是空的。 同时生产者使用的队列却已经满了,没有任何消费迹象。 结合上面的流程图不难发现应该是消费队列的 Consumer 出问题了,导致上游的队列不能消费,下有的业务线程池没事可做。 review 代码 于是查看了消费代码的业务逻辑,同时也发现消费线程是一个单...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- 设置Eclipse缩进为4个空格,增强代码规范
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- CentOS7设置SWAP分区,小内存服务器的救世主
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- MySQL8.0.19开启GTID主从同步CentOS8
- Linux系统CentOS6、CentOS7手动修改IP地址
- Windows10,CentOS7,CentOS8安装Nodejs环境
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- CentOS7,8上快速安装Gitea,搭建Git服务器