前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >这是用框架的通病么?

这是用框架的通病么?

作者头像
程序员鱼皮
发布2022-11-07 15:47:16
4200
发布2022-11-07 15:47:16
举报
文章被收录于专栏:鱼皮客栈鱼皮客栈

大家好,我是鱼皮。

前段时间,星球里一位学 Java 的朋友问我:

鱼皮你好,请问怎么能够根据前台用户的输入,自动创建和修改数据库的表呢? 在我看的视频教程中,都是先根据需求设计并且手动创建好库表,再去做增删改查。现在数据库表的字段是不固定的,就不知道怎么能动态地操作库表了。

这个问题并不难,所有的创建库表操作都是要通过 SQL 来执行的,所以我们只需要根据前端传来的字段来生成一句建表 SQL 就可以了。

举个例子:

前端传递:表名 user,字段 username 字符串、age 数字、is_ikun 布尔,并且把这些值封装为了一个对象

后端得到对象并进行遍历,生成下面的 SQL:

代码语言:javascript
复制
create table user {
 username varchar,
 age int,
 is_ikun boolean
}

得到 SQL 后,让程序来自动执行即可。

本来以为这个问题已经解决了,但这位小伙伴又找到我说:

鱼皮,拼接 SQL 我可以写出来。但我用的是 MyBatis Plus,代码里也没有对应的 Mapper、IService 之类的,甚至连访问接口都没有。。。我该怎么控制程序读取这个代码创建的数据库呢?

看到这里,我明白了,又是一位被框架 “害了” 的朋友。

记得学 Java 基础时,我们就接触过 JDBC(Java 数据库连接 API),可以通过它来连接数据库并执行 任意 SQL 语句,就像下面这样:

代码语言:javascript
复制
// 连接数据库
Connection conn = DriverManager.getConnection(url,username,password);
// 输入任意 SQL
String sql = "insert into table values('鱼皮');";
PreparedStatement stat = conn.prepareStatement(sql);
// 执行 SQL
int update = stat.executeUpdate();

而 MyBatis 数据访问框架的底层正是 JDBC!无论是 MyBatis 还是 MyBatis Plus 框架,它们都是对 JDBC 进行了抽象封装(比如上面说的 Mapper),让我们少写或不写 SQL 完成开发。

也就是说,使用 MyBatis 框架,一样可以执行任意 SQL 语句!

你可以随便定义一个 Mapper,直接将任意完整的 SQL 作为 value 传递到 mapper.xml 中,比如下面这样:

代码语言:javascript
复制
<mapper namespace="com.yupi.MyMapper">
  <insert id="insert" parameterType="java.lang.String">
    ${value}
  </insert>
</mapper>

这样一来,我们就可以在业务逻辑层用 Java 代码来编写逻辑灵活生成 SQL,而不是把 SQL 写死到 mapper 里了。你甚至可以直接用最原始的 JDBC 来达成同样的效果!

但是要注意防止 SQL 注入问题

讲到这里,那位同学恍然大悟:what's up!怎么套了层框架之后,反而忘记了最原始的实现方式。真的是被框架束缚住了!

如他所说,的确很多初学编程的朋友都有这种情况:离了框架不会写代码、框架没有的功能就不会做。

或者换句话说?离了视频教程就不会写代码,老师不讲的功能就不会做。

虽然扎心,但是现实。

今年我也看了不少网上的视频教程,不得不说现在培训机构讲的很多课真的挺到位的,比起我大学那会(几年前)的课程好太多了,用最短的时间就能带你学会框架、开发完整项目。

但是,只跟着看视频是远远不够的!

  • 因为课程追求快速入门,所以给你思考的时间有限。
  • 因为课程追求快速入门,所以很多代码中的坑不会带你去踩。
  • 因为课程追求快速入门,所以很多扩展知识不会带你发现。

因此,如果你在学编程的过程中不主动思考、不多写代码、不多自己探索知识,你的思考能力、编程能力和知识积累就很有限。也就更容易被框架所束缚。

所以这里给大家几个学习的建议:

  1. 在刚开始学编程时,尽量老老实实按照路线去学习,像 jdbc、servlet 这种知识也要适当了解。
  2. 在学习框架时,多思考 一下它是怎么运作的,比如 Spring Boot 的注解,它做了些什么事?如果没有 Spring Boot,你又怎么达到同样的效果?虽然刚开始学框架时还是优先以会用为主,但你可以先把这些自己想到的问题记下来,之后再慢慢解决。
  3. 试着多用框架开发一些自己的类库和组件,比如开发 Spring Boot starter 或者前端的 hooks,可以帮助你更好地理解框架的原理,这些东西写在简历上可能会比 “xx 管理系统” 亮眼很多。
  4. 有空可以阅读官方文档,了解并实践框架的配置和更多特性,从而弥补一些视频中遗漏的知识点。这样一来,虽然大家用的都是同一个框架,但你能用得更好,写在简历上就会更出彩一些。

哦对了,最后再补充一点:做后端开发的同学,有机会的话还是要多写 SQL 语句!真的不要被 MyBatis Plus 这种框架 “锁” 住了。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-09-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员鱼皮 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档