Skip to content

Latest commit

 

History

History
38 lines (36 loc) · 3.94 KB

main-feature.md

File metadata and controls

38 lines (36 loc) · 3.94 KB

Bee主要功能特点介绍:

Bee概念简单(10分钟即可入门)、功能强大。
Bee 简化了与DB交互的编码工作量。连接,事务都可以由Bee框架负责管理。
简单易用,文件小,性能好;同时支持JDBC(比如JavaWeb),Android和Harmony,NoSQL(Cassandra,MongoDB)

简单易用,省时,开发速度快

  • 1.接口简单,使用方便。Suid接口中对应SQL语言的select,update,insert,delete操作提供4个同名方法
  • 2.使用了Bee,你可以不用再另外编写dao代码,直接调用Bee的api即可完成对DB的操作。
  • 3.约定优于配置:Javabean没有注解,也不需要xml映射文件,只是纯的Javabean即可,甚至get,set方法不用也可以。
  • 4.智能化自动过滤实体的null和空字符串属性,不再需要写判断非空的代码。
  • 5.可轻松实现只查询一部分字段,轻松实现原生语句分页
  • 6.支持直接返回Json格式查询结果; 链式编程。
  • 7.Sharding分片,分库分表;只分库;只分表;读写分离;(对以前的代码无需修改,该功能对代码是透明的,即无需额外编码)。
  • 8.多种DB支持轻松扩展(MySQL,MariaDB,Oracle,H2,SQLite,PostgreSQL,SQL Server,Access,金仓,达梦等,NoSQL:Cassandra,Mongodb等直接可用),理论上支持JDBC的DB都可以支持,此外还支持Android和Harmony,支持ElasticSearch(7.x) ORM 查询;
  • 9.更多数据库分页默认支持:MsAccess,Cubrid,HSQL,Derby,Firebird等
  • 10.多种数据库可同时使用(如同时使用Mysql,Oracle,MongoDB)

自动,功强强大

  • 11.动态/任意组合查询条件,不需要提前准备dao接口,有新的查询需求也不用修改或添加接口。
  • 12.支持事务、多个ORM操作使用同一连接、for update,支持批处理操作,支持原生SQL(自定义sql语句),支持存储过程
  • 13.支持面向对象方式复杂查询、多表查询(无n+1问题; 支持:一对一,一对多,多对一,多对多;返回结果根据子表是否使用List有两种呈现结构);多表关联改插删(2.1.8)。
  • 14.Mongodb ORM,Mongodb分库分表。
  • 15.注册器、拦截器、多租户,支持自定义TypeHandler,处理查询的ResultSet结果;
    转换器SetParaTypeConvert转换PreparedStatement参数的类型。
  • 16.自定义动态SQL标签,@in,@toIsNULL1,@toIsNULL2,<if isNotNull>,<if isNotBlank>;
    动态sql,将list转为像in (1,2,3)的语句,不需要foreach,批量插入也不需要foreach。
  • 17.复杂查询前后端可自动解析。
  • 18.一级缓存,概念简单,功能强大;一级缓存也可以像JVM一样进行细粒度调优支持可更新的长久缓存列表,更新配置表,不需要重启。天生抵御缓存穿透 。 二级缓存扩展支持;内置Redis二级缓存支持
  • 19.第三方插件依赖;可零配置使用。
  • 20.性能好:接近JDBC的速度;文件小:Bee V1.17 仅502k, V2.1 仅827k

辅助功能:

  • 21.提供自然简单的分布式主键生成方案:分布式环境下生成连续单调递增(在一个workerid内),全局唯一数字id
  • 22.支持自动生成表对应的Javabean(支持Swagger),根据Javabean创建表,Javaweb后端代码根据模板自动生成;能打印非占位符的可执行sql(支持sql格式化),方便调试;支持生成Json格式的SQL脚本。
  • 23.支持读取Excel,从Excel导入数据到DB,操作简单;支持从Excel获取配置生成数据库表。
  • 24.流的工具类StreamUtil,DateUtil日期转换,判断日期格式,计算年龄。
  • 25.丰富的注解支持:PrimaryKey,Column,Datetime,Createtime,Updatetime;JustFetch,ReplaceInto(MySQL),Dict,DictI18n,GridFs等。
  • 26.使用实体名_F(自动生成)引用实体字段名Users_F.name或在SuidRichExt接口中使用格式如Users::getName。