【知识积累】SBT+Scala+MySQL的Demo
一、背景
由于项目需要,需要在Sbt+Scala项目中连接MySQL数据库。由于之前使用Maven+Java进行依赖管理偏多,在Sbt+Scala方面也在不断进行摸索,特此记录,作为小模块知识的积累。
二、系统环境
Scala、Sbt、IDE的版本分别如下
Scala版本 ==> 2.11.8
Sbt版本 ==> 0.13.8
Idea Intellij版本 ==> 2016.2.2
三、步骤
3.1 新建SBT项目
3.2 添加Student类和程序入口
项目结构如下图所示
其中Student代码如下
package com.hust.grid.leesf.domain /** * Created by LEESF on 2016/8/28. */ class Student(val id: Int, val name: String, val age: Int) { override def toString = "id = " + id + ", name = " + name + ", age = " + age }
MySQLDemo代码如下
package com.hust.grid.leesf.entrance import java.sql.{Connection, DriverManager, SQLException} import com.hust.grid.leesf.domain.Student /** * Created by LEESF on 2016/8/28. */ object MySQLDemo { def main(args: Array[String]): Unit = { val url = "jdbc:mysql://localhost:3306/test?user=root&useUnicode=true&characterEncoding=utf-8" var conn: Connection = null try { // load mysql driver classOf[com.mysql.jdbc.Driver] conn = DriverManager.getConnection(url) val stmt = conn.createStatement val sql = "select * from student" val rs = stmt.executeQuery(sql) while (rs.next) { println(new Student(rs.getInt(1), rs.getString(2), rs.getInt(3))) } } catch { case e: SQLException => e.printStackTrace case e: Exception => e.printStackTrace } finally { if (conn != null) { conn.close } } } }
build.sbt代码如下
name := "MySQLDemo" version := "1.0" scalaVersion := "2.11.8" libraryDependencies += "mysql" % "mysql-connector-java" % "5.1.6"
3.3 新建Student表
选定test数据库
执行SQL脚本如下
CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(20) DEFAULT NULL, `age` tinyint(2) DEFAULT NULL, PRIMARY KEY (`id`) );
插入记录脚本如下
insert into student(name, age) values("leesf", 24); insert into student(name, age) values("dyd", 24);
3.4 执行程序
执行MySQLDemo
结果如下
id = 1, name = leesf, age = 24
id = 2, name = dyd, age = 24
说明:以上结果表明已经成功访问数据库,并取得其中的数据。
四、总结
以上记录了使用SBT+Scala访问MySQL数据的过程,整个Demo已经上传至github,有需要的园友可以直接fork,谢谢各位园友的观看。
PS:如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”,将会是我不竭的动力!
作者:leesf 掌控之中,才会成功;掌控之外,注定失败。
出处:http://www.cnblogs.com/leesf456/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
如果觉得本文对您有帮助,您可以请我喝杯咖啡!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!