ktorm框架代码生成器
代码生成器支持的数据库有
- Mysql
- Sqlserver
链接:https://pan.baidu.com/s/1XQ8MMuglz1gU_x4Hjnn0wg 提取码:r861
如下图
{
"Type": "Mysql",
"OutPutFolder": "../java/dal",
"IsKotlin": true,
"CamelCase": true,
"KtormVersionNew": true,
"NamespaceName": "DbModel",
"ConnectionString": "Server=localhost;Port=53306;Database=antmgr;Uid=root;Pwd=123456;charset=utf8;SslMode=none",
"TableFilter": [],
"SetFkList": [
"system_users,RoleTid,system_role,Tid"
]
}
字段 | 说明 |
---|---|
Type | 支持 mysql 和 sqlserver (sqlserver的话支持在后面指定版本号:sqlserver2000, sqlserver2005,sqlserver2008,sqlserver2012,sqlserver2017,如果不指定的话 sqlserver = sqlserver2008) |
OutPutFolder | 生成的代码保存在本机的哪个文件夹(可以使用绝对路径和相对路径) 相对路径是相对于你选择的json文件 例如(../java) |
IsKotlin | 需要设置为true |
KtormVersionNew | 如果用的是新版本的ktorm的话需要设置为true(因为ktorm更改了namespace) |
CamelCase | 生成Dao和Model的时候可以把字段名称下划线转驼峰 |
NamespaceName | 指定 package 名称 |
ConnectionString | db连接字符串 |
TableFilter | 表名称的string数组,如果指定了只会生成特定的表的代码 , system_% -》代表只生成system_开头的表 |
SetFkList | 外键关系设置(可以是非物理的外键)有4个参数逗号隔开分别是,A表的哪个字段关联B表的哪个字段,关联关系是1:1 |
是db里面的表,一张表对应这个目录下的一个kotlin文件
一个model对应一个dao
dataBase的扩展方法,只需要拿到database 就可以拿到表对象进行db操作。 可以参考下面的代码。
val database = Database.connect(
"jdbc:mysql://localhost:3306/antmgr?user=root&password=123456&useSSL=false",
logger = ConsoleLogger(threshold = LogLevel.DEBUG)
)
//默认自动join是关闭的
val user = database.systemUsers.filter { it.Tid eq 2 }.firstOrNull()
println(user?.SystemRole)
//按照下面的方式开启自动join查询
val user2 = database.systemUsers.joinReferencesAndSelect().filter { it.Tid eq 2 }.firstOrNull()
println(user2?.SystemRole)
//筛选
val systemMenu = database.systemMenus.filter { (it.IsActive) and (it.Name eq "yuzd") }.firstOrNull()
println(systemMenu)
//新增
database.systemMenus.insert {
set(it.Name, "test")
set(it.IsActive, false)
}
//修改
database.systemMenus.update {
set(it.IsActive, true)
where { it.Name eq "test" }
}
//删除
database.systemMenus.delete {
it.Name eq "test"
}
更多详细可以参考ktorm框架的文档 https://www.ktorm.org/en/entities-and-column-binding.html
- 优化遇到错误的信息展示
- 支持sqlserver