【ActiveJdbc】01 入门
官方快速上手文档:
https://javalite.io/activejdbc
https://javalite.io/getting_started
完整介绍:
https://javalite.io/documentation
环境搭建:
1、在数据库中创建该表,注意主键设置为空移除
CREATE TABLE people (
id int(11) NOT NULL auto_increment PRIMARY KEY,
first_name VARCHAR(56) NOT NULL,
last_name VARCHAR(56),
created_at DATETIME,
updated_at DATETIME
);
2、创建一个空的Maven工程,添加必要的包:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <groupId>cn.dzz</groupId>
<artifactId>ActiveJDBC</artifactId>
<version>1.0-SNAPSHOT</version> <dependencies>
<dependency>
<groupId>org.javalite</groupId>
<artifactId>activejdbc</artifactId>
<version>2.2</version>
</dependency> <dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.25</version>
</dependency>
</dependencies> <build>
<plugins>
<plugin>
<groupId>org.javalite</groupId>
<artifactId>activejdbc-instrumentation</artifactId>
<version>2.2</version>
<executions>
<execution>
<phase>process-classes</phase>
<goals>
<goal>instrument</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build> </project>
3、编写Model继承类,如果名称不一致,可使用ActiveJDBC提供的table注解标注
package cn.dzz.model; import org.javalite.activejdbc.Model;
import org.javalite.activejdbc.annotations.Table; @Table("employees")
public class Employee extends Model { }
4、创建连接并执行SQL操作
【注意连接高版本MySQL,com.mysql.cj.jdbc.Driver,连接地址需要加上参数】
package cn.dzz.instance; import cn.dzz.model.Employee;
import org.javalite.activejdbc.Base; public class ConnectTest { public static void main(String[] args) {
Base.open("com.mysql.jdbc.Driver", "jdbc:mysql://localhost:3307/devbase", "root", "123456"); Employee e = new Employee();
e.set("first_name", "John");
e.set("last_name", "Doe");
e.saveIt(); // new Employee().set("first_name", "John", "last_name", "Doe").saveIt();
}
}
首次操作一定出现这个问题:
Caused by: activejdbc.InitException: you are trying to work with models, but no models are found. Maybe you have no models in project, or you did not instrument the models. It is expected that you have a file activejdbc_models.properties on classpath
解决参考:
https://www.dazhuanlan.com/2019/12/17/5df8089723b56/#配置参考

通过IDEA找到这个Maven安装的植入插件:
执行一次插件,再次允许即可:

