首先,需要从调用 Database 窗口 View>Tool Windows>Database

添加到数据库的连接

选择数据的表,然后右击

选择 Scripted Extensions > Generate POJOs.groovy 既可以生成实体

Scripted Extensions 中前面2个菜单,是生成实体的模版,后面一个是实体模版所在的目录。实际使用中,我们需要对生成的模版代码修改

进入模版目录

打开对应的模版文件进行修改, 下方是我修改后的模版文件和生成的代码

import com.intellij.database.model.DasTable
import com.intellij.database.model.ObjectKind
import com.intellij.database.util.Case
import com.intellij.database.util.DasUtil /*
* Available context bindings:
* SELECTION Iterable<DasObject>
* PROJECT project
* FILES files helper
*/ packageName = "com.sample;"
typeMapping = [
(~/(?i)int/) : "long",
(~/(?i)float|double|decimal|real/): "double",
(~/(?i)datetime|timestamp/) : "java.sql.Timestamp",
(~/(?i)date/) : "java.sql.Date",
(~/(?i)time/) : "java.sql.Time",
(~/(?i)/) : "String"
] FILES.chooseDirectoryAndSave("Choose directory", "Choose where to store generated files") { dir ->
SELECTION.filter { it instanceof DasTable && it.getKind() == ObjectKind.TABLE }.each { generate(it, dir) }
} def generate(table, dir) {
def className = javaName(table.getName(), true)
def fields = calcFields(table)
new File(dir, className.replace('_', '') + ".java").withPrintWriter { out -> generate(out, className, fields) }
} def generate(out, className, fields) {
out.println "package $packageName"
out.println ""
out.println ""
out.println "import lombok.Getter;"
out.println "import lombok.Setter;"
out.println "import javax.persistence.*;"
// out.println "import java.sql.Timestamp;"
out.println ""
out.println "@Entity"
out.println "@Table(name = \"${className.toLowerCase()}\")"
out.println "@Setter @Getter"
out.println "public class ${className.replace('_', '')} {"
out.println ""
fields.each() {
if (it.annos != "") out.println " ${it.annos}" if (it.name == 'id') {
out.println " @Id"
out.println " @GeneratedValue(strategy = GenerationType.IDENTITY)"
}
if (it.name.contains('_'))
out.println " @Column(name = \"${it.name.toLowerCase()}\")"
out.println " private ${it.type} ${it.name.replace('_', '')};"
out.println ""
}
out.println "}"
} def calcFields(table) {
DasUtil.getColumns(table).reduce([]) { fields, col ->
def spec = Case.LOWER.apply(col.getDataType().getSpecification())
def typeStr = typeMapping.find { p, t -> p.matcher(spec).find() }.value
fields += [[
name : javaName(col.getName(), false),
type : typeStr,
annos: ""]]
}
} def javaName(str, capitalize) {
def s = str.split(/(?<=[^\p{IsLetter}])/).collect { Case.LOWER.apply(it).capitalize() }
.join("").replaceAll(/[^\p{javaJavaIdentifierPart}]/, "_")
capitalize || s.length() == 1? s : Case.LOWER.apply(s[0]) + s[1..-1]
}
package com.sample;

import lombok.Getter;
import lombok.Setter;
import javax.persistence.*; @Entity
@Table(name = "parking_orders")
@Setter @Getter
public class ParkingOrders { @Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private long id; @Column(name = "project_id")
private long projectId; @Column(name = "site_id")
private long siteId; @Column(name = "site_name")
private String siteName; @Column(name = "order_no")
private String orderNo; @Column(name = "order_amount")
private double orderAmount; @Column(name = "discount_amount")
private double discountAmount; @Column(name = "payable_amount")
private double payableAmount; @Column(name = "real_amount")
private double realAmount; @Column(name = "loan_status")
private long loanStatus; @Column(name = "house_name")
private String houseName; @Column(name = "customer_name")
private String customerName; @Column(name = "customer_phone")
private String customerPhone; @Column(name = "customer_code")
private String customerCode; @Column(name = "manager_id")
private long managerId; private long status; private String remark; @Column(name = "contract_no")
private String contractNo; @Column(name = "check_code")
private String checkCode; @Column(name = "add_time")
private java.sql.Timestamp addTime; @Column(name = "confirm_time")
private java.sql.Timestamp confirmTime; @Column(name = "complete_time")
private java.sql.Timestamp completeTime; }

