当前位置:首页 > > 程序员鱼皮
[导读]前端传递:表名 user,字段 username 字符串、age 数字、is_ikun 布尔,并且把这些值封装为了一个对象

大家好,我是鱼皮。

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

鱼皮你好,请问怎么能够根据前台用户的输入,自动创建和修改数据库的表呢?

在我看的视频教程中,都是先根据需求设计并且手动创建好库表,再去做增删改查。现在数据库表的字段是不固定的,就不知道怎么能动态地操作库表了。

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

举个例子:

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

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

create table user {
 username varchar,
 age int,
 is_ikun boolean }

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

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

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

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

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

// 连接数据库 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 中,比如下面这样:

<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 这种框架 “锁” 住了。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