可以看到是插入成功的
API阅读:
单记录查询:
// 子查询? 和对应的条件 ,条件是可变参数,支持多条件
Employee e = Employee.findFirst("first_name = ?", "John");
System.out.println(e); Object first_name = e.get("first_name");
System.out.println(first_name);
Object id = e.get("id");
System.out.println(id);
Object last_name = e.get("last_name");
System.out.println(last_name);
问题在于返回的属性值是一个Object,需要自己转换?
多记录直接调用where方法:
List<Employee> employees = Employee.where("first_name = ?", "John");
更新记录类同JPA,先查再改:
Employee e = Employee.findFirst("first_name = ?", "John");
e.set("last_name", "Steinbeck").saveIt();
删除记录同理:
Employee e = Employee.findFirst("first_name = ?", "John");
e.delete();
也支持类静态方法:
Person.delete("age > ?", "10");
复杂的批处理操作:
PreparedStatement ps = Base.startBatch("insert into people (NAME, LAST_NAME, DOB) values(?, ?, ?)");
Base.addBatch(ps, "Mic", "Jagger", "1962-01-01");
Base.addBatch(ps, "Marilyn", "Monroe", "1932-01-01");
Base.executeBatch(ps);
ps.close();
全删和全找:
Employee.deleteAll();
List<Employee> employees = Employee.findAll();
支持建造者模式方式赋值多个字段:
new Person().set("first_name", "Marilyn").set("last_name", "Monroe").set("dob", "1935-12-06").saveIt();
也可以通过类静态方法:
Person.createIt("first_name", "Marilyn", "last_name", "Monroe", "dob", "1935-12-06");
读取数量不多的数据集:
List<Map> usersList = Base.findAll("select * from users where company_id = ? ", companyId);
for(Map record: userList){
System.out.println("first_name: " + record.get("first_name"));
System.out.println("last_name: " + record.get("last_name"));
}
百万级数据读取:
Base.find("select first_name, last_name from really_large_table", ....).with(new RowListenerAdapter() {
public void onNext(Map row) {
///write your code here
Object o1 = row.get("first_name");
Object o2 = row.get("last_name");
}
});
时间转换成毫秒值:
Long lastLoginTime = Convert.toLong(Base.firstCell?("select time from logins where user_id ? order by created_at limit 1", 123));
取表的单个列记录:
List ssns = Base.firstColumn("select ssn from people where first_name = ?", "John");
for(Object ssn: ssns)
System.out.println(ssn);
SETTER & GETTER 包装处理:
public class Person extends Model{
public void setFirstName(String firstName){
set("first_name", firstName);
}
public String getFirstName(){
return getString("first_name");
}
}
所以ActiveJDBC也提供了对应的包装处理,方便开发者直接获取正确的数据类型:
【原始get方法得到的是Object】
String name = p.getString("name");
Timestamp dob = p.getTimestamp("dob");
文档中提及ActiveJDBC会尽可能的帮你转换类型,根据表设计的字段类型来返回,然而上面的读取并不会这样
如果不行,还可以调用Convert工具类的方法实现转换
http://javalite.github.io/activejdbc/snapshot/org/javalite/common/Convert.html
单复数命名映射约定:
ActiveJDBC的创造者约定:表名称统一使用复数形式,而映射的Java模型类则用单数形式命名
对于工地英语的我来说简直费解,所以创造者又提供了@Table注解,指定表名称即可
@Table("Operator")
public class Operator extends Model{}
【ActiveJdbc】01 入门的更多相关文章
- Python学习--01入门
Python学习--01入门 Python是一种解释型.面向对象.动态数据类型的高级程序设计语言.和PHP一样,它是后端开发语言. 如果有C语言.PHP语言.JAVA语言等其中一种语言的基础,学习Py ...
- [译]Vulkan教程(01)入门
[译]Vulkan教程(01)入门 接下来我将翻译(https://vulkan-tutorial.com)上的Vulkan教程.这可能是我学习Vulkan的最好方式,但不是最理想的方式. 我会用“d ...
- Express 教程 01 - 入门教程之经典的Hello World
目录: 前言 一.Express?纳尼?! 二.开始前的准备工作 三.测试安装之经典的Hello World 四.使用express(1)来生成一个应用程序 五.说明 前言: 本篇文章是建立在Node ...
- Laravel5.0学习--01 入门
本文以laravel5.0.22为例. 生产环境建议使用laravel5.1版本,因为该版本是长期支持版本.5.1文档更详细:http://laravel-china.org/docs/5.1. 环境 ...
- elasticsearch6.7 01.入门指南(2)
2.安装(略) 默认情况下,elasticsearch 使用端口 9200 来访问它的 REST API.如果有必要,该端口也可以配置 3.探索集群 3.1 The REST API 既然我们已经启动 ...
- Java日志 #01# 入门
很多人在学习完一个东西之后就会忘掉自己作为初学者时的体验.. 例如刚接触git的时候自己也是一头雾水,然后别人问起来,老是会说:xxxx#!@#,就是这么回事儿,有什么不好懂的. 其实从不懂到懂,再到 ...
- [freemarker篇]01.入门Freemarker示例
这今天“弄”军哥的管理系统,里面由涉及到一部分的FreeMarker的知识,并且我那些学生在亚信实习也涉及到这部分的知识,所以想开始总结一些FreeMarker,正好我可开始使用一下Maven,简单的 ...
- Redis -- 01 入门
1. Redis是什么 与memcached 和 couchbase类似,redis是非常快速的基于内存的键值数据库,使用标准c编写,是使用最广泛的缓存中间件.利用Redis提供的五种基本数据类型(S ...
- echarts -01 入门
1.效果图 2. code <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...
- 现代OpenGL教程 01 - 入门指南
原文链接传送门 译序 早前学OpenGL的时候还是1.x版本,用的都是glVertex,glNormal等固定管线API.后来工作需要接触DirectX9,shader也只是可选项而已,跟固定管线一起 ...
随机推荐
- 国产大模型参加高考,同写2024年高考作文,及格分(通义千问、Kimi、智谱清言、Gemini Advanced、Claude-3-Sonnet、GPT-4o)
大家好,我是章北海 今天高考,上午的语文结束,市面上又要来一场大模型参考的文章了. 我也凑凑热闹,让通义千问.Kimi.智谱清言一起来写一下高考作文. 公平起见,不加任何其他prompt,直接把题目甩 ...
- (十)selenium实现微博高级搜索信息爬取
1.selenium模拟登陆 2.定位进入高级搜索页面 3.对高级搜索进行定位,设置. 4.代码实现 import time from selenium import webdriver from l ...
- AlexNet论文解读
前言 作为深度学习的开山之作AlexNet,确实给后来的研究者们很大的启发,使用神经网络来做具体的任务,如分类任务.回归(预测)任务等,尽管AlexNet在今天看来已经有很多神经网络超越了它,但是 ...
- rust 程序设计笔记(2)所有权 & 引用
所有权 数据存储在栈和堆上,存放在栈上的数据都是已知所占据空间的 突然的问题 // 内存中的栈是怎么存储数据的? 好的,想象一下你有一摞盘子.你只能从上面放盘子,也只能从上面拿盘子,这就是栈的工作方式 ...
- css 隐藏移动端滚动条
<template> <div id="app"> <router-view /> </div> </template htm ...
- redis查询 第1个数据库,而不是默认的第0个数据库
redis查询 第1个数据库,而不是默认的第0个数据库 spring.redis.database = 1 默认: spring.redis.database = 0 car-test:0>ge ...
- String忽略大小写方法compareToIgnoreCase源码及Comparator自定义比较器
String忽略大小写方法compareToIgnoreCase源码及Comparator自定义比较器 //源码 public int compareToIgnoreCase(String str) ...
- Fastjson基础环境配置与Java基础概念
Preface 此篇系列文章将会从 Java 的基础语法开始,以 Fastjson 的各个反序列化漏洞分析为结尾,详细记录如何从一个具有基础面向对象编程但毫无 Java 基础的小白成长为了解 Fast ...
- 深入理解Android View(1)
做android其实也有一段时间了,我们每个人都会碰到一些这样或那样的问题,碰到问题了就拼命百度,可是发现,我们解决问题的能力并没有提升很多,所以我才有想总结一下我项目中所用过的相关知识,并了解一下A ...
- Java面试知识点(六)hashmap深度理解
1.hashmap 的数据结构 要知道 hashmap 是什么,首先要搞清楚它的数据结构,在 java 编程语言中,最基本的结构就是两种,一个是数组,另外一个是模拟指针(引用),所有的数据结构都可以用 ...