main_table.sql 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492
  1. -- liquibase formatted sql
  2. -- changeset Charles7c:1
  3. -- comment 初始化表结构
  4. CREATE TABLE IF NOT EXISTS "sys_menu" (
  5. "id" int8 NOT NULL,
  6. "title" varchar(30) NOT NULL,
  7. "parent_id" int8 NOT NULL DEFAULT 0,
  8. "type" int2 NOT NULL DEFAULT 1,
  9. "path" varchar(255) DEFAULT NULL,
  10. "name" varchar(50) DEFAULT NULL,
  11. "component" varchar(255) DEFAULT NULL,
  12. "redirect" varchar(255) DEFAULT NULL,
  13. "icon" varchar(50) DEFAULT NULL,
  14. "is_external" bool DEFAULT false,
  15. "is_cache" bool DEFAULT false,
  16. "is_hidden" bool DEFAULT false,
  17. "permission" varchar(100) DEFAULT NULL,
  18. "sort" int4 NOT NULL DEFAULT 999,
  19. "status" int2 NOT NULL DEFAULT 1,
  20. "create_user" int8 NOT NULL,
  21. "create_time" timestamp NOT NULL,
  22. "update_user" int8 DEFAULT NULL,
  23. "update_time" timestamp DEFAULT NULL,
  24. PRIMARY KEY ("id")
  25. );
  26. CREATE INDEX "idx_menu_parent_id" ON "sys_menu" ("parent_id");
  27. CREATE INDEX "idx_menu_create_user" ON "sys_menu" ("create_user");
  28. CREATE INDEX "idx_menu_update_user" ON "sys_menu" ("update_user");
  29. CREATE UNIQUE INDEX "uk_menu_title_parent_id" ON "sys_menu" ("title", "parent_id");
  30. COMMENT ON COLUMN "sys_menu"."id" IS 'ID';
  31. COMMENT ON COLUMN "sys_menu"."title" IS '标题';
  32. COMMENT ON COLUMN "sys_menu"."parent_id" IS '上级菜单ID';
  33. COMMENT ON COLUMN "sys_menu"."type" IS '类型(1:目录;2:菜单;3:按钮)';
  34. COMMENT ON COLUMN "sys_menu"."path" IS '路由地址';
  35. COMMENT ON COLUMN "sys_menu"."name" IS '组件名称';
  36. COMMENT ON COLUMN "sys_menu"."component" IS '组件路径';
  37. COMMENT ON COLUMN "sys_menu"."redirect" IS '重定向地址';
  38. COMMENT ON COLUMN "sys_menu"."icon" IS '图标';
  39. COMMENT ON COLUMN "sys_menu"."is_external" IS '是否外链';
  40. COMMENT ON COLUMN "sys_menu"."is_cache" IS '是否缓存';
  41. COMMENT ON COLUMN "sys_menu"."is_hidden" IS '是否隐藏';
  42. COMMENT ON COLUMN "sys_menu"."permission" IS '权限标识';
  43. COMMENT ON COLUMN "sys_menu"."sort" IS '排序';
  44. COMMENT ON COLUMN "sys_menu"."status" IS '状态(1:启用;2:禁用)';
  45. COMMENT ON COLUMN "sys_menu"."create_user" IS '创建人';
  46. COMMENT ON COLUMN "sys_menu"."create_time" IS '创建时间';
  47. COMMENT ON COLUMN "sys_menu"."update_user" IS '修改人';
  48. COMMENT ON COLUMN "sys_menu"."update_time" IS '修改时间';
  49. COMMENT ON TABLE "sys_menu" IS '菜单表';
  50. CREATE TABLE IF NOT EXISTS "sys_dept" (
  51. "id" int8 NOT NULL,
  52. "name" varchar(30) NOT NULL,
  53. "parent_id" int8 NOT NULL DEFAULT 0,
  54. "ancestors" varchar(512) NOT NULL DEFAULT '',
  55. "description" varchar(200) DEFAULT NULL,
  56. "sort" int4 NOT NULL DEFAULT 999,
  57. "status" int2 NOT NULL DEFAULT 1,
  58. "is_system" bool NOT NULL DEFAULT false,
  59. "create_user" int8 NOT NULL,
  60. "create_time" timestamp NOT NULL,
  61. "update_user" int8 DEFAULT NULL,
  62. "update_time" timestamp DEFAULT NULL,
  63. PRIMARY KEY ("id")
  64. );
  65. CREATE INDEX "idx_dept_parent_id" ON "sys_dept" ("parent_id");
  66. CREATE INDEX "idx_dept_create_user" ON "sys_dept" ("create_user");
  67. CREATE INDEX "idx_dept_update_user" ON "sys_dept" ("update_user");
  68. CREATE UNIQUE INDEX "uk_dept_name_parent_id" ON "sys_dept" ("name", "parent_id");
  69. COMMENT ON COLUMN "sys_dept"."id" IS 'ID';
  70. COMMENT ON COLUMN "sys_dept"."name" IS '名称';
  71. COMMENT ON COLUMN "sys_dept"."parent_id" IS '上级部门ID';
  72. COMMENT ON COLUMN "sys_dept"."ancestors" IS '祖级列表';
  73. COMMENT ON COLUMN "sys_dept"."description" IS '描述';
  74. COMMENT ON COLUMN "sys_dept"."sort" IS '排序';
  75. COMMENT ON COLUMN "sys_dept"."status" IS '状态(1:启用;2:禁用)';
  76. COMMENT ON COLUMN "sys_dept"."is_system" IS '是否为系统内置数据';
  77. COMMENT ON COLUMN "sys_dept"."create_user" IS '创建人';
  78. COMMENT ON COLUMN "sys_dept"."create_time" IS '创建时间';
  79. COMMENT ON COLUMN "sys_dept"."update_user" IS '修改人';
  80. COMMENT ON COLUMN "sys_dept"."update_time" IS '修改时间';
  81. COMMENT ON TABLE "sys_dept" IS '部门表';
  82. CREATE TABLE IF NOT EXISTS "sys_role" (
  83. "id" int8 NOT NULL,
  84. "name" varchar(30) NOT NULL,
  85. "code" varchar(30) NOT NULL,
  86. "data_scope" int2 NOT NULL DEFAULT 4,
  87. "description" varchar(200) DEFAULT NULL,
  88. "sort" int4 NOT NULL DEFAULT 999,
  89. "is_system" bool NOT NULL DEFAULT false,
  90. "menu_check_strictly" bool DEFAULT false,
  91. "dept_check_strictly" bool DEFAULT false,
  92. "create_user" int8 NOT NULL,
  93. "create_time" timestamp NOT NULL,
  94. "update_user" int8 DEFAULT NULL,
  95. "update_time" timestamp DEFAULT NULL,
  96. PRIMARY KEY ("id")
  97. );
  98. CREATE UNIQUE INDEX "uk_role_name" ON "sys_role" ("name");
  99. CREATE UNIQUE INDEX "uk_role_code" ON "sys_role" ("code");
  100. CREATE INDEX "idx_role_create_user" ON "sys_role" ("create_user");
  101. CREATE INDEX "idx_role_update_user" ON "sys_role" ("update_user");
  102. COMMENT ON COLUMN "sys_role"."id" IS 'ID';
  103. COMMENT ON COLUMN "sys_role"."name" IS '名称';
  104. COMMENT ON COLUMN "sys_role"."code" IS '编码';
  105. COMMENT ON COLUMN "sys_role"."data_scope" IS '数据权限(1:全部数据权限;2:本部门及以下数据权限;3:本部门数据权限;4:仅本人数据权限;5:自定义数据权限)';
  106. COMMENT ON COLUMN "sys_role"."description" IS '描述';
  107. COMMENT ON COLUMN "sys_role"."sort" IS '排序';
  108. COMMENT ON COLUMN "sys_role"."is_system" IS '是否为系统内置数据';
  109. COMMENT ON COLUMN "sys_role"."menu_check_strictly" IS '菜单选择是否父子节点关联';
  110. COMMENT ON COLUMN "sys_role"."dept_check_strictly" IS '部门选择是否父子节点关联';
  111. COMMENT ON COLUMN "sys_role"."create_user" IS '创建人';
  112. COMMENT ON COLUMN "sys_role"."create_time" IS '创建时间';
  113. COMMENT ON COLUMN "sys_role"."update_user" IS '修改人';
  114. COMMENT ON COLUMN "sys_role"."update_time" IS '修改时间';
  115. COMMENT ON TABLE "sys_role" IS '角色表';
  116. CREATE TABLE IF NOT EXISTS "sys_user" (
  117. "id" int8 NOT NULL,
  118. "username" varchar(64) NOT NULL,
  119. "nickname" varchar(30) NOT NULL,
  120. "password" varchar(255) DEFAULT NULL,
  121. "gender" int2 NOT NULL DEFAULT 0,
  122. "email" varchar(255) DEFAULT NULL,
  123. "phone" varchar(255) DEFAULT NULL,
  124. "avatar" text DEFAULT NULL,
  125. "description" varchar(200) DEFAULT NULL,
  126. "status" int2 NOT NULL DEFAULT 1,
  127. "is_system" bool NOT NULL DEFAULT false,
  128. "pwd_reset_time" timestamp DEFAULT NULL,
  129. "dept_id" int8 NOT NULL,
  130. "create_user" int8 DEFAULT NULL,
  131. "create_time" timestamp NOT NULL,
  132. "update_user" int8 DEFAULT NULL,
  133. "update_time" timestamp DEFAULT NULL,
  134. PRIMARY KEY ("id")
  135. );
  136. CREATE UNIQUE INDEX "uk_user_username" ON "sys_user" ("username");
  137. CREATE UNIQUE INDEX "uk_user_email" ON "sys_user" ("email");
  138. CREATE UNIQUE INDEX "uk_user_phone" ON "sys_user" ("phone");
  139. CREATE INDEX "idx_user_dept_id" ON "sys_user" ("dept_id");
  140. CREATE INDEX "idx_user_create_user" ON "sys_user" ("create_user");
  141. CREATE INDEX "idx_user_update_user" ON "sys_user" ("update_user");
  142. COMMENT ON COLUMN "sys_user"."id" IS 'ID';
  143. COMMENT ON COLUMN "sys_user"."username" IS '用户名';
  144. COMMENT ON COLUMN "sys_user"."nickname" IS '昵称';
  145. COMMENT ON COLUMN "sys_user"."password" IS '密码';
  146. COMMENT ON COLUMN "sys_user"."gender" IS '性别(0:未知;1:男;2:女)';
  147. COMMENT ON COLUMN "sys_user"."email" IS '邮箱';
  148. COMMENT ON COLUMN "sys_user"."phone" IS '手机号码';
  149. COMMENT ON COLUMN "sys_user"."avatar" IS '头像';
  150. COMMENT ON COLUMN "sys_user"."description" IS '描述';
  151. COMMENT ON COLUMN "sys_user"."status" IS '状态(1:启用;2:禁用)';
  152. COMMENT ON COLUMN "sys_user"."is_system" IS '是否为系统内置数据';
  153. COMMENT ON COLUMN "sys_user"."pwd_reset_time" IS '最后一次修改密码时间';
  154. COMMENT ON COLUMN "sys_user"."dept_id" IS '部门ID';
  155. COMMENT ON COLUMN "sys_user"."create_user" IS '创建人';
  156. COMMENT ON COLUMN "sys_user"."create_time" IS '创建时间';
  157. COMMENT ON COLUMN "sys_user"."update_user" IS '修改人';
  158. COMMENT ON COLUMN "sys_user"."update_time" IS '修改时间';
  159. COMMENT ON TABLE "sys_user" IS '用户表';
  160. CREATE TABLE IF NOT EXISTS "sys_user_password_history" (
  161. "id" int8 NOT NULL,
  162. "user_id" int8 NOT NULL,
  163. "password" varchar(255) NOT NULL,
  164. "create_time" timestamp NOT NULL,
  165. PRIMARY KEY ("id")
  166. );
  167. CREATE INDEX "idx_uph_user_id" ON "sys_user_password_history" ("user_id");
  168. COMMENT ON COLUMN "sys_user_password_history"."id" IS 'ID';
  169. COMMENT ON COLUMN "sys_user_password_history"."user_id" IS '用户ID';
  170. COMMENT ON COLUMN "sys_user_password_history"."password" IS '密码';
  171. COMMENT ON COLUMN "sys_user_password_history"."create_time" IS '创建时间';
  172. COMMENT ON TABLE "sys_user_password_history" IS '用户历史密码表';
  173. CREATE TABLE IF NOT EXISTS "sys_user_social" (
  174. "id" int8 NOT NULL,
  175. "source" varchar(255) NOT NULL,
  176. "open_id" varchar(255) NOT NULL,
  177. "user_id" int8 NOT NULL,
  178. "meta_json" text DEFAULT NULL,
  179. "last_login_time" timestamp DEFAULT NULL,
  180. "create_time" timestamp NOT NULL,
  181. PRIMARY KEY ("id")
  182. );
  183. CREATE UNIQUE INDEX "uk_user_source_open_id" ON "sys_user_social" ("source", "open_id");
  184. COMMENT ON COLUMN "sys_user_social"."id" IS 'ID';
  185. COMMENT ON COLUMN "sys_user_social"."source" IS '来源';
  186. COMMENT ON COLUMN "sys_user_social"."open_id" IS '开放ID';
  187. COMMENT ON COLUMN "sys_user_social"."user_id" IS '用户ID';
  188. COMMENT ON COLUMN "sys_user_social"."meta_json" IS '附加信息';
  189. COMMENT ON COLUMN "sys_user_social"."last_login_time" IS '最后登录时间';
  190. COMMENT ON COLUMN "sys_user_social"."create_time" IS '创建时间';
  191. COMMENT ON TABLE "sys_user_social" IS '用户社会化关联表';
  192. CREATE TABLE IF NOT EXISTS "sys_user_role" (
  193. "user_id" int8 NOT NULL,
  194. "role_id" int8 NOT NULL,
  195. PRIMARY KEY ("user_id", "role_id")
  196. );
  197. COMMENT ON COLUMN "sys_user_role"."user_id" IS '用户ID';
  198. COMMENT ON COLUMN "sys_user_role"."role_id" IS '角色ID';
  199. COMMENT ON TABLE "sys_user_role" IS '用户和角色关联表';
  200. CREATE TABLE IF NOT EXISTS "sys_role_menu" (
  201. "role_id" int8 NOT NULL,
  202. "menu_id" int8 NOT NULL,
  203. PRIMARY KEY ("role_id", "menu_id")
  204. );
  205. COMMENT ON COLUMN "sys_role_menu"."role_id" IS '角色ID';
  206. COMMENT ON COLUMN "sys_role_menu"."menu_id" IS '菜单ID';
  207. COMMENT ON TABLE "sys_role_menu" IS '角色和菜单关联表';
  208. CREATE TABLE IF NOT EXISTS "sys_role_dept" (
  209. "role_id" int8 NOT NULL,
  210. "dept_id" int8 NOT NULL,
  211. PRIMARY KEY ("role_id", "dept_id")
  212. );
  213. COMMENT ON COLUMN "sys_role_dept"."role_id" IS '角色ID';
  214. COMMENT ON COLUMN "sys_role_dept"."dept_id" IS '部门ID';
  215. COMMENT ON TABLE "sys_role_dept" IS '角色和部门关联表';
  216. CREATE TABLE IF NOT EXISTS "sys_option" (
  217. "id" int8 NOT NULL,
  218. "category" varchar(50) NOT NULL,
  219. "name" varchar(50) NOT NULL,
  220. "code" varchar(100) NOT NULL,
  221. "value" text DEFAULT NULL,
  222. "default_value" text DEFAULT NULL,
  223. "description" varchar(200) DEFAULT NULL,
  224. "update_user" int8 DEFAULT NULL,
  225. "update_time" timestamp DEFAULT NULL,
  226. PRIMARY KEY ("id")
  227. );
  228. CREATE UNIQUE INDEX "uk_option_category_code" ON "sys_option" ("category", "code");
  229. COMMENT ON COLUMN "sys_option"."id" IS 'ID';
  230. COMMENT ON COLUMN "sys_option"."category" IS '类别';
  231. COMMENT ON COLUMN "sys_option"."name" IS '名称';
  232. COMMENT ON COLUMN "sys_option"."code" IS '键';
  233. COMMENT ON COLUMN "sys_option"."value" IS '值';
  234. COMMENT ON COLUMN "sys_option"."default_value" IS '默认值';
  235. COMMENT ON COLUMN "sys_option"."description" IS '描述';
  236. COMMENT ON COLUMN "sys_option"."update_user" IS '修改人';
  237. COMMENT ON COLUMN "sys_option"."update_time" IS '修改时间';
  238. COMMENT ON TABLE "sys_option" IS '参数表';
  239. CREATE TABLE IF NOT EXISTS "sys_dict" (
  240. "id" int8 NOT NULL,
  241. "name" varchar(30) NOT NULL,
  242. "code" varchar(30) NOT NULL,
  243. "description" varchar(200) DEFAULT NULL,
  244. "is_system" bool NOT NULL DEFAULT false,
  245. "create_user" int8 NOT NULL,
  246. "create_time" timestamp NOT NULL,
  247. "update_user" int8 DEFAULT NULL,
  248. "update_time" timestamp DEFAULT NULL,
  249. PRIMARY KEY ("id")
  250. );
  251. CREATE UNIQUE INDEX "uk_dict_name" ON "sys_dict" ("name");
  252. CREATE UNIQUE INDEX "uk_dict_code" ON "sys_dict" ("code");
  253. COMMENT ON COLUMN "sys_dict"."id" IS 'ID';
  254. COMMENT ON COLUMN "sys_dict"."name" IS '名称';
  255. COMMENT ON COLUMN "sys_dict"."code" IS '编码';
  256. COMMENT ON COLUMN "sys_dict"."description" IS '描述';
  257. COMMENT ON COLUMN "sys_dict"."is_system" IS '是否为系统内置数据';
  258. COMMENT ON COLUMN "sys_dict"."create_user" IS '创建人';
  259. COMMENT ON COLUMN "sys_dict"."create_time" IS '创建时间';
  260. COMMENT ON COLUMN "sys_dict"."update_user" IS '修改人';
  261. COMMENT ON COLUMN "sys_dict"."update_time" IS '修改时间';
  262. COMMENT ON TABLE "sys_dict" IS '字典表';
  263. CREATE TABLE IF NOT EXISTS "sys_dict_item" (
  264. "id" int8 NOT NULL,
  265. "label" varchar(30) NOT NULL,
  266. "value" varchar(30) NOT NULL,
  267. "color" varchar(30) DEFAULT NULL,
  268. "sort" int4 NOT NULL DEFAULT 999,
  269. "description" varchar(200) DEFAULT NULL,
  270. "status" int2 NOT NULL DEFAULT 1,
  271. "dict_id" int8 NOT NULL,
  272. "create_user" int8 NOT NULL,
  273. "create_time" timestamp NOT NULL,
  274. "update_user" int8 DEFAULT NULL,
  275. "update_time" timestamp DEFAULT NULL,
  276. PRIMARY KEY ("id")
  277. );
  278. CREATE UNIQUE INDEX "uk_dict_item_value_dict_id" ON "sys_dict_item" ("value", "dict_id");
  279. CREATE INDEX "idx_dict_item_dict_id" ON "sys_dict_item" ("dict_id");
  280. CREATE INDEX "idx_dict_item_create_user" ON "sys_dict_item" ("create_user");
  281. CREATE INDEX "idx_dict_item_update_user" ON "sys_dict_item" ("update_user");
  282. COMMENT ON COLUMN "sys_dict_item"."id" IS 'ID';
  283. COMMENT ON COLUMN "sys_dict_item"."label" IS '标签';
  284. COMMENT ON COLUMN "sys_dict_item"."value" IS '值';
  285. COMMENT ON COLUMN "sys_dict_item"."color" IS '标签颜色';
  286. COMMENT ON COLUMN "sys_dict_item"."sort" IS '排序';
  287. COMMENT ON COLUMN "sys_dict_item"."description" IS '描述';
  288. COMMENT ON COLUMN "sys_dict_item"."status" IS '状态(1:启用;2:禁用)';
  289. COMMENT ON COLUMN "sys_dict_item"."dict_id" IS '字典ID';
  290. COMMENT ON COLUMN "sys_dict_item"."create_user" IS '创建人';
  291. COMMENT ON COLUMN "sys_dict_item"."create_time" IS '创建时间';
  292. COMMENT ON COLUMN "sys_dict_item"."update_user" IS '修改人';
  293. COMMENT ON COLUMN "sys_dict_item"."update_time" IS '修改时间';
  294. COMMENT ON TABLE "sys_dict_item" IS '字典项表';
  295. CREATE TABLE IF NOT EXISTS "sys_log" (
  296. "id" int8 NOT NULL,
  297. "trace_id" varchar(255) DEFAULT NULL,
  298. "description" varchar(255) NOT NULL,
  299. "module" varchar(50) NOT NULL,
  300. "request_url" varchar(512) NOT NULL,
  301. "request_method" varchar(10) NOT NULL,
  302. "request_headers" text DEFAULT NULL,
  303. "request_body" text DEFAULT NULL,
  304. "status_code" int4 NOT NULL,
  305. "response_headers" text DEFAULT NULL,
  306. "response_body" text DEFAULT NULL,
  307. "time_taken" int8 NOT NULL,
  308. "ip" varchar(100) DEFAULT NULL,
  309. "address" varchar(255) DEFAULT NULL,
  310. "browser" varchar(100) DEFAULT NULL,
  311. "os" varchar(100) DEFAULT NULL,
  312. "status" int2 NOT NULL DEFAULT 1,
  313. "error_msg" text DEFAULT NULL,
  314. "create_user" int8 DEFAULT NULL,
  315. "create_time" timestamp NOT NULL,
  316. PRIMARY KEY ("id")
  317. );
  318. CREATE INDEX "idx_log_module" ON "sys_log" ("module");
  319. CREATE INDEX "idx_log_ip" ON "sys_log" ("ip");
  320. CREATE INDEX "idx_log_address" ON "sys_log" ("address");
  321. CREATE INDEX "idx_log_create_time" ON "sys_log" ("create_time");
  322. COMMENT ON COLUMN "sys_log"."id" IS 'ID';
  323. COMMENT ON COLUMN "sys_log"."trace_id" IS '链路ID';
  324. COMMENT ON COLUMN "sys_log"."description" IS '日志描述';
  325. COMMENT ON COLUMN "sys_log"."module" IS '所属模块';
  326. COMMENT ON COLUMN "sys_log"."request_url" IS '请求URL';
  327. COMMENT ON COLUMN "sys_log"."request_method" IS '请求方式';
  328. COMMENT ON COLUMN "sys_log"."request_headers" IS '请求头';
  329. COMMENT ON COLUMN "sys_log"."request_body" IS '请求体';
  330. COMMENT ON COLUMN "sys_log"."status_code" IS '状态码';
  331. COMMENT ON COLUMN "sys_log"."response_headers" IS '响应头';
  332. COMMENT ON COLUMN "sys_log"."response_body" IS '响应体';
  333. COMMENT ON COLUMN "sys_log"."time_taken" IS '耗时(ms)';
  334. COMMENT ON COLUMN "sys_log"."ip" IS 'IP';
  335. COMMENT ON COLUMN "sys_log"."address" IS 'IP归属地';
  336. COMMENT ON COLUMN "sys_log"."browser" IS '浏览器';
  337. COMMENT ON COLUMN "sys_log"."os" IS '操作系统';
  338. COMMENT ON COLUMN "sys_log"."status" IS '状态(1:成功;2:失败)';
  339. COMMENT ON COLUMN "sys_log"."error_msg" IS '错误信息';
  340. COMMENT ON COLUMN "sys_log"."create_user" IS '创建人';
  341. COMMENT ON COLUMN "sys_log"."create_time" IS '创建时间';
  342. COMMENT ON TABLE "sys_log" IS '系统日志表';
  343. CREATE TABLE IF NOT EXISTS "sys_message" (
  344. "id" int8 NOT NULL,
  345. "title" varchar(50) NOT NULL,
  346. "content" varchar(255) DEFAULT NULL,
  347. "type" int2 NOT NULL DEFAULT 1,
  348. "create_user" int8 DEFAULT NULL,
  349. "create_time" timestamp NOT NULL,
  350. PRIMARY KEY ("id")
  351. );
  352. COMMENT ON COLUMN "sys_message"."id" IS 'ID';
  353. COMMENT ON COLUMN "sys_message"."title" IS '标题';
  354. COMMENT ON COLUMN "sys_message"."content" IS '内容';
  355. COMMENT ON COLUMN "sys_message"."type" IS '类型(1:系统消息)';
  356. COMMENT ON COLUMN "sys_message"."create_user" IS '创建人';
  357. COMMENT ON COLUMN "sys_message"."create_time" IS '创建时间';
  358. COMMENT ON TABLE "sys_message" IS '消息表';
  359. CREATE TABLE IF NOT EXISTS "sys_message_user" (
  360. "message_id" int8 NOT NULL,
  361. "user_id" int8 NOT NULL,
  362. "is_read" bool NOT NULL DEFAULT false,
  363. "read_time" timestamp DEFAULT NULL,
  364. PRIMARY KEY ("message_id", "user_id")
  365. );
  366. COMMENT ON COLUMN "sys_message_user"."message_id" IS '消息ID';
  367. COMMENT ON COLUMN "sys_message_user"."user_id" IS '用户ID';
  368. COMMENT ON COLUMN "sys_message_user"."is_read" IS '是否已读';
  369. COMMENT ON COLUMN "sys_message_user"."read_time" IS '读取时间';
  370. COMMENT ON TABLE "sys_message_user" IS '消息和用户关联表';
  371. CREATE TABLE IF NOT EXISTS "sys_notice" (
  372. "id" int8 NOT NULL,
  373. "title" varchar(150) NOT NULL,
  374. "content" text NOT NULL,
  375. "type" varchar(30) NOT NULL,
  376. "effective_time" timestamp DEFAULT NULL,
  377. "terminate_time" timestamp DEFAULT NULL,
  378. "sort" int4 NOT NULL DEFAULT 999,
  379. "create_user" int8 NOT NULL,
  380. "create_time" timestamp NOT NULL,
  381. "update_user" int8 DEFAULT NULL,
  382. "update_time" timestamp DEFAULT NULL,
  383. PRIMARY KEY ("id")
  384. );
  385. CREATE INDEX "idx_notice_create_user" ON "sys_notice" ("create_user");
  386. CREATE INDEX "idx_notice_update_user" ON "sys_notice" ("update_user");
  387. COMMENT ON COLUMN "sys_notice"."id" IS 'ID';
  388. COMMENT ON COLUMN "sys_notice"."title" IS '标题';
  389. COMMENT ON COLUMN "sys_notice"."content" IS '内容';
  390. COMMENT ON COLUMN "sys_notice"."type" IS '类型';
  391. COMMENT ON COLUMN "sys_notice"."effective_time" IS '生效时间';
  392. COMMENT ON COLUMN "sys_notice"."terminate_time" IS '终止时间';
  393. COMMENT ON COLUMN "sys_notice"."sort" IS '排序';
  394. COMMENT ON COLUMN "sys_notice"."create_user" IS '创建人';
  395. COMMENT ON COLUMN "sys_notice"."create_time" IS '创建时间';
  396. COMMENT ON COLUMN "sys_notice"."update_user" IS '修改人';
  397. COMMENT ON COLUMN "sys_notice"."update_time" IS '修改时间';
  398. COMMENT ON TABLE "sys_notice" IS '公告表';
  399. CREATE TABLE IF NOT EXISTS "sys_storage" (
  400. "id" int8 NOT NULL,
  401. "name" varchar(100) NOT NULL,
  402. "code" varchar(30) NOT NULL,
  403. "type" int2 NOT NULL DEFAULT 1,
  404. "access_key" varchar(255) DEFAULT NULL,
  405. "secret_key" varchar(255) DEFAULT NULL,
  406. "endpoint" varchar(255) DEFAULT NULL,
  407. "bucket_name" varchar(255) DEFAULT NULL,
  408. "domain" varchar(255) NOT NULL DEFAULT '',
  409. "description" varchar(200) DEFAULT NULL,
  410. "is_default" bool NOT NULL DEFAULT false,
  411. "sort" int4 NOT NULL DEFAULT 999,
  412. "status" int2 NOT NULL DEFAULT 1,
  413. "create_user" int8 NOT NULL,
  414. "create_time" timestamp NOT NULL,
  415. "update_user" int8 DEFAULT NULL,
  416. "update_time" timestamp DEFAULT NULL,
  417. PRIMARY KEY ("id")
  418. );
  419. CREATE UNIQUE INDEX "uk_storage_code" ON "sys_storage" ("code");
  420. CREATE INDEX "idx_storage_create_user" ON "sys_storage" ("create_user");
  421. CREATE INDEX "idx_storage_update_user" ON "sys_storage" ("update_user");
  422. COMMENT ON COLUMN "sys_storage"."id" IS 'ID';
  423. COMMENT ON COLUMN "sys_storage"."name" IS '名称';
  424. COMMENT ON COLUMN "sys_storage"."code" IS '编码';
  425. COMMENT ON COLUMN "sys_storage"."type" IS '类型(1:兼容S3协议存储;2:本地存储)';
  426. COMMENT ON COLUMN "sys_storage"."access_key" IS 'Access Key(访问密钥)';
  427. COMMENT ON COLUMN "sys_storage"."secret_key" IS 'Secret Key(私有密钥)';
  428. COMMENT ON COLUMN "sys_storage"."endpoint" IS 'Endpoint(终端节点)';
  429. COMMENT ON COLUMN "sys_storage"."bucket_name" IS '桶名称';
  430. COMMENT ON COLUMN "sys_storage"."domain" IS '域名';
  431. COMMENT ON COLUMN "sys_storage"."description" IS '描述';
  432. COMMENT ON COLUMN "sys_storage"."is_default" IS '是否为默认存储';
  433. COMMENT ON COLUMN "sys_storage"."sort" IS '排序';
  434. COMMENT ON COLUMN "sys_storage"."status" IS '状态(1:启用;2:禁用)';
  435. COMMENT ON COLUMN "sys_storage"."create_user" IS '创建人';
  436. COMMENT ON COLUMN "sys_storage"."create_time" IS '创建时间';
  437. COMMENT ON COLUMN "sys_storage"."update_user" IS '修改人';
  438. COMMENT ON COLUMN "sys_storage"."update_time" IS '修改时间';
  439. COMMENT ON TABLE "sys_storage" IS '存储表';
  440. CREATE TABLE IF NOT EXISTS "sys_file" (
  441. "id" int8 NOT NULL,
  442. "name" varchar(255) NOT NULL,
  443. "size" int8 NOT NULL,
  444. "url" varchar(512) NOT NULL,
  445. "extension" varchar(100) DEFAULT NULL,
  446. "thumbnail_size" int8 DEFAULT NULL,
  447. "thumbnail_url" varchar(512) DEFAULT NULL,
  448. "type" int2 NOT NULL DEFAULT 1,
  449. "storage_id" int8 NOT NULL,
  450. "create_user" int8 NOT NULL,
  451. "create_time" timestamp NOT NULL,
  452. "update_user" int8 NOT NULL,
  453. "update_time" timestamp NOT NULL,
  454. PRIMARY KEY ("id")
  455. );
  456. CREATE INDEX "idx_file_url" ON "sys_file" ("url");
  457. CREATE INDEX "idx_file_type" ON "sys_file" ("type");
  458. CREATE INDEX "idx_file_create_user" ON "sys_file" ("create_user");
  459. CREATE INDEX "idx_file_update_user" ON "sys_file" ("update_user");
  460. COMMENT ON COLUMN "sys_file"."id" IS 'ID';
  461. COMMENT ON COLUMN "sys_file"."name" IS '名称';
  462. COMMENT ON COLUMN "sys_file"."size" IS '大小(字节)';
  463. COMMENT ON COLUMN "sys_file"."url" IS 'URL';
  464. COMMENT ON COLUMN "sys_file"."extension" IS '扩展名';
  465. COMMENT ON COLUMN "sys_file"."thumbnail_size" IS '缩略图大小(字节)';
  466. COMMENT ON COLUMN "sys_file"."thumbnail_url" IS '缩略图URL';
  467. COMMENT ON COLUMN "sys_file"."type" IS '类型(1:其他;2:图片;3:文档;4:视频;5:音频)';
  468. COMMENT ON COLUMN "sys_file"."storage_id" IS '存储ID';
  469. COMMENT ON COLUMN "sys_file"."create_user" IS '创建人';
  470. COMMENT ON COLUMN "sys_file"."create_time" IS '创建时间';
  471. COMMENT ON COLUMN "sys_file"."update_user" IS '修改人';
  472. COMMENT ON COLUMN "sys_file"."update_time" IS '修改时间';
  473. COMMENT ON TABLE "sys_file" IS '文件表';