Intellij IDEA 从数据库生成 JPA Entity的更多相关文章

  1. 由数据库表生成jpa实体工具

    package cn.net.yto.aaa.dao.generator; /** * 由数据库表生成jpa实体工具 * * @author huike * Created by gf.liu on ...

  2. IDEA 通过数据库生成entity实体类

    IDEA利用数据库生成entity类教程 1.在左上角有一个View 选项 2. 然后选择 TOOL Windows 3. 然后选择Database然后会弹出一个窗口 4.选择+号 5.选择data ...

  3. 关于Entity Framework 5 从数据库生成模型时没有字段注释的解决方法!

    目前用到了EF5进行模型创建,发现从数据库生成过来的实体中并没有包含字段的说明信息(鄙视下微软,这么简单的问题都不给解决下,太粗枝大叶了),网上找到了EFTSQLDocumentation.Gener ...

  4. SQLite数据库和JPA简单介绍

    SQLite数据库和JPA简单介绍 一.SQLite简单使用 SQLite是遵循ACID的关系数据库管理系统,它的处理速度很快,它的设计目标是嵌入式的,只需要几百K的内存就可以了. 1.下载SQLit ...

  5. Java IDE 编辑器 --- IntelliJ IDEA 进阶篇 生成 hibernate 实体与映射文件

    原文:转:Java IDE 编辑器 --- IntelliJ IDEA 进阶篇 生成 hibernate 实体与映射文件 2011-04-30 12:50 很多人不知道怎么用 IntelliJ IDE ...

  6. Asp.Net MVC 从数据库生成代码(包括页面)

    项目需要,数据库已经设计完成,需要生成相关的数据访问代码和页面. 参考:http://www.tracefact.net/asp-net/aspnetmvc-model-part1.aspx http ...

  7. VS2015 +EF6 连接MYSQL数据库生成实体

      VS2015 +EF6 连接MYSQL数据库生成实体   已安装软件:VS2015                       XAMPP Control Panel(Mysql服务器)      ...

  8. 在 Mac OS X 上创建的 .NET 命令行程序访问数据库 (使用Entity Framework 7 )

    var appInsights=window.appInsights||function(config){ function r(config){t[config]=function(){var i= ...

  9. Dapper.Contrib拓展及数据库生成实体

    1.关于Dapper.Contrib Dapper.Contrib是Dapper的一个拓展类库,Dapper是一个轻量级ORM框架,这个不了解的请自行收集资料,本文主要讲讲,数据库生成实体,并通过实体 ...

随机推荐

  1. django csrftoken

    CSRF(跨站请求伪造) 背景知识:浏览器在发送请求的时候,会自动带上当前域名对应的cookie内容,发送给服务端,不管这个请求是来源A网站还是其它网站,只要请求的是A网站的链接,就会带上A网站的co ...

  2. 快速理解js中的call,apply的作用

    今天被人问到js中的call,apply的区别和用途,解释了一番后,想到之前在逼乎上看到一位小伙伴生动形象的解释 本身不难理解,看下MDN就知道了,但是不常用,遇到了,还要脑回路回转下.或者时间长了, ...

  3. python第十一天

    今日内容 1. 函数的参数 2. 函数对象 -- 函数名  * * * *重点! 3. 函数 的嵌套调用 1. 形参与实参: 函数介绍: 1.1  函数为什么要有参数: 因为内部的函数体需要外部的数据 ...

  4. [Android] Android 手机下 仿 今日头条 新闻客户端

    利用一个月的时间,自学了 Android 开发 ,为了检验学习成果,特意 开发了这个  仿 今日头条 新闻客户端 AppNews 包括图文新闻+视频新闻+图片新闻 预览演示如下: 功能说明: 1)底部 ...

  5. kafka 日常使用和数据副本模型的理解

    kafka 日常使用和数据副本模型的理解 在使用Kafka过程中,有时经常需要查看一些消费者的情况.Kafka健康状况.临时查看.同步一些数据,又由于Kafka只是用来做流式存储,又没有像Mysql或 ...

  6. Oracle DB Day03(SQL)

    --day03 --创建一个包含下面信息的表,并添加一些记录待用 --EMPLOYEE_ID NOT NULL NUMBER(6) --FIRST_NAME VARCHAR2(20) --LAST_N ...

  7. python学习05

    数据类型之字典dict.set集合 1).字典dict 1. dict_1={'name':'tom','age':18} 是以键值对(key-value)的方式,其中键是可hash值的,即表示键是唯 ...

  8. reduce/filter/map/zip/isinstance/list列表推导式

  9. P1972 [SDOI2009]HH的项链

    洛谷的分块练习题 看到讨论中说分块莫队被卡就写了树状数组...(但感觉做法和莫队的思想有点像?) #include<bits/stdc++.h> using namespace std; ...

  10. Mail.Ru Cup 2018 Round 3 B. Divide Candies

    题目链接 分析一下题意可以得到题目要求的是满足下面这个 公式的不同的i,ji,ji,j的方案数; 即(i2+j2)mod&ThinSpace;&ThinSpace; m=0 (n ≤  ...