Giter Site home page Giter Site logo

wu9007 / pocket Goto Github PK

View Code? Open in Web Editor NEW
6.0 1.0 1.0 1009 KB

⛱ Pocket's core Object/Relational Mapping functionality

Home Page: https://leyan95.github.io/biscuits

License: MIT License

Java 100.00%
orm java8-date-time multiple-data-sources cache-control spring

pocket's People

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar

Forkers

armyhan

pocket's Issues

pool

配置定时检测连接池中的空闲连接,手动刷新(注意并发问题)

针对数据库表结构的DDL语句进行持久化

针对数据库表结构的DDL语句进行持久化,以便于升级或变更数据库表结构时支持可重复执行。
实现此功能后,可以做到用户程序临时升级或变更不会导致正常升级情况下发生由于DDL语句不可重复执行导致的升级报错。也可以一定程度上避免漏提交DDL语句带来的BUG。

缓存问题

关联表修改后通知缓存中心进行清理。

SQL加锁

支持 for update 方便使用分布式事务。

数据库驱动

  • 使用枚举简化配置文件中的数据库驱动名称

支持in函数

SELECT * FROM TBL_USER WHERE AGE IN(20, 21, 22, 26, 28);

异常提示信息

如:

  • 数据库异常中 包含FK_的时候,返回信息:您当前操作的数据已被其他业务应用,无法执行删除操作,请先撤销后续业务后再执行删除。
  • 数据库异常中 包含UK_的时候,返回信息:系统中存在与当前记录相同的数据,不允许重复提交。

uuid生成策略

确保uuid唯一

  • serverId固定三位
  • tabelId和时间戳之间使用固定数字分割
  • 若使用序列需要考虑何时清零

对象中多个属性使用 @Join 且 关联同一张表时数据查询异常

  • SQL
SELECT
	TBL_DIC_BASIC.UUID,
	TBL_DIC_BASIC.TYPE_ID,
	TBL_DIC_BASIC.PARENT_UUID,
	TBL_DIC_BASIC.NAME,
	TBL_DIC_BASIC.SPELL,
	TBL_DIC_BASIC.CODE,
	TBL_DIC_BASIC.SYSTEM_CODE,
	TBL_DIC_BASIC.OPERATOR,
	TBL_DIC_BASIC.OPERATE_TIME,
	TBL_DIC_BASIC.MEMO,
	TBL_DIC_BASIC.SORT,
	TBL_DIC_BASIC.IS_LEAF,
	TBL_DIC_STATIC.NAME AS IS_LEAF,
	TBL_DIC_BASIC.IS_NEED_CHECK,
	TBL_DIC_STATIC.NAME AS IS_NEED_CHECK,
	TBL_DIC_BASIC.WARNING_DAYS,
	TBL_DIC_BASIC.IS_ENABLE,SELECT
	TBL_DIC_BASIC.UUID,
	TBL_DIC_BASIC.TYPE_ID,
	TBL_DIC_BASIC.PARENT_UUID,
	TBL_DIC_BASIC.NAME,
	TBL_DIC_BASIC.SPELL,
	TBL_DIC_BASIC.CODE,
	TBL_DIC_BASIC.SYSTEM_CODE,
	TBL_DIC_BASIC.OPERATOR,
	TBL_DIC_BASIC.OPERATE_TIME,
	TBL_DIC_BASIC.MEMO,
	TBL_DIC_BASIC.SORT,
	TBL_DIC_BASIC.IS_LEAF,
	TBL_DIC_STATIC.NAME AS IS_LEAF,
	TBL_DIC_BASIC.IS_NEED_CHECK,
	TBL_DIC_STATIC.NAME AS IS_NEED_CHECK,
	TBL_DIC_BASIC.WARNING_DAYS,
	TBL_DIC_BASIC.IS_ENABLE,
	TBL_DIC_STATIC.NAME AS IS_ENABLE,
	TBL_DIC_BASIC.IS_QUALIFIED,
	TBL_DIC_STATIC.NAME AS IS_QUALIFIED,
	TBL_DIC_BASIC.IS_DELETED 
FROM
	TBL_DIC_BASIC
	LEFT JOIN TBL_DIC_STATIC ON TBL_DIC_BASIC.IS_LEAF = TBL_DIC_STATIC.UUID
	LEFT JOIN TBL_DIC_STATIC ON TBL_DIC_BASIC.IS_NEED_CHECK = TBL_DIC_STATIC.UUID
	LEFT JOIN TBL_DIC_STATIC ON TBL_DIC_BASIC.IS_ENABLE = TBL_DIC_STATIC.UUID
	LEFT JOIN TBL_DIC_STATIC ON TBL_DIC_BASIC.IS_QUALIFIED = TBL_DIC_STATIC.UUID 
WHERE 1=1
	TBL_DIC_BASIC.IS_DELETED = ? 
	AND TBL_DIC_BASIC.TYPE_ID = ? 
	LIMIT 0,
	13
	TBL_DIC_STATIC.NAME AS IS_ENABLE,
	TBL_DIC_BASIC.IS_QUALIFIED,
	TBL_DIC_STATIC.NAME AS IS_QUALIFIED,
	TBL_DIC_BASIC.IS_DELETED 
FROM
	TBL_DIC_BASIC
	LEFT JOIN TBL_DIC_STATIC ON TBL_DIC_BASIC.IS_LEAF = TBL_DIC_STATIC.UUID
	LEFT JOIN TBL_DIC_STATIC ON TBL_DIC_BASIC.IS_NEED_CHECK = TBL_DIC_STATIC.UUID
	LEFT JOIN TBL_DIC_STATIC ON TBL_DIC_BASIC.IS_ENABLE = TBL_DIC_STATIC.UUID
	LEFT JOIN TBL_DIC_STATIC ON TBL_DIC_BASIC.IS_QUALIFIED = TBL_DIC_STATIC.UUID 

语句执行

  • 记录语句执行时长
  • 设置语句执行超时时长

分表

自定义算法,将数据分别插入到特定表,以支持da'量数据。

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.