diff --git a/README.md b/README.md
index 2f3bf0098db21477746d7ddc8db9f6d39dd97b02..b7cb2152e46973066d305bc5adb7c8fb92aef929 100644
--- a/README.md
+++ b/README.md
@@ -1,12 +1,12 @@
-Dash-FastAPI-Admin v2.0.1
+Dash-FastAPI-Admin v2.1.0
基于Dash+FastAPI前后端分离的纯Python快速开发框架
-
+
@@ -17,7 +17,7 @@
Dash-FastAPI-Admin是一套全部开源的快速开发平台,毫无保留给个人及企业免费使用。
* 前端采用Dash、feffery-antd-components、feffery-utils-components。
-* 后端采用FastAPI、sqlalchemy、MySQL、Redis、OAuth2 & Jwt。
+* 后端采用FastAPI、sqlalchemy、MySQL(PostgreSQL)、Redis、OAuth2 & Jwt。
* 权限认证使用OAuth2 & Jwt,支持多终端认证系统。
* 支持加载动态权限菜单,多方式轻松权限控制。
* Vue2版本:
@@ -105,8 +105,10 @@ git clone https://gitee.com/insistence2022/dash-fastapi-admin.git
# 进入项目根目录
cd dash-fastapi-admin
-# 安装项目依赖环境
+# 如果使用的是MySQL数据库,请执行以下命令安装项目依赖环境
pip3 install -r requirements.txt
+# 如果使用的是PostgreSQL数据库,请执行以下命令安装项目依赖环境
+pip3 install -r requirements-pg.txt
```
### 开发
@@ -134,7 +136,7 @@ cd dash-fastapi-backend
# 运行sql文件
1.新建数据库dash-fastapi(默认,可修改)
-2.使用命令或数据库连接工具运行sql文件夹下的dash-fastapi.sql
+2.如果使用的是MySQL数据库,使用命令或数据库连接工具运行sql文件夹下的dash-fastapi.sql;如果使用的是PostgreSQL数据库,使用命令或数据库连接工具运行sql文件夹下的dash-fastapi-pg.sql
# 运行后端
python3 app.py --env=dev
@@ -193,7 +195,7 @@ cd dash-fastapi-backend
# 运行sql文件
1.新建数据库dash-fastapi(默认,可修改)
-2.使用命令或数据库连接工具运行sql文件夹下的dash-fastapi.sql
+2.如果使用的是MySQL数据库,使用命令或数据库连接工具运行sql文件夹下的dash-fastapi.sql;如果使用的是PostgreSQL数据库,使用命令或数据库连接工具运行sql文件夹下的dash-fastapi-pg.sql
# 运行后端
python3 app.py --env=prod
@@ -213,14 +215,14 @@ python3 app.py --env=prod
如果有对本项目及FastAPI感兴趣的朋友,欢迎加入知识星球一起交流学习,让我们一起变得更强。如果你觉得这个项目帮助到了你,你可以请作者喝杯咖啡表示鼓励☕。扫描下面微信二维码添加微信备注DF-Admin即可进群,也欢迎大家加入dash大神费弗里的知识星球学习更多dash开发知识。
\ No newline at end of file
diff --git a/dash-fastapi-backend/.env.dev b/dash-fastapi-backend/.env.dev
index 67e44f0840a6da79d93a4fbbc93510cdf5e2321e..f79f19e370f30a93e5e1137469f609604d662909 100644
--- a/dash-fastapi-backend/.env.dev
+++ b/dash-fastapi-backend/.env.dev
@@ -10,7 +10,7 @@ APP_HOST = '0.0.0.0'
# 应用端口
APP_PORT = 9099
# 应用版本
-APP_VERSION= '2.0.1'
+APP_VERSION= '2.1.0'
# 应用是否开启热重载
APP_RELOAD = true
# 应用是否开启IP归属区域查询
@@ -30,6 +30,8 @@ JWT_REDIS_EXPIRE_MINUTES = 30
# -------- 数据库配置 --------
+# 数据库类型,可选的有'mysql'、'postgresql',默认为'mysql'
+DB_TYPE = 'mysql'
# 数据库主机
DB_HOST = '127.0.0.1'
# 数据库端口
diff --git a/dash-fastapi-backend/.env.prod b/dash-fastapi-backend/.env.prod
index 545c3dbd3b66df1b9cfeaa7dcffec558f747af62..55c011df164cc6b376d746166e84070daab9d991 100644
--- a/dash-fastapi-backend/.env.prod
+++ b/dash-fastapi-backend/.env.prod
@@ -10,7 +10,7 @@ APP_HOST = '0.0.0.0'
# 应用端口
APP_PORT = 9099
# 应用版本
-APP_VERSION= '2.0.1'
+APP_VERSION= '2.1.0'
# 应用是否开启热重载
APP_RELOAD = false
# 应用是否开启IP归属区域查询
@@ -30,6 +30,8 @@ JWT_REDIS_EXPIRE_MINUTES = 30
# -------- 数据库配置 --------
+# 数据库类型,可选的有'mysql'、'postgresql',默认为'mysql'
+DB_TYPE = 'mysql'
# 数据库主机
DB_HOST = '127.0.0.1'
# 数据库端口
diff --git a/dash-fastapi-backend/config/database.py b/dash-fastapi-backend/config/database.py
index 14c5a80cb8131737f2083116d8fdfe2235cdf9df..006b6a53dbc66f4c1b0331635cbc9849ee27b293 100644
--- a/dash-fastapi-backend/config/database.py
+++ b/dash-fastapi-backend/config/database.py
@@ -9,6 +9,11 @@ ASYNC_SQLALCHEMY_DATABASE_URL = (
f'mysql+asyncmy://{DataBaseConfig.db_username}:{quote_plus(DataBaseConfig.db_password)}@'
f'{DataBaseConfig.db_host}:{DataBaseConfig.db_port}/{DataBaseConfig.db_database}'
)
+if DataBaseConfig.db_type == 'postgresql':
+ ASYNC_SQLALCHEMY_DATABASE_URL = (
+ f'postgresql+asyncpg://{DataBaseConfig.db_username}:{quote_plus(DataBaseConfig.db_password)}@'
+ f'{DataBaseConfig.db_host}:{DataBaseConfig.db_port}/{DataBaseConfig.db_database}'
+ )
async_engine = create_async_engine(
ASYNC_SQLALCHEMY_DATABASE_URL,
diff --git a/dash-fastapi-backend/config/env.py b/dash-fastapi-backend/config/env.py
index e232a1395832114e90ac6def2870da7fa15a2bf5..26120a2fbfe2ad5bd711e9b00c603e489b396d2d 100644
--- a/dash-fastapi-backend/config/env.py
+++ b/dash-fastapi-backend/config/env.py
@@ -4,6 +4,7 @@ import sys
from dotenv import load_dotenv
from functools import lru_cache
from pydantic_settings import BaseSettings
+from typing import Literal
class AppSettings(BaseSettings):
@@ -38,6 +39,7 @@ class DataBaseSettings(BaseSettings):
数据库配置
"""
+ db_type: Literal['mysql', 'postgresql'] = 'mysql'
db_host: str = '127.0.0.1'
db_port: int = 3306
db_username: str = 'root'
diff --git a/dash-fastapi-backend/config/get_scheduler.py b/dash-fastapi-backend/config/get_scheduler.py
index f6beeb988932ef7da97daed5535d720eb4e9f0be..bf7547d0fdcb76de121ddca693ad67ca37f697c9 100644
--- a/dash-fastapi-backend/config/get_scheduler.py
+++ b/dash-fastapi-backend/config/get_scheduler.py
@@ -82,6 +82,11 @@ SQLALCHEMY_DATABASE_URL = (
f'mysql+pymysql://{DataBaseConfig.db_username}:{quote_plus(DataBaseConfig.db_password)}@'
f'{DataBaseConfig.db_host}:{DataBaseConfig.db_port}/{DataBaseConfig.db_database}'
)
+if DataBaseConfig.db_type == 'postgresql':
+ SQLALCHEMY_DATABASE_URL = (
+ f'postgresql+psycopg2://{DataBaseConfig.db_username}:{quote_plus(DataBaseConfig.db_password)}@'
+ f'{DataBaseConfig.db_host}:{DataBaseConfig.db_port}/{DataBaseConfig.db_database}'
+ )
engine = create_engine(
SQLALCHEMY_DATABASE_URL,
echo=DataBaseConfig.db_echo,
diff --git a/dash-fastapi-backend/module_admin/controller/user_controller.py b/dash-fastapi-backend/module_admin/controller/user_controller.py
index eda93a698b8f30a27cacf0dbe04b24a82b0fcec7..c3bcc00b554bffd61f5fa7f4bd2e1fd592f4d392 100644
--- a/dash-fastapi-backend/module_admin/controller/user_controller.py
+++ b/dash-fastapi-backend/module_admin/controller/user_controller.py
@@ -2,7 +2,7 @@ import os
from datetime import datetime
from fastapi import APIRouter, Depends, File, Form, Query, Request, UploadFile
from sqlalchemy.ext.asyncio import AsyncSession
-from typing import Optional, Union
+from typing import Literal, Optional, Union
from pydantic_validation_decorator import ValidateFields
from config.get_db import get_db
from config.env import UploadConfig
@@ -220,7 +220,7 @@ async def query_detail_system_user_profile(
)
async def query_detail_system_user(
request: Request,
- user_id: Optional[Union[int, str]] = '',
+ user_id: Optional[Union[int, Literal['']]] = '',
query_db: AsyncSession = Depends(get_db),
current_user: CurrentUserModel = Depends(LoginService.get_current_user),
data_scope_sql: str = Depends(GetDataScope('SysUser')),
diff --git a/dash-fastapi-backend/module_admin/dao/config_dao.py b/dash-fastapi-backend/module_admin/dao/config_dao.py
index 7b3c067847d85abd4cf3ba05e084dc3973c12c6c..4f34a2fa05acfdc4604f6ecb88837b34f8b97c2e 100644
--- a/dash-fastapi-backend/module_admin/dao/config_dao.py
+++ b/dash-fastapi-backend/module_admin/dao/config_dao.py
@@ -71,6 +71,7 @@ class ConfigDao:
if query_object.begin_time and query_object.end_time
else True,
)
+ .order_by(SysConfig.config_id)
.distinct()
)
config_list = await PageUtil.paginate(db, query, query_object.page_num, query_object.page_size, is_page)
diff --git a/dash-fastapi-backend/module_admin/dao/dict_dao.py b/dash-fastapi-backend/module_admin/dao/dict_dao.py
index 8f4aab221714345d545dee6edd4f981be81631c1..c5a8ed5c855c1717c1470d1ed8b952559936b7b4 100644
--- a/dash-fastapi-backend/module_admin/dao/dict_dao.py
+++ b/dash-fastapi-backend/module_admin/dao/dict_dao.py
@@ -84,6 +84,7 @@ class DictTypeDao:
if query_object.begin_time and query_object.end_time
else True,
)
+ .order_by(SysDictType.dict_id)
.distinct()
)
dict_type_list = await PageUtil.paginate(db, query, query_object.page_num, query_object.page_size, is_page)
diff --git a/dash-fastapi-backend/module_admin/dao/job_dao.py b/dash-fastapi-backend/module_admin/dao/job_dao.py
index 7f4f4a34e99bbd84b08c2ae32bad9f7fc2eee3a7..805d4602b2c01b1e0552004fa1504592efbd3192 100644
--- a/dash-fastapi-backend/module_admin/dao/job_dao.py
+++ b/dash-fastapi-backend/module_admin/dao/job_dao.py
@@ -69,6 +69,7 @@ class JobDao:
SysJob.job_group == query_object.job_group if query_object.job_group else True,
SysJob.status == query_object.status if query_object.status else True,
)
+ .order_by(SysJob.job_id)
.distinct()
)
job_list = await PageUtil.paginate(db, query, query_object.page_num, query_object.page_size, is_page)
diff --git a/dash-fastapi-backend/module_admin/dao/job_log_dao.py b/dash-fastapi-backend/module_admin/dao/job_log_dao.py
index 730be5aa285daae3aef29dade1bee41315cec3e8..586a3d61adc42338a79f03dc07d0b010207e3f15 100644
--- a/dash-fastapi-backend/module_admin/dao/job_log_dao.py
+++ b/dash-fastapi-backend/module_admin/dao/job_log_dao.py
@@ -1,5 +1,5 @@
from datetime import datetime, time
-from sqlalchemy import delete, select
+from sqlalchemy import delete, desc, select
from sqlalchemy.ext.asyncio import AsyncSession
from sqlalchemy.orm import Session
from module_admin.entity.do.job_do import SysJobLog
@@ -35,6 +35,7 @@ class JobLogDao:
if query_object.begin_time and query_object.end_time
else True,
)
+ .order_by(desc(SysJobLog.create_time))
.distinct()
)
job_log_list = await PageUtil.paginate(db, query, query_object.page_num, query_object.page_size, is_page)
diff --git a/dash-fastapi-backend/module_admin/dao/notice_dao.py b/dash-fastapi-backend/module_admin/dao/notice_dao.py
index 961a9921c160a00ce5a1f4084b525018fc33bf49..9f48a14c3422a9568e517296fcc023845f905928 100644
--- a/dash-fastapi-backend/module_admin/dao/notice_dao.py
+++ b/dash-fastapi-backend/module_admin/dao/notice_dao.py
@@ -72,6 +72,7 @@ class NoticeDao:
if query_object.begin_time and query_object.end_time
else True,
)
+ .order_by(SysNotice.notice_id)
.distinct()
)
notice_list = await PageUtil.paginate(db, query, query_object.page_num, query_object.page_size, is_page)
diff --git a/dash-fastapi-backend/module_admin/dao/user_dao.py b/dash-fastapi-backend/module_admin/dao/user_dao.py
index 52a088c8fa4c43e9e201cc50c613ddc8d7fe8c2d..cc5356626e735045c91158e755d7a69a72060f98 100644
--- a/dash-fastapi-backend/module_admin/dao/user_dao.py
+++ b/dash-fastapi-backend/module_admin/dao/user_dao.py
@@ -318,6 +318,7 @@ class UserDao:
and_(SysUser.dept_id == SysDept.dept_id, SysDept.status == '0', SysDept.del_flag == '0'),
isouter=True,
)
+ .order_by(SysUser.user_id)
.distinct()
)
user_list = await PageUtil.paginate(db, query, query_object.page_num, query_object.page_size, is_page)
diff --git a/dash-fastapi-backend/module_admin/entity/do/config_do.py b/dash-fastapi-backend/module_admin/entity/do/config_do.py
index 32af3b0f737766a5f1f37da5e8d7c415beb88cb0..012d2be2df2a391ad55069044dc268332cf474aa 100644
--- a/dash-fastapi-backend/module_admin/entity/do/config_do.py
+++ b/dash-fastapi-backend/module_admin/entity/do/config_do.py
@@ -19,4 +19,4 @@ class SysConfig(Base):
create_time = Column(DateTime, nullable=True, default=datetime.now(), comment='创建时间')
update_by = Column(String(64), nullable=True, default='', comment='更新者')
update_time = Column(DateTime, nullable=True, default=datetime.now(), comment='更新时间')
- remark = Column(String(500), nullable=True, default='', comment='备注')
+ remark = Column(String(500), nullable=True, default=None, comment='备注')
diff --git a/dash-fastapi-backend/module_admin/entity/do/dept_do.py b/dash-fastapi-backend/module_admin/entity/do/dept_do.py
index 96ac8daf6e999a8de60e9f654ef6b77899ba9371..44e2f02f3a6c6929f8d66dc6c2845320754ab8cd 100644
--- a/dash-fastapi-backend/module_admin/entity/do/dept_do.py
+++ b/dash-fastapi-backend/module_admin/entity/do/dept_do.py
@@ -18,8 +18,8 @@ class SysDept(Base):
leader = Column(String(20), nullable=True, default=None, comment='负责人')
phone = Column(String(11), nullable=True, default=None, comment='联系电话')
email = Column(String(50), nullable=True, default=None, comment='邮箱')
- status = Column(String(1), nullable=True, default=0, comment='部门状态(0正常 1停用)')
- del_flag = Column(String(1), nullable=True, default=0, comment='删除标志(0代表存在 2代表删除)')
+ status = Column(String(1), nullable=True, default='0', comment='部门状态(0正常 1停用)')
+ del_flag = Column(String(1), nullable=True, default='0', comment='删除标志(0代表存在 2代表删除)')
create_by = Column(String(64), nullable=True, default='', comment='创建者')
create_time = Column(DateTime, nullable=True, default=datetime.now(), comment='创建时间')
update_by = Column(String(64), nullable=True, default='', comment='更新者')
diff --git a/dash-fastapi-backend/module_admin/entity/do/dict_do.py b/dash-fastapi-backend/module_admin/entity/do/dict_do.py
index 061c88f2b2352a233a275c36700603f7bf6b1ae1..7a155ea5289c5f8eb339466d62eb1e89e5812167 100644
--- a/dash-fastapi-backend/module_admin/entity/do/dict_do.py
+++ b/dash-fastapi-backend/module_admin/entity/do/dict_do.py
@@ -18,7 +18,7 @@ class SysDictType(Base):
create_time = Column(DateTime, nullable=True, default=datetime.now(), comment='创建时间')
update_by = Column(String(64), nullable=True, default='', comment='更新者')
update_time = Column(DateTime, nullable=True, default=datetime.now(), comment='更新时间')
- remark = Column(String(500), nullable=True, default='', comment='备注')
+ remark = Column(String(500), nullable=True, default=None, comment='备注')
__table_args__ = (UniqueConstraint('dict_type', name='uq_sys_dict_type_dict_type'),)
@@ -35,12 +35,12 @@ class SysDictData(Base):
dict_label = Column(String(100), nullable=True, default='', comment='字典标签')
dict_value = Column(String(100), nullable=True, default='', comment='字典键值')
dict_type = Column(String(100), nullable=True, default='', comment='字典类型')
- css_class = Column(String(100), nullable=True, default='', comment='样式属性(其他样式扩展)')
- list_class = Column(String(100), nullable=True, default='', comment='表格回显样式')
+ css_class = Column(String(100), nullable=True, default=None, comment='样式属性(其他样式扩展)')
+ list_class = Column(String(100), nullable=True, default=None, comment='表格回显样式')
is_default = Column(String(1), nullable=True, default='N', comment='是否默认(Y是 N否)')
status = Column(String(1), nullable=True, default='0', comment='状态(0正常 1停用)')
create_by = Column(String(64), nullable=True, default='', comment='创建者')
create_time = Column(DateTime, nullable=True, default=datetime.now(), comment='创建时间')
update_by = Column(String(64), nullable=True, default='', comment='更新者')
update_time = Column(DateTime, nullable=True, default=datetime.now(), comment='更新时间')
- remark = Column(String(500), nullable=True, default='', comment='备注')
+ remark = Column(String(500), nullable=True, default=None, comment='备注')
diff --git a/dash-fastapi-backend/module_admin/entity/do/job_do.py b/dash-fastapi-backend/module_admin/entity/do/job_do.py
index c6d671b18a27ca86e13edc729b23f417602bf112..b2cbfb8dbce4cb969a8b1de9b56ad4022d145815 100644
--- a/dash-fastapi-backend/module_admin/entity/do/job_do.py
+++ b/dash-fastapi-backend/module_admin/entity/do/job_do.py
@@ -11,32 +11,26 @@ class SysJob(Base):
__tablename__ = 'sys_job'
job_id = Column(Integer, primary_key=True, autoincrement=True, comment='任务ID')
- job_name = Column(String(64, collation='utf8_general_ci'), nullable=False, comment='任务名称')
- job_group = Column(String(64, collation='utf8_general_ci'), nullable=False, default='default', comment='任务组名')
- job_executor = Column(
- String(64, collation='utf8_general_ci'), nullable=False, default='default', comment='任务执行器'
- )
- invoke_target = Column(String(500, collation='utf8_general_ci'), nullable=False, comment='调用目标字符串')
- job_args = Column(String(255, collation='utf8_general_ci'), nullable=True, comment='位置参数')
- job_kwargs = Column(String(255, collation='utf8_general_ci'), nullable=True, comment='关键字参数')
- cron_expression = Column(
- String(255, collation='utf8_general_ci'), nullable=True, default='', comment='cron执行表达式'
- )
+ job_name = Column(String(64), nullable=True, default='', comment='任务名称')
+ job_group = Column(String(64), nullable=True, default='default', comment='任务组名')
+ job_executor = Column(String(64), nullable=True, default='default', comment='任务执行器')
+ invoke_target = Column(String(500), nullable=False, comment='调用目标字符串')
+ job_args = Column(String(255), nullable=True, default='', comment='位置参数')
+ job_kwargs = Column(String(255), nullable=True, default='', comment='关键字参数')
+ cron_expression = Column(String(255), nullable=True, default='', comment='cron执行表达式')
misfire_policy = Column(
- String(20, collation='utf8_general_ci'),
+ String(20),
nullable=True,
default='3',
comment='计划执行错误策略(1立即执行 2执行一次 3放弃执行)',
)
- concurrent = Column(
- String(1, collation='utf8_general_ci'), nullable=True, default='1', comment='是否并发执行(0允许 1禁止)'
- )
- status = Column(String(1, collation='utf8_general_ci'), nullable=True, default='0', comment='状态(0正常 1暂停)')
- create_by = Column(String(64, collation='utf8_general_ci'), nullable=True, default='', comment='创建者')
+ concurrent = Column(String(1), nullable=True, default='1', comment='是否并发执行(0允许 1禁止)')
+ status = Column(String(1), nullable=True, default='0', comment='状态(0正常 1暂停)')
+ create_by = Column(String(64), nullable=True, default='', comment='创建者')
create_time = Column(DateTime, nullable=True, default=datetime.now(), comment='创建时间')
- update_by = Column(String(64, collation='utf8_general_ci'), nullable=True, default='', comment='更新者')
+ update_by = Column(String(64), nullable=True, default='', comment='更新者')
update_time = Column(DateTime, nullable=True, default=datetime.now(), comment='更新时间')
- remark = Column(String(500, collation='utf8_general_ci'), nullable=True, default='', comment='备注信息')
+ remark = Column(String(500), nullable=True, default='', comment='备注信息')
class SysJobLog(Base):
@@ -47,18 +41,14 @@ class SysJobLog(Base):
__tablename__ = 'sys_job_log'
job_log_id = Column(Integer, primary_key=True, autoincrement=True, comment='任务日志ID')
- job_name = Column(String(64, collation='utf8_general_ci'), nullable=False, comment='任务名称')
- job_group = Column(String(64, collation='utf8_general_ci'), nullable=False, comment='任务组名')
- job_executor = Column(
- String(64, collation='utf8_general_ci'), nullable=False, default='default', comment='任务执行器'
- )
- invoke_target = Column(String(500, collation='utf8_general_ci'), nullable=False, comment='调用目标字符串')
- job_args = Column(String(255, collation='utf8_general_ci'), nullable=True, comment='位置参数')
- job_kwargs = Column(String(255, collation='utf8_general_ci'), nullable=True, comment='关键字参数')
- job_trigger = Column(String(255, collation='utf8_general_ci'), nullable=True, comment='任务触发器')
- job_message = Column(String(500, collation='utf8_general_ci'), nullable=True, default='', comment='日志信息')
- status = Column(
- String(1, collation='utf8_general_ci'), nullable=True, default='0', comment='执行状态(0正常 1失败)'
- )
- exception_info = Column(String(2000, collation='utf8_general_ci'), nullable=True, default='', comment='异常信息')
+ job_name = Column(String(64), nullable=False, comment='任务名称')
+ job_group = Column(String(64), nullable=False, comment='任务组名')
+ job_executor = Column(String(64), nullable=False, comment='任务执行器')
+ invoke_target = Column(String(500), nullable=False, comment='调用目标字符串')
+ job_args = Column(String(255), nullable=True, default='', comment='位置参数')
+ job_kwargs = Column(String(255), nullable=True, default='', comment='关键字参数')
+ job_trigger = Column(String(255), nullable=True, default='', comment='任务触发器')
+ job_message = Column(String(500), nullable=True, default='', comment='日志信息')
+ status = Column(String(1), nullable=True, default='0', comment='执行状态(0正常 1失败)')
+ exception_info = Column(String(2000), nullable=True, default='', comment='异常信息')
create_time = Column(DateTime, nullable=True, default=datetime.now(), comment='创建时间')
diff --git a/dash-fastapi-backend/module_admin/entity/do/log_do.py b/dash-fastapi-backend/module_admin/entity/do/log_do.py
index f915207cf984f4c663ea4cb818fa5c99f9a8610d..f9e14ab49da43512cd36f089785b6892ed5f6fdd 100644
--- a/dash-fastapi-backend/module_admin/entity/do/log_do.py
+++ b/dash-fastapi-backend/module_admin/entity/do/log_do.py
@@ -11,15 +11,13 @@ class SysLogininfor(Base):
__tablename__ = 'sys_logininfor'
info_id = Column(Integer, primary_key=True, autoincrement=True, comment='访问ID')
- user_name = Column(String(50, collation='utf8_general_ci'), nullable=True, default='', comment='用户账号')
- ipaddr = Column(String(128, collation='utf8_general_ci'), nullable=True, default='', comment='登录IP地址')
- login_location = Column(String(255, collation='utf8_general_ci'), nullable=True, default='', comment='登录地点')
- browser = Column(String(50, collation='utf8_general_ci'), nullable=True, default='', comment='浏览器类型')
- os = Column(String(50, collation='utf8_general_ci'), nullable=True, default='', comment='操作系统')
- status = Column(
- String(1, collation='utf8_general_ci'), nullable=True, default='0', comment='登录状态(0成功 1失败)'
- )
- msg = Column(String(255, collation='utf8_general_ci'), nullable=True, default='', comment='提示消息')
+ user_name = Column(String(50), nullable=True, default='', comment='用户账号')
+ ipaddr = Column(String(128), nullable=True, default='', comment='登录IP地址')
+ login_location = Column(String(255), nullable=True, default='', comment='登录地点')
+ browser = Column(String(50), nullable=True, default='', comment='浏览器类型')
+ os = Column(String(50), nullable=True, default='', comment='操作系统')
+ status = Column(String(1), nullable=True, default='0', comment='登录状态(0成功 1失败)')
+ msg = Column(String(255), nullable=True, default='', comment='提示消息')
login_time = Column(DateTime, nullable=True, default=datetime.now(), comment='访问时间')
idx_sys_logininfor_s = Index('idx_sys_logininfor_s', status)
@@ -34,20 +32,20 @@ class SysOperLog(Base):
__tablename__ = 'sys_oper_log'
oper_id = Column(BigInteger, primary_key=True, autoincrement=True, comment='日志主键')
- title = Column(String(50, collation='utf8_general_ci'), nullable=True, default='', comment='模块标题')
+ title = Column(String(50), nullable=True, default='', comment='模块标题')
business_type = Column(Integer, default=0, comment='业务类型(0其它 1新增 2修改 3删除)')
- method = Column(String(100, collation='utf8_general_ci'), nullable=True, default='', comment='方法名称')
- request_method = Column(String(10, collation='utf8_general_ci'), nullable=True, default='', comment='请求方式')
+ method = Column(String(100), nullable=True, default='', comment='方法名称')
+ request_method = Column(String(10), nullable=True, default='', comment='请求方式')
operator_type = Column(Integer, default=0, comment='操作类别(0其它 1后台用户 2手机端用户)')
- oper_name = Column(String(50, collation='utf8_general_ci'), nullable=True, default='', comment='操作人员')
- dept_name = Column(String(50, collation='utf8_general_ci'), nullable=True, default='', comment='部门名称')
- oper_url = Column(String(255, collation='utf8_general_ci'), nullable=True, default='', comment='请求URL')
- oper_ip = Column(String(128, collation='utf8_general_ci'), nullable=True, default='', comment='主机地址')
- oper_location = Column(String(255, collation='utf8_general_ci'), nullable=True, default='', comment='操作地点')
- oper_param = Column(String(2000, collation='utf8_general_ci'), nullable=True, default='', comment='请求参数')
- json_result = Column(String(2000, collation='utf8_general_ci'), nullable=True, default='', comment='返回参数')
+ oper_name = Column(String(50), nullable=True, default='', comment='操作人员')
+ dept_name = Column(String(50), nullable=True, default='', comment='部门名称')
+ oper_url = Column(String(255), nullable=True, default='', comment='请求URL')
+ oper_ip = Column(String(128), nullable=True, default='', comment='主机地址')
+ oper_location = Column(String(255), nullable=True, default='', comment='操作地点')
+ oper_param = Column(String(2000), nullable=True, default='', comment='请求参数')
+ json_result = Column(String(2000), nullable=True, default='', comment='返回参数')
status = Column(Integer, default=0, comment='操作状态(0正常 1异常)')
- error_msg = Column(String(2000, collation='utf8_general_ci'), nullable=True, default='', comment='错误消息')
+ error_msg = Column(String(2000), nullable=True, default='', comment='错误消息')
oper_time = Column(DateTime, nullable=True, default=datetime.now(), comment='操作时间')
cost_time = Column(BigInteger, default=0, comment='消耗时间')
diff --git a/dash-fastapi-backend/module_admin/entity/do/notice_do.py b/dash-fastapi-backend/module_admin/entity/do/notice_do.py
index 125a40a8ef38766307ccd210e00bd1ad9fa5e9c1..9d1eb982ecb8f94eccc136bc09cb83ce8d5e3c74 100644
--- a/dash-fastapi-backend/module_admin/entity/do/notice_do.py
+++ b/dash-fastapi-backend/module_admin/entity/do/notice_do.py
@@ -11,12 +11,12 @@ class SysNotice(Base):
__tablename__ = 'sys_notice'
notice_id = Column(Integer, primary_key=True, autoincrement=True, comment='公告ID')
- notice_title = Column(String(50, collation='utf8_general_ci'), nullable=False, comment='公告标题')
- notice_type = Column(String(1, collation='utf8_general_ci'), nullable=False, comment='公告类型(1通知 2公告)')
+ notice_title = Column(String(50), nullable=False, comment='公告标题')
+ notice_type = Column(String(1), nullable=False, comment='公告类型(1通知 2公告)')
notice_content = Column(LargeBinary, comment='公告内容')
- status = Column(String(1, collation='utf8_general_ci'), default='0', comment='公告状态(0正常 1关闭)')
- create_by = Column(String(64, collation='utf8_general_ci'), default='', comment='创建者')
+ status = Column(String(1), default='0', comment='公告状态(0正常 1关闭)')
+ create_by = Column(String(64), default='', comment='创建者')
create_time = Column(DateTime, comment='创建时间', default=datetime.now())
- update_by = Column(String(64, collation='utf8_general_ci'), default='', comment='更新者')
+ update_by = Column(String(64), default='', comment='更新者')
update_time = Column(DateTime, comment='更新时间', default=datetime.now())
- remark = Column(String(255, collation='utf8_general_ci'), comment='备注')
+ remark = Column(String(255), comment='备注')
diff --git a/dash-fastapi-backend/module_admin/entity/do/post_do.py b/dash-fastapi-backend/module_admin/entity/do/post_do.py
index 54ab38dcb0d3ee77b500286f6e7d731ac092dd78..f231f720febde67dbe3a03ce73805a516dfb0c31 100644
--- a/dash-fastapi-backend/module_admin/entity/do/post_do.py
+++ b/dash-fastapi-backend/module_admin/entity/do/post_do.py
@@ -19,4 +19,4 @@ class SysPost(Base):
create_time = Column(DateTime, nullable=True, default=datetime.now(), comment='创建时间')
update_by = Column(String(64), default='', comment='更新者')
update_time = Column(DateTime, nullable=True, default=datetime.now(), comment='更新时间')
- remark = Column(String(500), nullable=True, default='', comment='备注')
+ remark = Column(String(500), nullable=True, default=None, comment='备注')
diff --git a/dash-fastapi-backend/module_admin/entity/do/role_do.py b/dash-fastapi-backend/module_admin/entity/do/role_do.py
index fc2e34d593ac8eb624f9288a9a2be32a7d8c3303..58d4de12b7b7083c9b9fc8f3089aba4a1cab18dd 100644
--- a/dash-fastapi-backend/module_admin/entity/do/role_do.py
+++ b/dash-fastapi-backend/module_admin/entity/do/role_do.py
@@ -11,23 +11,23 @@ class SysRole(Base):
__tablename__ = 'sys_role'
role_id = Column(Integer, primary_key=True, autoincrement=True, comment='角色ID')
- role_name = Column(String(30, collation='utf8_general_ci'), nullable=False, comment='角色名称')
- role_key = Column(String(100, collation='utf8_general_ci'), nullable=False, comment='角色权限字符串')
+ role_name = Column(String(30), nullable=False, comment='角色名称')
+ role_key = Column(String(100), nullable=False, comment='角色权限字符串')
role_sort = Column(Integer, nullable=False, comment='显示顺序')
data_scope = Column(
- String(1, collation='utf8_general_ci'),
+ String(1),
default='1',
comment='数据范围(1:全部数据权限 2:自定数据权限 3:本部门数据权限 4:本部门及以下数据权限)',
)
menu_check_strictly = Column(Integer, default=1, comment='菜单树选择项是否关联显示')
dept_check_strictly = Column(Integer, default=1, comment='部门树选择项是否关联显示')
- status = Column(String(1, collation='utf8_general_ci'), nullable=False, comment='角色状态(0正常 1停用)')
- del_flag = Column(String(1, collation='utf8_general_ci'), default='0', comment='删除标志(0代表存在 2代表删除)')
- create_by = Column(String(64, collation='utf8_general_ci'), default='', comment='创建者')
+ status = Column(String(1), nullable=False, default='0', comment='角色状态(0正常 1停用)')
+ del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
+ create_by = Column(String(64), default='', comment='创建者')
create_time = Column(DateTime, default=datetime.now(), comment='创建时间')
- update_by = Column(String(64, collation='utf8_general_ci'), default='', comment='更新者')
+ update_by = Column(String(64), default='', comment='更新者')
update_time = Column(DateTime, default=datetime.now(), comment='更新时间')
- remark = Column(String(500, collation='utf8_general_ci'), comment='备注')
+ remark = Column(String(500), default=None, comment='备注')
class SysRoleDept(Base):
diff --git a/dash-fastapi-backend/module_admin/entity/do/user_do.py b/dash-fastapi-backend/module_admin/entity/do/user_do.py
index 21bba84a7bdeab34378dd39d70439859c4cc8d1d..2dd0ba0a5e31c238134b80f0f69e13580e3656fd 100644
--- a/dash-fastapi-backend/module_admin/entity/do/user_do.py
+++ b/dash-fastapi-backend/module_admin/entity/do/user_do.py
@@ -11,24 +11,24 @@ class SysUser(Base):
__tablename__ = 'sys_user'
user_id = Column(Integer, primary_key=True, autoincrement=True, comment='用户ID')
- dept_id = Column(Integer, comment='部门ID')
- user_name = Column(String(30, collation='utf8_general_ci'), nullable=False, comment='用户账号')
- nick_name = Column(String(30, collation='utf8_general_ci'), nullable=False, comment='用户昵称')
- user_type = Column(String(2, collation='utf8_general_ci'), default='00', comment='用户类型(00系统用户)')
- email = Column(String(50, collation='utf8_general_ci'), default='', comment='用户邮箱')
- phonenumber = Column(String(11, collation='utf8_general_ci'), default='', comment='手机号码')
- sex = Column(String(1, collation='utf8_general_ci'), default='0', comment='用户性别(0男 1女 2未知)')
- avatar = Column(String(100, collation='utf8_general_ci'), default='', comment='头像地址')
- password = Column(String(100, collation='utf8_general_ci'), default='', comment='密码')
- status = Column(String(1, collation='utf8_general_ci'), default='0', comment='帐号状态(0正常 1停用)')
- del_flag = Column(String(1, collation='utf8_general_ci'), default='0', comment='删除标志(0代表存在 2代表删除)')
- login_ip = Column(String(128, collation='utf8_general_ci'), default='', comment='最后登录IP')
+ dept_id = Column(Integer, default=None, comment='部门ID')
+ user_name = Column(String(30), nullable=False, comment='用户账号')
+ nick_name = Column(String(30), nullable=False, comment='用户昵称')
+ user_type = Column(String(2), default='00', comment='用户类型(00系统用户)')
+ email = Column(String(50), default='', comment='用户邮箱')
+ phonenumber = Column(String(11), default='', comment='手机号码')
+ sex = Column(String(1), default='0', comment='用户性别(0男 1女 2未知)')
+ avatar = Column(String(100), default='', comment='头像地址')
+ password = Column(String(100), default='', comment='密码')
+ status = Column(String(1), default='0', comment='帐号状态(0正常 1停用)')
+ del_flag = Column(String(1), default='0', comment='删除标志(0代表存在 2代表删除)')
+ login_ip = Column(String(128), default='', comment='最后登录IP')
login_date = Column(DateTime, comment='最后登录时间')
- create_by = Column(String(64, collation='utf8_general_ci'), default='', comment='创建者')
+ create_by = Column(String(64), default='', comment='创建者')
create_time = Column(DateTime, comment='创建时间', default=datetime.now())
- update_by = Column(String(64, collation='utf8_general_ci'), default='', comment='更新者')
+ update_by = Column(String(64), default='', comment='更新者')
update_time = Column(DateTime, comment='更新时间', default=datetime.now())
- remark = Column(String(500, collation='utf8_general_ci'), comment='备注')
+ remark = Column(String(500), default=None, comment='备注')
class SysUserRole(Base):
diff --git a/dash-fastapi-backend/module_admin/service/dept_service.py b/dash-fastapi-backend/module_admin/service/dept_service.py
index 31440802f0ef941bc11e1ffd87d86fa5982d6782..8c86a7e14e5cf8c102ecb2d14583ea3664c8c472 100644
--- a/dash-fastapi-backend/module_admin/service/dept_service.py
+++ b/dash-fastapi-backend/module_admin/service/dept_service.py
@@ -254,7 +254,7 @@ class DeptService:
:return:
"""
dept_id_list = dept.ancestors.split(',')
- await DeptDao.update_dept_status_normal_dao(query_db, dept_id_list)
+ await DeptDao.update_dept_status_normal_dao(query_db, list(map(int, dept_id_list)))
@classmethod
async def update_dept_children(cls, query_db: AsyncSession, dept_id: int, new_ancestors: str, old_ancestors: str):
diff --git a/dash-fastapi-backend/sql/dash-fastapi-pg.sql b/dash-fastapi-backend/sql/dash-fastapi-pg.sql
new file mode 100644
index 0000000000000000000000000000000000000000..a40cd9cbd3c7a7d5ba9a80418f30fd0568fc93c0
--- /dev/null
+++ b/dash-fastapi-backend/sql/dash-fastapi-pg.sql
@@ -0,0 +1,978 @@
+-- ----------------------------
+-- 1、部门表
+-- ----------------------------
+drop table if exists sys_dept;
+create table sys_dept (
+ dept_id bigserial,
+ parent_id bigint default 0,
+ ancestors varchar(50) default '',
+ dept_name varchar(30) default '',
+ order_num int4 default 0,
+ leader varchar(20) default null,
+ phone varchar(11) default null,
+ email varchar(50) default null,
+ status char(1) default '0',
+ del_flag char(1) default '0',
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ primary key (dept_id)
+);
+alter sequence sys_dept_dept_id_seq restart 200;
+comment on column sys_dept.dept_id is '部门id';
+comment on column sys_dept.parent_id is '父部门id';
+comment on column sys_dept.ancestors is '祖级列表';
+comment on column sys_dept.dept_name is '部门名称';
+comment on column sys_dept.order_num is '显示顺序';
+comment on column sys_dept.leader is '负责人';
+comment on column sys_dept.phone is '联系电话';
+comment on column sys_dept.email is '邮箱';
+comment on column sys_dept.status is '部门状态(0正常 1停用)';
+comment on column sys_dept.del_flag is '删除标志(0代表存在 2代表删除)';
+comment on column sys_dept.create_by is '创建者';
+comment on column sys_dept.create_time is '创建时间';
+comment on column sys_dept.update_by is '更新者';
+comment on column sys_dept.update_time is '更新时间';
+comment on table sys_dept is '部门表';
+
+-- ----------------------------
+-- 初始化-部门表数据
+-- ----------------------------
+insert into sys_dept values(100, 0, '0', '集团总公司', 0, '年糕', '15888888888', 'niangao@qq.com', '0', '0', 'admin', current_timestamp, '', null);
+insert into sys_dept values(101, 100, '0,100', '深圳分公司', 1, '年糕', '15888888888', 'niangao@qq.com', '0', '0', 'admin', current_timestamp, '', null);
+insert into sys_dept values(102, 100, '0,100', '长沙分公司', 2, '年糕', '15888888888', 'niangao@qq.com', '0', '0', 'admin', current_timestamp, '', null);
+insert into sys_dept values(103, 101, '0,100,101', '研发部门', 1, '年糕', '15888888888', 'niangao@qq.com', '0', '0', 'admin', current_timestamp, '', null);
+insert into sys_dept values(104, 101, '0,100,101', '市场部门', 2, '年糕', '15888888888', 'niangao@qq.com', '0', '0', 'admin', current_timestamp, '', null);
+insert into sys_dept values(105, 101, '0,100,101', '测试部门', 3, '年糕', '15888888888', 'niangao@qq.com', '0', '0', 'admin', current_timestamp, '', null);
+insert into sys_dept values(106, 101, '0,100,101', '财务部门', 4, '年糕', '15888888888', 'niangao@qq.com', '0', '0', 'admin', current_timestamp, '', null);
+insert into sys_dept values(107, 101, '0,100,101', '运维部门', 5, '年糕', '15888888888', 'niangao@qq.com', '0', '0', 'admin', current_timestamp, '', null);
+insert into sys_dept values(108, 102, '0,100,102', '市场部门', 1, '年糕', '15888888888', 'niangao@qq.com', '0', '0', 'admin', current_timestamp, '', null);
+insert into sys_dept values(109, 102, '0,100,102', '财务部门', 2, '年糕', '15888888888', 'niangao@qq.com', '0', '0', 'admin', current_timestamp, '', null);
+
+-- ----------------------------
+-- 2、用户信息表
+-- ----------------------------
+drop table if exists sys_user;
+create table sys_user (
+ user_id bigserial not null,
+ dept_id bigint default null,
+ user_name varchar(30) not null,
+ nick_name varchar(30) not null,
+ user_type varchar(2) default '00',
+ email varchar(50) default '',
+ phonenumber varchar(11) default '',
+ sex char(1) default '0',
+ avatar varchar(100) default '',
+ password varchar(100) default '',
+ status char(1) default '0',
+ del_flag char(1) default '0',
+ login_ip varchar(128) default '',
+ login_date timestamp(0),
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ remark varchar(500) default null,
+ primary key (user_id)
+);
+alter sequence sys_user_user_id_seq restart 100;
+comment on column sys_user.user_id is '用户ID';
+comment on column sys_user.dept_id is '部门ID';
+comment on column sys_user.user_name is '用户账号';
+comment on column sys_user.nick_name is '用户昵称';
+comment on column sys_user.user_type is '用户类型(00系统用户)';
+comment on column sys_user.email is '用户邮箱';
+comment on column sys_user.phonenumber is '手机号码';
+comment on column sys_user.sex is '用户性别(0男 1女 2未知)';
+comment on column sys_user.avatar is '头像地址';
+comment on column sys_user.password is '密码';
+comment on column sys_user.status is '帐号状态(0正常 1停用)';
+comment on column sys_user.del_flag is '删除标志(0代表存在 2代表删除)';
+comment on column sys_user.login_ip is '最后登录IP';
+comment on column sys_user.login_date is '最后登录时间';
+comment on column sys_user.create_by is '创建者';
+comment on column sys_user.create_time is '创建时间';
+comment on column sys_user.update_by is '更新者';
+comment on column sys_user.update_time is '更新时间';
+comment on column sys_user.remark is '备注';
+comment on table sys_user is '用户信息表';
+
+-- ----------------------------
+-- 3、岗位信息表
+-- ----------------------------
+drop table if exists sys_post;
+create table sys_post (
+ post_id bigserial not null,
+ post_code varchar(64) not null,
+ post_name varchar(50) not null,
+ post_sort int4 not null,
+ status char(1) not null,
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ remark varchar(500) default null,
+ primary key (post_id)
+);
+alter sequence sys_post_post_id_seq restart 5;
+comment on column sys_post.post_id is '岗位ID';
+comment on column sys_post.post_code is '岗位编码';
+comment on column sys_post.post_name is '岗位名称';
+comment on column sys_post.post_sort is '显示顺序';
+comment on column sys_post.status is '状态(0正常 1停用)';
+comment on column sys_post.create_by is '创建者';
+comment on column sys_post.create_time is '创建时间';
+comment on column sys_post.update_by is '更新者';
+comment on column sys_post.update_time is '更新时间';
+comment on column sys_post.remark is '备注';
+comment on table sys_post is '岗位信息表';
+
+-- ----------------------------
+-- 初始化-岗位信息表数据
+-- ----------------------------
+insert into sys_post values(1, 'ceo', '董事长', 1, '0', 'admin', current_timestamp, '', null, '');
+insert into sys_post values(2, 'se', '项目经理', 2, '0', 'admin', current_timestamp, '', null, '');
+insert into sys_post values(3, 'hr', '人力资源', 3, '0', 'admin', current_timestamp, '', null, '');
+insert into sys_post values(4, 'user', '普通员工', 4, '0', 'admin', current_timestamp, '', null, '');
+
+-- ----------------------------
+-- 初始化-用户信息表数据
+-- ----------------------------
+insert into sys_user values(1, 103, 'admin', '超级管理员', '00', 'niangao@163.com', '15888888888', '1', '', '$2a$10$7JB720yubVSZvUI0rEqK/.VqGOZTH.ulu33dHOiBE8ByOhJIrdAu2', '0', '0', '127.0.0.1', current_timestamp, 'admin', current_timestamp, '', null, '管理员');
+insert into sys_user values(2, 105, 'niangao', '年糕', '00', 'niangao@qq.com', '15666666666', '1', '', '$2a$10$7JB720yubVSZvUI0rEqK/.VqGOZTH.ulu33dHOiBE8ByOhJIrdAu2', '0', '0', '127.0.0.1', current_timestamp, 'admin', current_timestamp, '', null, '测试员');
+
+-- ----------------------------
+-- 4、角色信息表
+-- ----------------------------
+drop table if exists sys_role;
+create table sys_role (
+ role_id bigserial not null,
+ role_name varchar(30) not null,
+ role_key varchar(100) not null,
+ role_sort int4 not null,
+ data_scope char(1) default '1',
+ menu_check_strictly smallint default 1,
+ dept_check_strictly smallint default 1,
+ status char(1) not null,
+ del_flag char(1) default '0',
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ remark varchar(500) default null,
+ primary key (role_id)
+);
+alter sequence sys_role_role_id_seq restart 3;
+comment on column sys_role.role_id is '角色ID';
+comment on column sys_role.role_name is '角色名称';
+comment on column sys_role.role_key is '角色权限字符串';
+comment on column sys_role.role_sort is '显示顺序';
+comment on column sys_role.data_scope is '数据范围(1:全部数据权限 2:自定数据权限 3:本部门数据权限 4:本部门及以下数据权限)';
+comment on column sys_role.menu_check_strictly is '菜单树选择项是否关联显示';
+comment on column sys_role.dept_check_strictly is '部门树选择项是否关联显示';
+comment on column sys_role.status is '角色状态(0正常 1停用)';
+comment on column sys_role.del_flag is '删除标志(0代表存在 2代表删除)';
+comment on column sys_role.create_by is '创建者';
+comment on column sys_role.create_time is '创建时间';
+comment on column sys_role.update_by is '更新者';
+comment on column sys_role.update_time is '更新时间';
+comment on column sys_role.remark is '备注';
+comment on table sys_role is '角色信息表';
+
+-- ----------------------------
+-- 初始化-角色信息表数据
+-- ----------------------------
+insert into sys_role values(1, '超级管理员', 'admin', 1, 1, 1, 1, '0', '0', 'admin', current_timestamp, '', null, '超级管理员');
+insert into sys_role values(2, '普通角色', 'common', 2, 2, 1, 1, '0', '0', 'admin', current_timestamp, '', null, '普通角色');
+
+-- ----------------------------
+-- 5、菜单权限表
+-- ----------------------------
+drop table if exists sys_menu;
+create table sys_menu (
+ menu_id bigserial not null,
+ menu_name varchar(50) not null,
+ parent_id bigint default 0,
+ order_num int4 default 0,
+ path varchar(200) default '',
+ component varchar(255) default null,
+ query varchar(255) default null,
+ route_name varchar(50) default '',
+ is_frame int4 default 1,
+ is_cache int4 default 0,
+ menu_type char(1) default '',
+ visible char(1) default '0',
+ status char(1) default '0',
+ perms varchar(100) default null,
+ icon varchar(100) default '#',
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ remark varchar(500) default '',
+ primary key (menu_id)
+);
+alter sequence sys_menu_menu_id_seq restart 2000;
+comment on column sys_menu.menu_id is '菜单ID';
+comment on column sys_menu.menu_name is '菜单名称';
+comment on column sys_menu.parent_id is '父菜单ID';
+comment on column sys_menu.order_num is '显示顺序';
+comment on column sys_menu.path is '路由地址';
+comment on column sys_menu.component is '组件路径';
+comment on column sys_menu.query is '路由参数';
+comment on column sys_menu.route_name is '路由名称';
+comment on column sys_menu.is_frame is '是否为外链(0是 1否)';
+comment on column sys_menu.is_cache is '是否缓存(0缓存 1不缓存)';
+comment on column sys_menu.menu_type is '菜单类型(M目录 C菜单 F按钮)';
+comment on column sys_menu.visible is '菜单状态(0显示 1隐藏)';
+comment on column sys_menu.status is '菜单状态(0正常 1停用)';
+comment on column sys_menu.perms is '权限标识';
+comment on column sys_menu.icon is '菜单图标';
+comment on column sys_menu.create_by is '创建者';
+comment on column sys_menu.create_time is '创建时间';
+comment on column sys_menu.update_by is '更新者';
+comment on column sys_menu.update_time is '更新时间';
+comment on column sys_menu.remark is '备注';
+comment on table sys_menu is '菜单权限表';
+
+-- ----------------------------
+-- 初始化-菜单信息表数据
+-- ----------------------------
+-- 一级菜单
+insert into sys_menu values(1, '系统管理', 0, '1', 'system', null, '', '', 1, 0, 'M', '0', '0', '', 'antd-setting', 'admin', current_timestamp, '', null, '系统管理目录');
+insert into sys_menu values(2, '系统监控', 0, '2', 'monitor', null, '', '', 1, 0, 'M', '0', '0', '', 'antd-fund-projection-screen', 'admin', current_timestamp, '', null, '系统监控目录');
+insert into sys_menu values(3, '系统工具', 0, '3', 'tool', null, '', '', 1, 0, 'M', '0', '0', '', 'antd-repair', 'admin', current_timestamp, '', null, '系统工具目录');
+insert into sys_menu values(4, '若依官网', 0, '4', 'http://ruoyi.vip', null, '', '', 0, 0, 'M', '0', '0', '', 'antd-send', 'admin', current_timestamp, '', null, '若依官网地址');
+-- 二级菜单
+insert into sys_menu values(100, '用户管理', 1, '1', 'user', 'system.user', '', '', 1, 0, 'C', '0', '0', 'system:user:list', 'antd-user', 'admin', current_timestamp, '', null, '用户管理菜单');
+insert into sys_menu values(101, '角色管理', 1, '2', 'role', 'system.role', '', '', 1, 0, 'C', '0', '0', 'system:role:list', 'antd-team', 'admin', current_timestamp, '', null, '角色管理菜单');
+insert into sys_menu values(102, '菜单管理', 1, '3', 'menu', 'system.menu', '', '', 1, 0, 'C', '0', '0', 'system:menu:list', 'antd-app-store-add', 'admin', current_timestamp, '', null, '菜单管理菜单');
+insert into sys_menu values(103, '部门管理', 1, '4', 'dept', 'system.dept', '', '', 1, 0, 'C', '0', '0', 'system:dept:list', 'antd-cluster', 'admin', current_timestamp, '', null, '部门管理菜单');
+insert into sys_menu values(104, '岗位管理', 1, '5', 'post', 'system.post', '', '', 1, 0, 'C', '0', '0', 'system:post:list', 'antd-idcard', 'admin', current_timestamp, '', null, '岗位管理菜单');
+insert into sys_menu values(105, '字典管理', 1, '6', 'dict', 'system.dict', '', '', 1, 0, 'C', '0', '0', 'system:dict:list', 'antd-read', 'admin', current_timestamp, '', null, '字典管理菜单');
+insert into sys_menu values(106, '参数设置', 1, '7', 'config', 'system.config', '', '', 1, 0, 'C', '0', '0', 'system:config:list', 'antd-calculator', 'admin', current_timestamp, '', null, '参数设置菜单');
+insert into sys_menu values(107, '通知公告', 1, '8', 'notice', 'system.notice', '', '', 1, 0, 'C', '0', '0', 'system:notice:list', 'antd-notification', 'admin', current_timestamp, '', null, '通知公告菜单');
+insert into sys_menu values(108, '日志管理', 1, '9', 'log', '', '', '', 1, 0, 'M', '0', '0', '', 'antd-bug', 'admin', current_timestamp, '', null, '日志管理菜单');
+insert into sys_menu values(109, '在线用户', 2, '1', 'online', 'monitor.online', '', '', 1, 0, 'C', '0', '0', 'monitor:online:list', 'antd-desktop', 'admin', current_timestamp, '', null, '在线用户菜单');
+insert into sys_menu values(110, '定时任务', 2, '2', 'job', 'monitor.job', '', '', 1, 0, 'C', '0', '0', 'monitor:job:list', 'antd-deployment-unit', 'admin', current_timestamp, '', null, '定时任务菜单');
+insert into sys_menu values(111, '数据监控', 2, '3', 'druid', 'monitor.druid', '', '', 1, 0, 'C', '0', '0', 'monitor:druid:list', 'antd-database', 'admin', current_timestamp, '', null, '数据监控菜单');
+insert into sys_menu values(112, '服务监控', 2, '4', 'server', 'monitor.server', '', '', 1, 0, 'C', '0', '0', 'monitor:server:list', 'antd-cloud-server', 'admin', current_timestamp, '', null, '服务监控菜单');
+insert into sys_menu values(113, '缓存监控', 2, '5', 'cache', 'monitor.cache.control', '', '', 1, 0, 'C', '0', '0', 'monitor:cache:list', 'antd-cloud-sync', 'admin', current_timestamp, '', null, '缓存监控菜单');
+insert into sys_menu values(114, '缓存列表', 2, '6', 'cacheList', 'monitor.cache.list', '', '', 1, 0, 'C', '0', '0', 'monitor:cache:list', 'antd-table', 'admin', current_timestamp, '', null, '缓存列表菜单');
+insert into sys_menu values(115, '表单构建', 3, '1', 'build', 'tool.build', '', '', 1, 0, 'C', '0', '0', 'tool:build:list', 'antd-build', 'admin', current_timestamp, '', null, '表单构建菜单');
+insert into sys_menu values(116, '代码生成', 3, '2', 'gen', 'tool.gen', '', '', 1, 0, 'C', '0', '0', 'tool:gen:list', 'antd-console-sql', 'admin', current_timestamp, '', null, '代码生成菜单');
+insert into sys_menu values(117, '系统接口', 3, '3', 'swagger', 'tool.swagger', '', '', 1, 0, 'C', '0', '0', 'tool:swagger:list', 'antd-api', 'admin', current_timestamp, '', null, '系统接口菜单');
+-- 三级菜单
+insert into sys_menu values(500, '操作日志', 108, '1', 'operlog', 'monitor.operlog', '', '', 1, 0, 'C', '0', '0', 'monitor:operlog:list', 'antd-clear', 'admin', current_timestamp, '', null, '操作日志菜单');
+insert into sys_menu values(501, '登录日志', 108, '2', 'logininfor', 'monitor.logininfor', '', '', 1, 0, 'C', '0', '0', 'monitor:logininfor:list', 'antd-control', 'admin', current_timestamp, '', null, '登录日志菜单');
+-- 用户管理按钮
+insert into sys_menu values(1000, '用户查询', 100, '1', '', '', '', '', 1, 0, 'F', '0', '0', 'system:user:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1001, '用户新增', 100, '2', '', '', '', '', 1, 0, 'F', '0', '0', 'system:user:add', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1002, '用户修改', 100, '3', '', '', '', '', 1, 0, 'F', '0', '0', 'system:user:edit', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1003, '用户删除', 100, '4', '', '', '', '', 1, 0, 'F', '0', '0', 'system:user:remove', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1004, '用户导出', 100, '5', '', '', '', '', 1, 0, 'F', '0', '0', 'system:user:export', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1005, '用户导入', 100, '6', '', '', '', '', 1, 0, 'F', '0', '0', 'system:user:import', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1006, '重置密码', 100, '7', '', '', '', '', 1, 0, 'F', '0', '0', 'system:user:resetPwd', '#', 'admin', current_timestamp, '', null, '');
+-- 角色管理按钮
+insert into sys_menu values(1007, '角色查询', 101, '1', '', '', '', '', 1, 0, 'F', '0', '0', 'system:role:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1008, '角色新增', 101, '2', '', '', '', '', 1, 0, 'F', '0', '0', 'system:role:add', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1009, '角色修改', 101, '3', '', '', '', '', 1, 0, 'F', '0', '0', 'system:role:edit', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1010, '角色删除', 101, '4', '', '', '', '', 1, 0, 'F', '0', '0', 'system:role:remove', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1011, '角色导出', 101, '5', '', '', '', '', 1, 0, 'F', '0', '0', 'system:role:export', '#', 'admin', current_timestamp, '', null, '');
+-- 菜单管理按钮
+insert into sys_menu values(1012, '菜单查询', 102, '1', '', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1013, '菜单新增', 102, '2', '', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:add', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1014, '菜单修改', 102, '3', '', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:edit', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1015, '菜单删除', 102, '4', '', '', '', '', 1, 0, 'F', '0', '0', 'system:menu:remove', '#', 'admin', current_timestamp, '', null, '');
+-- 部门管理按钮
+insert into sys_menu values(1016, '部门查询', 103, '1', '', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1017, '部门新增', 103, '2', '', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:add', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1018, '部门修改', 103, '3', '', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:edit', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1019, '部门删除', 103, '4', '', '', '', '', 1, 0, 'F', '0', '0', 'system:dept:remove', '#', 'admin', current_timestamp, '', null, '');
+-- 岗位管理按钮
+insert into sys_menu values(1020, '岗位查询', 104, '1', '', '', '', '', 1, 0, 'F', '0', '0', 'system:post:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1021, '岗位新增', 104, '2', '', '', '', '', 1, 0, 'F', '0', '0', 'system:post:add', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1022, '岗位修改', 104, '3', '', '', '', '', 1, 0, 'F', '0', '0', 'system:post:edit', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1023, '岗位删除', 104, '4', '', '', '', '', 1, 0, 'F', '0', '0', 'system:post:remove', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1024, '岗位导出', 104, '5', '', '', '', '', 1, 0, 'F', '0', '0', 'system:post:export', '#', 'admin', current_timestamp, '', null, '');
+-- 字典管理按钮
+insert into sys_menu values(1025, '字典查询', 105, '1', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:dict:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1026, '字典新增', 105, '2', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:dict:add', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1027, '字典修改', 105, '3', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:dict:edit', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1028, '字典删除', 105, '4', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:dict:remove', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1029, '字典导出', 105, '5', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:dict:export', '#', 'admin', current_timestamp, '', null, '');
+-- 参数设置按钮
+insert into sys_menu values(1030, '参数查询', 106, '1', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:config:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1031, '参数新增', 106, '2', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:config:add', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1032, '参数修改', 106, '3', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:config:edit', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1033, '参数删除', 106, '4', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:config:remove', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1034, '参数导出', 106, '5', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:config:export', '#', 'admin', current_timestamp, '', null, '');
+-- 通知公告按钮
+insert into sys_menu values(1035, '公告查询', 107, '1', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:notice:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1036, '公告新增', 107, '2', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:notice:add', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1037, '公告修改', 107, '3', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:notice:edit', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1038, '公告删除', 107, '4', '#', '', '', '', 1, 0, 'F', '0', '0', 'system:notice:remove', '#', 'admin', current_timestamp, '', null, '');
+-- 操作日志按钮
+insert into sys_menu values(1039, '操作查询', 500, '1', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:operlog:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1040, '操作删除', 500, '2', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:operlog:remove', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1041, '日志导出', 500, '3', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:operlog:export', '#', 'admin', current_timestamp, '', null, '');
+-- 登录日志按钮
+insert into sys_menu values(1042, '登录查询', 501, '1', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1043, '登录删除', 501, '2', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:remove', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1044, '日志导出', 501, '3', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:export', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1045, '账户解锁', 501, '4', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:logininfor:unlock', '#', 'admin', current_timestamp, '', null, '');
+-- 在线用户按钮
+insert into sys_menu values(1046, '在线查询', 109, '1', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:online:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1047, '批量强退', 109, '2', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:online:batchLogout', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1048, '单条强退', 109, '3', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:online:forceLogout', '#', 'admin', current_timestamp, '', null, '');
+-- 定时任务按钮
+insert into sys_menu values(1049, '任务查询', 110, '1', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:job:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1050, '任务新增', 110, '2', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:job:add', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1051, '任务修改', 110, '3', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:job:edit', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1052, '任务删除', 110, '4', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:job:remove', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1053, '状态修改', 110, '5', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:job:changeStatus', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1054, '任务导出', 110, '6', '#', '', '', '', 1, 0, 'F', '0', '0', 'monitor:job:export', '#', 'admin', current_timestamp, '', null, '');
+-- 代码生成按钮
+insert into sys_menu values(1055, '生成查询', 116, '1', '#', '', '', '', 1, 0, 'F', '0', '0', 'tool:gen:query', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1056, '生成修改', 116, '2', '#', '', '', '', 1, 0, 'F', '0', '0', 'tool:gen:edit', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1057, '生成删除', 116, '3', '#', '', '', '', 1, 0, 'F', '0', '0', 'tool:gen:remove', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1058, '导入代码', 116, '4', '#', '', '', '', 1, 0, 'F', '0', '0', 'tool:gen:import', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1059, '预览代码', 116, '5', '#', '', '', '', 1, 0, 'F', '0', '0', 'tool:gen:preview', '#', 'admin', current_timestamp, '', null, '');
+insert into sys_menu values(1060, '生成代码', 116, '6', '#', '', '', '', 1, 0, 'F', '0', '0', 'tool:gen:code', '#', 'admin', current_timestamp, '', null, '');
+
+-- ----------------------------
+-- 6、用户和角色关联表 用户N-1角色
+-- ----------------------------
+drop table if exists sys_user_role;
+create table sys_user_role (
+ user_id bigint not null,
+ role_id bigint not null,
+ primary key (user_id, role_id)
+);
+comment on column sys_user_role.user_id is '用户ID';
+comment on column sys_user_role.role_id is '角色ID';
+comment on table sys_user_role is '用户和角色关联表';
+
+-- ----------------------------
+-- 初始化-用户和角色关联表数据
+-- ----------------------------
+insert into sys_user_role values (1, 1);
+insert into sys_user_role values (2, 2);
+
+-- ----------------------------
+-- 7、角色和菜单关联表 角色1-N菜单
+-- ----------------------------
+drop table if exists sys_role_menu;
+create table sys_role_menu (
+ role_id bigint not null,
+ menu_id bigint not null,
+ primary key (role_id, menu_id)
+);
+comment on column sys_role_menu.role_id is '角色ID';
+comment on column sys_role_menu.menu_id is '菜单ID';
+comment on table sys_role_menu is '角色和菜单关联表';
+
+-- ----------------------------
+-- 初始化-角色和菜单关联表数据
+-- ----------------------------
+insert into sys_role_menu values (2, 1);
+insert into sys_role_menu values (2, 2);
+insert into sys_role_menu values (2, 3);
+insert into sys_role_menu values (2, 4);
+insert into sys_role_menu values (2, 100);
+insert into sys_role_menu values (2, 101);
+insert into sys_role_menu values (2, 102);
+insert into sys_role_menu values (2, 103);
+insert into sys_role_menu values (2, 104);
+insert into sys_role_menu values (2, 105);
+insert into sys_role_menu values (2, 106);
+insert into sys_role_menu values (2, 107);
+insert into sys_role_menu values (2, 108);
+insert into sys_role_menu values (2, 109);
+insert into sys_role_menu values (2, 110);
+insert into sys_role_menu values (2, 111);
+insert into sys_role_menu values (2, 112);
+insert into sys_role_menu values (2, 113);
+insert into sys_role_menu values (2, 114);
+insert into sys_role_menu values (2, 115);
+insert into sys_role_menu values (2, 116);
+insert into sys_role_menu values (2, 117);
+insert into sys_role_menu values (2, 500);
+insert into sys_role_menu values (2, 501);
+insert into sys_role_menu values (2, 1000);
+insert into sys_role_menu values (2, 1001);
+insert into sys_role_menu values (2, 1002);
+insert into sys_role_menu values (2, 1003);
+insert into sys_role_menu values (2, 1004);
+insert into sys_role_menu values (2, 1005);
+insert into sys_role_menu values (2, 1006);
+insert into sys_role_menu values (2, 1007);
+insert into sys_role_menu values (2, 1008);
+insert into sys_role_menu values (2, 1009);
+insert into sys_role_menu values (2, 1010);
+insert into sys_role_menu values (2, 1011);
+insert into sys_role_menu values (2, 1012);
+insert into sys_role_menu values (2, 1013);
+insert into sys_role_menu values (2, 1014);
+insert into sys_role_menu values (2, 1015);
+insert into sys_role_menu values (2, 1016);
+insert into sys_role_menu values (2, 1017);
+insert into sys_role_menu values (2, 1018);
+insert into sys_role_menu values (2, 1019);
+insert into sys_role_menu values (2, 1020);
+insert into sys_role_menu values (2, 1021);
+insert into sys_role_menu values (2, 1022);
+insert into sys_role_menu values (2, 1023);
+insert into sys_role_menu values (2, 1024);
+insert into sys_role_menu values (2, 1025);
+insert into sys_role_menu values (2, 1026);
+insert into sys_role_menu values (2, 1027);
+insert into sys_role_menu values (2, 1028);
+insert into sys_role_menu values (2, 1029);
+insert into sys_role_menu values (2, 1030);
+insert into sys_role_menu values (2, 1031);
+insert into sys_role_menu values (2, 1032);
+insert into sys_role_menu values (2, 1033);
+insert into sys_role_menu values (2, 1034);
+insert into sys_role_menu values (2, 1035);
+insert into sys_role_menu values (2, 1036);
+insert into sys_role_menu values (2, 1037);
+insert into sys_role_menu values (2, 1038);
+insert into sys_role_menu values (2, 1039);
+insert into sys_role_menu values (2, 1040);
+insert into sys_role_menu values (2, 1041);
+insert into sys_role_menu values (2, 1042);
+insert into sys_role_menu values (2, 1043);
+insert into sys_role_menu values (2, 1044);
+insert into sys_role_menu values (2, 1045);
+insert into sys_role_menu values (2, 1046);
+insert into sys_role_menu values (2, 1047);
+insert into sys_role_menu values (2, 1048);
+insert into sys_role_menu values (2, 1049);
+insert into sys_role_menu values (2, 1050);
+insert into sys_role_menu values (2, 1051);
+insert into sys_role_menu values (2, 1052);
+insert into sys_role_menu values (2, 1053);
+insert into sys_role_menu values (2, 1054);
+insert into sys_role_menu values (2, 1055);
+insert into sys_role_menu values (2, 1056);
+insert into sys_role_menu values (2, 1057);
+insert into sys_role_menu values (2, 1058);
+insert into sys_role_menu values (2, 1059);
+insert into sys_role_menu values (2, 1060);
+
+-- ----------------------------
+-- 8、角色和部门关联表 角色1-N部门
+-- ----------------------------
+drop table if exists sys_role_dept;
+create table sys_role_dept (
+ role_id bigint not null,
+ dept_id bigint not null,
+ primary key (role_id, dept_id)
+);
+comment on column sys_role_dept.role_id is '角色ID';
+comment on column sys_role_dept.dept_id is '部门ID';
+comment on table sys_role_dept is '角色和部门关联表';
+
+-- ----------------------------
+-- 初始化-角色和部门关联表数据
+-- ----------------------------
+insert into sys_role_dept values (2, 100);
+insert into sys_role_dept values (2, 101);
+insert into sys_role_dept values (2, 105);
+
+-- ----------------------------
+-- 9、用户与岗位关联表 用户1-N岗位
+-- ----------------------------
+drop table if exists sys_user_post;
+create table sys_user_post (
+ user_id bigint not null,
+ post_id bigint not null,
+ primary key (user_id, post_id)
+);
+comment on column sys_user_post.user_id is '用户ID';
+comment on column sys_user_post.post_id is '岗位ID';
+comment on table sys_user_post is '用户与岗位关联表';
+
+-- ----------------------------
+-- 初始化-用户与岗位关联表数据
+-- ----------------------------
+insert into sys_user_post values (1, 1);
+insert into sys_user_post values (2, 2);
+
+-- ----------------------------
+-- 10、操作日志记录
+-- ----------------------------
+drop table if exists sys_oper_log;
+create table sys_oper_log (
+ oper_id bigserial not null,
+ title varchar(50) default '',
+ business_type int4 default 0,
+ method varchar(100) default '',
+ request_method varchar(10) default '',
+ operator_type int4 default 0,
+ oper_name varchar(50) default '',
+ dept_name varchar(50) default '',
+ oper_url varchar(255) default '',
+ oper_ip varchar(128) default '',
+ oper_location varchar(255) default '',
+ oper_param varchar(2000) default '',
+ json_result varchar(2000) default '',
+ status int4 default 0,
+ error_msg varchar(2000) default '',
+ oper_time timestamp(0),
+ cost_time int8 default 0,
+ primary key (oper_id)
+);
+alter sequence sys_oper_log_oper_id_seq restart 100;
+create index idx_sys_oper_log_bt on sys_oper_log(business_type);
+create index idx_sys_oper_log_s on sys_oper_log(status);
+create index idx_sys_oper_log_ot on sys_oper_log(oper_time);
+comment on column sys_oper_log.oper_id is '日志主键';
+comment on column sys_oper_log.title is '模块标题';
+comment on column sys_oper_log.business_type is '业务类型(0其它 1新增 2修改 3删除)';
+comment on column sys_oper_log.method is '方法名称';
+comment on column sys_oper_log.request_method is '请求方式';
+comment on column sys_oper_log.operator_type is '操作类别(0其它 1后台用户 2手机端用户)';
+comment on column sys_oper_log.oper_name is '操作人员';
+comment on column sys_oper_log.dept_name is '部门名称';
+comment on column sys_oper_log.oper_url is '请求URL';
+comment on column sys_oper_log.oper_ip is '主机地址';
+comment on column sys_oper_log.oper_location is '操作地点';
+comment on column sys_oper_log.oper_param is '请求参数';
+comment on column sys_oper_log.json_result is '返回参数';
+comment on column sys_oper_log.status is '操作状态(0正常 1异常)';
+comment on column sys_oper_log.error_msg is '错误消息';
+comment on column sys_oper_log.oper_time is '操作时间';
+comment on table sys_oper_log is '操作日志记录';
+
+-- ----------------------------
+-- 11、字典类型表
+-- ----------------------------
+drop table if exists sys_dict_type;
+create table sys_dict_type (
+ dict_id bigserial not null,
+ dict_name varchar(100) default '',
+ dict_type varchar(100) unique default '',
+ status char(1) default '0',
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ remark varchar(500) default null,
+ primary key (dict_id)
+);
+alter sequence sys_dict_type_dict_id_seq restart 100;
+comment on column sys_dict_type.dict_id is '字典主键';
+comment on column sys_dict_type.dict_name is '字典名称';
+comment on column sys_dict_type.dict_type is '字典类型';
+comment on column sys_dict_type.status is '状态(0正常 1停用)';
+comment on column sys_dict_type.create_by is '创建者';
+comment on column sys_dict_type.create_time is '创建时间';
+comment on column sys_dict_type.update_by is '更新者';
+comment on column sys_dict_type.update_time is '更新时间';
+comment on column sys_dict_type.remark is '备注';
+comment on table sys_dict_type is '字典类型表';
+
+-- ----------------------------
+-- 初始化-字典类型表数据
+-- ----------------------------
+insert into sys_dict_type values(1, '用户性别', 'sys_user_sex', '0', 'admin', current_timestamp, '', null, '用户性别列表');
+insert into sys_dict_type values(2, '菜单状态', 'sys_show_hide', '0', 'admin', current_timestamp, '', null, '菜单状态列表');
+insert into sys_dict_type values(3, '系统开关', 'sys_normal_disable', '0', 'admin', current_timestamp, '', null, '系统开关列表');
+insert into sys_dict_type values(4, '任务状态', 'sys_job_status', '0', 'admin', current_timestamp, '', null, '任务状态列表');
+insert into sys_dict_type values(5, '任务分组', 'sys_job_group', '0', 'admin', current_timestamp, '', null, '任务分组列表');
+insert into sys_dict_type values(6, '任务执行器', 'sys_job_executor', '0', 'admin', current_timestamp, '', null, '任务执行器列表');
+insert into sys_dict_type values(7, '系统是否', 'sys_yes_no', '0', 'admin', current_timestamp, '', null, '系统是否列表');
+insert into sys_dict_type values(8, '通知类型', 'sys_notice_type', '0', 'admin', current_timestamp, '', null, '通知类型列表');
+insert into sys_dict_type values(9, '通知状态', 'sys_notice_status', '0', 'admin', current_timestamp, '', null, '通知状态列表');
+insert into sys_dict_type values(10, '操作类型', 'sys_oper_type', '0', 'admin', current_timestamp, '', null, '操作类型列表');
+insert into sys_dict_type values(11, '系统状态', 'sys_common_status', '0', 'admin', current_timestamp, '', null, '登录状态列表');
+
+-- ----------------------------
+-- 12、字典数据表
+-- ----------------------------
+drop table if exists sys_dict_data;
+create table sys_dict_data (
+ dict_code bigserial not null,
+ dict_sort int4 default 0,
+ dict_label varchar(100) default '',
+ dict_value varchar(100) default '',
+ dict_type varchar(100) default '',
+ css_class varchar(100) default null,
+ list_class varchar(100) default null,
+ is_default char(1) default 'N',
+ status char(1) default '0',
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ remark varchar(500) default null,
+ primary key (dict_code)
+);
+alter sequence sys_dict_data_dict_code_seq restart 100;
+comment on column sys_dict_data.dict_code is '字典编码';
+comment on column sys_dict_data.dict_sort is '字典排序';
+comment on column sys_dict_data.dict_label is '字典标签';
+comment on column sys_dict_data.dict_value is '字典键值';
+comment on column sys_dict_data.dict_type is '字典类型';
+comment on column sys_dict_data.css_class is '样式属性(其他样式扩展)';
+comment on column sys_dict_data.list_class is '表格回显样式';
+comment on column sys_dict_data.is_default is '是否默认(Y是 N否)';
+comment on column sys_dict_data.status is '状态(0正常 1停用)';
+comment on column sys_dict_data.create_by is '创建者';
+comment on column sys_dict_data.create_time is '创建时间';
+comment on column sys_dict_data.update_by is '更新者';
+comment on column sys_dict_data.update_time is '更新时间';
+comment on column sys_dict_data.remark is '备注';
+comment on table sys_dict_data is '字典数据表';
+
+-- ----------------------------
+-- 初始化-字典数据表数据
+-- ----------------------------
+insert into sys_dict_data values(1, 1, '男', '0', 'sys_user_sex', '', '', 'Y', '0', 'admin', current_timestamp, '', null, '性别男');
+insert into sys_dict_data values(2, 2, '女', '1', 'sys_user_sex', '', '', 'N', '0', 'admin', current_timestamp, '', null, '性别女');
+insert into sys_dict_data values(3, 3, '未知', '2', 'sys_user_sex', '', '', 'N', '0', 'admin', current_timestamp, '', null, '性别未知');
+insert into sys_dict_data values(4, 1, '显示', '0', 'sys_show_hide', '', 'primary', 'Y', '0', 'admin', current_timestamp, '', null, '显示菜单');
+insert into sys_dict_data values(5, 2, '隐藏', '1', 'sys_show_hide', '', 'danger', 'N', '0', 'admin', current_timestamp, '', null, '隐藏菜单');
+insert into sys_dict_data values(6, 1, '正常', '0', 'sys_normal_disable', '', 'primary', 'Y', '0', 'admin', current_timestamp, '', null, '正常状态');
+insert into sys_dict_data values(7, 2, '停用', '1', 'sys_normal_disable', '', 'danger', 'N', '0', 'admin', current_timestamp, '', null, '停用状态');
+insert into sys_dict_data values(8, 1, '正常', '0', 'sys_job_status', '', 'primary', 'Y', '0', 'admin', current_timestamp, '', null, '正常状态');
+insert into sys_dict_data values(9, 2, '暂停', '1', 'sys_job_status', '', 'danger', 'N', '0', 'admin', current_timestamp, '', null, '停用状态');
+insert into sys_dict_data values(10, 1, '默认', 'default', 'sys_job_group', '', 'default', 'Y', '0', 'admin', current_timestamp, '', null, '默认分组');
+insert into sys_dict_data values(11, 2, '数据库', 'sqlalchemy', 'sys_job_group', '', 'success', 'N', '0', 'admin', current_timestamp, '', null, '数据库分组');
+insert into sys_dict_data values(12, 3, 'redis', 'redis', 'sys_job_group', '', 'warning', 'N', '0', 'admin', current_timestamp, '', null, 'reids分组');
+insert into sys_dict_data values(13, 1, '默认', 'default', 'sys_job_executor', '', 'default', 'N', '0', 'admin', current_timestamp, '', null, '线程池');
+insert into sys_dict_data values(14, 2, '进程池', 'processpool', 'sys_job_executor', '', 'primary', 'N', '0', 'admin', current_timestamp, '', null, '进程池');
+insert into sys_dict_data values(15, 1, '是', 'Y', 'sys_yes_no', '', 'primary', 'Y', '0', 'admin', current_timestamp, '', null, '系统默认是');
+insert into sys_dict_data values(16, 2, '否', 'N', 'sys_yes_no', '', 'danger', 'N', '0', 'admin', current_timestamp, '', null, '系统默认否');
+insert into sys_dict_data values(17, 1, '通知', '1', 'sys_notice_type', '', 'warning', 'Y', '0', 'admin', current_timestamp, '', null, '通知');
+insert into sys_dict_data values(18, 2, '公告', '2', 'sys_notice_type', '', 'success', 'N', '0', 'admin', current_timestamp, '', null, '公告');
+insert into sys_dict_data values(19, 1, '正常', '0', 'sys_notice_status', '', 'primary', 'Y', '0', 'admin', current_timestamp, '', null, '正常状态');
+insert into sys_dict_data values(20, 2, '关闭', '1', 'sys_notice_status', '', 'danger', 'N', '0', 'admin', current_timestamp, '', null, '关闭状态');
+insert into sys_dict_data values(21, 99, '其他', '0', 'sys_oper_type', '', 'info', 'N', '0', 'admin', current_timestamp, '', null, '其他操作');
+insert into sys_dict_data values(22, 1, '新增', '1', 'sys_oper_type', '', 'info', 'N', '0', 'admin', current_timestamp, '', null, '新增操作');
+insert into sys_dict_data values(23, 2, '修改', '2', 'sys_oper_type', '', 'info', 'N', '0', 'admin', current_timestamp, '', null, '修改操作');
+insert into sys_dict_data values(24, 3, '删除', '3', 'sys_oper_type', '', 'danger', 'N', '0', 'admin', current_timestamp, '', null, '删除操作');
+insert into sys_dict_data values(25, 4, '授权', '4', 'sys_oper_type', '', 'primary', 'N', '0', 'admin', current_timestamp, '', null, '授权操作');
+insert into sys_dict_data values(26, 5, '导出', '5', 'sys_oper_type', '', 'warning', 'N', '0', 'admin', current_timestamp, '', null, '导出操作');
+insert into sys_dict_data values(27, 6, '导入', '6', 'sys_oper_type', '', 'warning', 'N', '0', 'admin', current_timestamp, '', null, '导入操作');
+insert into sys_dict_data values(28, 7, '强退', '7', 'sys_oper_type', '', 'danger', 'N', '0', 'admin', current_timestamp, '', null, '强退操作');
+insert into sys_dict_data values(29, 8, '生成代码', '8', 'sys_oper_type', '', 'warning', 'N', '0', 'admin', current_timestamp, '', null, '生成操作');
+insert into sys_dict_data values(30, 9, '清空数据', '9', 'sys_oper_type', '', 'danger', 'N', '0', 'admin', current_timestamp, '', null, '清空操作');
+insert into sys_dict_data values(31, 1, '成功', '0', 'sys_common_status', '', 'primary', 'N', '0', 'admin', current_timestamp, '', null, '正常状态');
+insert into sys_dict_data values(32, 2, '失败', '1', 'sys_common_status', '', 'danger', 'N', '0', 'admin', current_timestamp, '', null, '停用状态');
+
+-- ----------------------------
+-- 13、参数配置表
+-- ----------------------------
+drop table if exists sys_config;
+create table sys_config (
+ config_id serial not null,
+ config_name varchar(100) default '',
+ config_key varchar(100) default '',
+ config_value varchar(500) default '',
+ config_type char(1) default 'N',
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ remark varchar(500) default null,
+ primary key (config_id)
+);
+alter sequence sys_config_config_id_seq restart 100;
+comment on column sys_config.config_id is '参数主键';
+comment on column sys_config.config_name is '参数名称';
+comment on column sys_config.config_key is '参数键名';
+comment on column sys_config.config_value is '参数键值';
+comment on column sys_config.config_type is '系统内置(Y是 N否)';
+comment on column sys_config.create_by is '创建者';
+comment on column sys_config.create_time is '创建时间';
+comment on column sys_config.update_by is '更新者';
+comment on column sys_config.update_time is '更新时间';
+comment on column sys_config.remark is '备注';
+comment on table sys_config is '参数配置表';
+
+-- ----------------------------
+-- 初始化-参数配置表数据
+-- ----------------------------
+insert into sys_config values(1, '主框架页-默认皮肤样式名称', 'sys.index.skinName', 'skin-blue', 'Y', 'admin', current_timestamp, '', null, '蓝色 skin-blue、绿色 skin-green、紫色 skin-purple、红色 skin-red、黄色 skin-yellow' );
+insert into sys_config values(2, '用户管理-账号初始密码', 'sys.user.initPassword', '123456', 'Y', 'admin', current_timestamp, '', null, '初始化密码 123456' );
+insert into sys_config values(3, '主框架页-侧边栏主题', 'sys.index.sideTheme', 'theme-dark', 'Y', 'admin', current_timestamp, '', null, '深色主题theme-dark,浅色主题theme-light' );
+insert into sys_config values(4, '账号自助-验证码开关', 'sys.account.captchaEnabled', 'true', 'Y', 'admin', current_timestamp, '', null, '是否开启验证码功能(true开启,false关闭)');
+insert into sys_config values(5, '账号自助-是否开启用户注册功能', 'sys.account.registerUser', 'false', 'Y', 'admin', current_timestamp, '', null, '是否开启注册用户功能(true开启,false关闭)');
+insert into sys_config values(6, '账号自助-是否开启忘记密码功能', 'sys.account.forgetUser', 'true', 'Y', 'admin', current_timestamp, '', null, '是否开启忘记密码功能(true开启,false关闭)');
+insert into sys_config values(7, '用户登录-黑名单列表', 'sys.login.blackIPList', '', 'Y', 'admin', current_timestamp, '', null, '设置登录IP黑名单限制,多个匹配项以;分隔,支持匹配(*通配、网段)');
+
+-- ----------------------------
+-- 14、系统访问记录
+-- ----------------------------
+drop table if exists sys_logininfor;
+create table sys_logininfor (
+ info_id bigserial not null,
+ user_name varchar(50) default '',
+ ipaddr varchar(128) default '',
+ login_location varchar(255) default '',
+ browser varchar(50) default '',
+ os varchar(50) default '',
+ status char(1) default '0',
+ msg varchar(255) default '',
+ login_time timestamp(0),
+ primary key (info_id)
+);
+alter sequence sys_logininfor_info_id_seq restart 100;
+create index idx_sys_logininfor_s on sys_logininfor(status);
+create index idx_sys_logininfor_lt on sys_logininfor(login_time);
+comment on column sys_logininfor.info_id is '访问ID';
+comment on column sys_logininfor.user_name is '用户账号';
+comment on column sys_logininfor.ipaddr is '登录IP地址';
+comment on column sys_logininfor.login_location is '登录地点';
+comment on column sys_logininfor.browser is '浏览器类型';
+comment on column sys_logininfor.os is '操作系统';
+comment on column sys_logininfor.status is '登录状态(0成功 1失败)';
+comment on column sys_logininfor.msg is '提示消息';
+comment on column sys_logininfor.login_time is '访问时间';
+comment on table sys_logininfor is '系统访问记录';
+
+-- ----------------------------
+-- 15、定时任务调度表
+-- ----------------------------
+drop table if exists sys_job;
+create table sys_job (
+ job_id bigserial not null,
+ job_name varchar(64) default '',
+ job_group varchar(64) default 'default',
+ job_executor varchar(64) default 'default',
+ invoke_target varchar(500) not null,
+ job_args varchar(255) default '',
+ job_kwargs varchar(255) default '',
+ cron_expression varchar(255) default '',
+ misfire_policy varchar(20) default '3',
+ concurrent char(1) default '1',
+ status char(1) default '0',
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ remark varchar(500) default '',
+ primary key (job_id, job_name, job_group)
+);
+alter sequence sys_job_job_id_seq restart 100;
+comment on column sys_job.job_id is '任务ID';
+comment on column sys_job.job_name is '任务名称';
+comment on column sys_job.job_group is '任务组名';
+comment on column sys_job.job_executor is '任务执行器';
+comment on column sys_job.invoke_target is '调用目标字符串';
+comment on column sys_job.job_args is '位置参数';
+comment on column sys_job.job_kwargs is '关键字参数';
+comment on column sys_job.cron_expression is 'cron执行表达式';
+comment on column sys_job.misfire_policy is '计划执行错误策略(1立即执行 2执行一次 3放弃执行)';
+comment on column sys_job.concurrent is '是否并发执行(0允许 1禁止)';
+comment on column sys_job.status is '状态(0正常 1暂停)';
+comment on column sys_job.create_by is '创建者';
+comment on column sys_job.create_time is '创建时间';
+comment on column sys_job.update_by is '更新者';
+comment on column sys_job.update_time is '更新时间';
+comment on column sys_job.remark is '备注信息';
+comment on table sys_job is '定时任务调度表';
+
+-- ----------------------------
+-- 初始化-定时任务调度表数据
+-- ----------------------------
+insert into sys_job values(1, '系统默认(无参)', 'default', 'default', 'module_task.scheduler_test.job', null, null, '0/10 * * * * ?', '3', '1', '1', 'admin', current_timestamp, '', null, '');
+insert into sys_job values(2, '系统默认(有参)', 'default', 'default', 'module_task.scheduler_test.job', 'test', null, '0/15 * * * * ?', '3', '1', '1', 'admin', current_timestamp, '', null, '');
+insert into sys_job values(3, '系统默认(多参)', 'default', 'default', 'module_task.scheduler_test.job', 'new', '{test: 111}', '0/20 * * * * ?', '3', '1', '1', 'admin', current_timestamp, '', null, '');
+
+-- ----------------------------
+-- 16、定时任务调度日志表
+-- ----------------------------
+drop table if exists sys_job_log;
+create table sys_job_log (
+ job_log_id bigserial not null,
+ job_name varchar(64) not null,
+ job_group varchar(64) not null,
+ job_executor varchar(64) not null,
+ invoke_target varchar(500) not null,
+ job_args varchar(255) default '',
+ job_kwargs varchar(255) default '',
+ job_trigger varchar(255) default '',
+ job_message varchar(500),
+ status char(1) default '0',
+ exception_info varchar(2000) default '',
+ create_time timestamp(0),
+ primary key (job_log_id)
+);
+comment on column sys_job_log.job_log_id is '任务日志ID';
+comment on column sys_job_log.job_name is '任务名称';
+comment on column sys_job_log.job_group is '任务组名';
+comment on column sys_job_log.job_executor is '任务执行器';
+comment on column sys_job_log.invoke_target is '调用目标字符串';
+comment on column sys_job_log.job_args is '位置参数';
+comment on column sys_job_log.job_kwargs is '关键字参数';
+comment on column sys_job_log.job_trigger is '任务触发器';
+comment on column sys_job_log.job_message is '日志信息';
+comment on column sys_job_log.status is '执行状态(0正常 1失败)';
+comment on column sys_job_log.exception_info is '异常信息';
+comment on column sys_job_log.create_time is '创建时间';
+comment on table sys_job_log is '定时任务调度日志表';
+
+-- ----------------------------
+-- 17、通知公告表
+-- ----------------------------
+drop table if exists sys_notice;
+create table sys_notice (
+ notice_id serial not null,
+ notice_title varchar(50) not null,
+ notice_type char(1) not null,
+ notice_content bytea default null,
+ status char(1) default '0',
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ remark varchar(255) default null,
+ primary key (notice_id)
+);
+alter sequence sys_notice_notice_id_seq restart 10;
+comment on column sys_notice.notice_id is '公告ID';
+comment on column sys_notice.notice_title is '公告标题';
+comment on column sys_notice.notice_type is '公告类型(1通知 2公告)';
+comment on column sys_notice.notice_content is '公告内容';
+comment on column sys_notice.status is '公告状态(0正常 1关闭)';
+comment on column sys_notice.create_by is '创建者';
+comment on column sys_notice.create_time is '创建时间';
+comment on column sys_notice.update_by is '更新者';
+comment on column sys_notice.update_time is '更新时间';
+comment on column sys_notice.remark is '备注';
+comment on table sys_notice is '通知公告表';
+
+-- ----------------------------
+-- 初始化-公告信息表数据
+-- ----------------------------
+insert into sys_notice values(1, '温馨提醒:2018-07-01 vfadmin新版本发布啦', '2', '新版本内容', '0', 'admin', current_timestamp, '', null, '管理员');
+insert into sys_notice values(2, '维护通知:2018-07-01 vfadmin系统凌晨维护', '1', '维护内容', '0', 'admin', current_timestamp, '', null, '管理员');
+
+-- ----------------------------
+-- 18、代码生成业务表
+-- ----------------------------
+drop table if exists gen_table;
+create table gen_table (
+ table_id bigserial not null,
+ table_name varchar(200) default '',
+ table_comment varchar(500) default '',
+ sub_table_name varchar(64) default null,
+ sub_table_fk_name varchar(64) default null,
+ class_name varchar(100) default '',
+ tpl_category varchar(200) default 'crud',
+ tpl_web_type varchar(30) default '',
+ package_name varchar(100),
+ module_name varchar(30),
+ business_name varchar(30),
+ function_name varchar(50),
+ function_author varchar(50),
+ gen_type char(1) default '0',
+ gen_path varchar(200) default '/',
+ options varchar(1000),
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ remark varchar(500) default null,
+ primary key (table_id)
+);
+comment on column gen_table.table_id is '编号';
+comment on column gen_table.table_name is '表名称';
+comment on column gen_table.table_comment is '表描述';
+comment on column gen_table.sub_table_name is '关联子表的表名';
+comment on column gen_table.sub_table_fk_name is '子表关联的外键名';
+comment on column gen_table.class_name is '实体类名称';
+comment on column gen_table.tpl_category is '使用的模板(crud单表操作 tree树表操作)';
+comment on column gen_table.tpl_web_type is '前端模板类型(element-ui模版 element-plus模版)';
+comment on column gen_table.package_name is '生成包路径';
+comment on column gen_table.module_name is '生成模块名';
+comment on column gen_table.business_name is '生成业务名';
+comment on column gen_table.function_name is '生成功能名';
+comment on column gen_table.function_author is '生成功能作者';
+comment on column gen_table.gen_type is '生成代码方式(0zip压缩包 1自定义路径)';
+comment on column gen_table.gen_path is '生成路径(不填默认项目路径)';
+comment on column gen_table.options is '其它生成选项';
+comment on column gen_table.create_by is '创建者';
+comment on column gen_table.create_time is '创建时间';
+comment on column gen_table.update_by is '更新者';
+comment on column gen_table.update_time is '更新时间';
+comment on column gen_table.remark is '备注';
+comment on table gen_table is '代码生成业务表';
+
+-- ----------------------------
+-- 19、代码生成业务表字段
+-- ----------------------------
+drop table if exists gen_table_column;
+create table gen_table_column (
+ column_id bigserial not null,
+ table_id varchar(64),
+ column_name varchar(200),
+ column_comment varchar(500),
+ column_type varchar(100),
+ java_type varchar(500),
+ java_field varchar(200),
+ is_pk char(1),
+ is_increment char(1),
+ is_required char(1),
+ is_insert char(1),
+ is_edit char(1),
+ is_list char(1),
+ is_query char(1),
+ query_type varchar(200) default 'EQ',
+ html_type varchar(200),
+ dict_type varchar(200) default '',
+ sort int4,
+ create_by varchar(64) default '',
+ create_time timestamp(0),
+ update_by varchar(64) default '',
+ update_time timestamp(0),
+ primary key (column_id)
+);
+comment on column gen_table_column.column_id is '编号';
+comment on column gen_table_column.table_id is '归属表编号';
+comment on column gen_table_column.column_name is '列名称';
+comment on column gen_table_column.column_comment is '列描述';
+comment on column gen_table_column.column_type is '列类型';
+comment on column gen_table_column.java_type is 'JAVA类型';
+comment on column gen_table_column.java_field is 'JAVA字段名';
+comment on column gen_table_column.is_pk is '是否主键(1是)';
+comment on column gen_table_column.is_increment is '是否自增(1是)';
+comment on column gen_table_column.is_required is '是否必填(1是)';
+comment on column gen_table_column.is_insert is '是否为插入字段(1是)';
+comment on column gen_table_column.is_edit is '是否编辑字段(1是)';
+comment on column gen_table_column.is_list is '是否列表字段(1是)';
+comment on column gen_table_column.is_query is '是否查询字段(1是)';
+comment on column gen_table_column.query_type is '查询方式(等于、不等于、大于、小于、范围)';
+comment on column gen_table_column.html_type is '显示类型(文本框、文本域、下拉框、复选框、单选框、日期控件)';
+comment on column gen_table_column.dict_type is '字典类型';
+comment on column gen_table_column.sort is '排序';
+comment on column gen_table_column.create_by is '创建者';
+comment on column gen_table_column.create_time is '创建时间';
+comment on column gen_table_column.update_by is '更新者';
+comment on column gen_table_column.update_time is '更新时间';
+comment on table gen_table_column is '代码生成业务表字段';
+
+CREATE OR REPLACE FUNCTION "find_in_set"(int8, varchar)
+ RETURNS "pg_catalog"."bool" AS $BODY$
+DECLARE
+ STR ALIAS FOR $1;
+ STRS ALIAS FOR $2;
+ POS INTEGER;
+ STATUS BOOLEAN;
+BEGIN
+ SELECT POSITION( ','||STR||',' IN ','||STRS||',') INTO POS;
+ IF POS > 0 THEN
+ STATUS = TRUE;
+ ELSE
+ STATUS = FALSE;
+ END IF;
+ RETURN STATUS;
+END;
+$BODY$
+ LANGUAGE plpgsql VOLATILE
+ COST 100;
diff --git a/dash-fastapi-frontend/.env.dev b/dash-fastapi-frontend/.env.dev
index 876a5a5dcacbe5225b9248eb88850a64f3b64e26..1c39a5161f51d4f62b247e381fe3ae453223e726 100644
--- a/dash-fastapi-frontend/.env.dev
+++ b/dash-fastapi-frontend/.env.dev
@@ -16,7 +16,7 @@ APP_HOST = '0.0.0.0'
# 应用端口
APP_PORT = 8088
# 应用版本
-APP_VERSION= '2.0.1'
+APP_VERSION= '2.1.0'
# 应用是否开启debug模式
APP_DEBUG = true
# flask-compress压缩配置
diff --git a/dash-fastapi-frontend/.env.prod b/dash-fastapi-frontend/.env.prod
index 4cbc4fa1dfb6f50693e84b9da3d4eb0fe77af112..8d9b01e633b943a75bd7bd340cdef68e8edf0f5a 100644
--- a/dash-fastapi-frontend/.env.prod
+++ b/dash-fastapi-frontend/.env.prod
@@ -16,7 +16,7 @@ APP_HOST = '0.0.0.0'
# 应用端口
APP_PORT = 8088
# 应用版本
-APP_VERSION= '2.0.1'
+APP_VERSION= '2.1.0'
# 应用是否开启debug模式
APP_DEBUG = false
# flask-compress压缩配置
diff --git a/requirements-pg.txt b/requirements-pg.txt
new file mode 100644
index 0000000000000000000000000000000000000000..24b2c643e5b48f7970db9423deb4c487a34a344e
--- /dev/null
+++ b/requirements-pg.txt
@@ -0,0 +1,26 @@
+APScheduler==3.10.4
+asyncpg==0.30.0
+cachebox==4.1.2
+dash==2.18.1
+DateTime==5.5
+fastapi[all]==0.115.0
+feffery-antd-charts==0.1.0rc5
+feffery-antd-components==0.3.8
+feffery-markdown-components==0.2.10
+feffery-utils-components==0.2.0rc24
+Flask-Compress==1.15
+jsonpath-ng==1.5.3
+loguru==0.7.2
+openpyxl==3.1.5
+pandas==2.2.2
+passlib[bcrypt]==1.7.4
+Pillow==10.4.0
+psutil==6.0.0
+pydantic-validation-decorator==0.1.2
+PyJWT[crypto]==2.8.0
+psycopg2==2.9.10
+redis==5.0.7
+requests==2.32.3
+SQLAlchemy[asyncio]==2.0.31
+user-agents==2.2.0
+waitress==3.0.0