20250220162340_a1.cs 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687
  1. using System;
  2. using Microsoft.EntityFrameworkCore.Migrations;
  3. #nullable disable
  4. namespace bitforum.Migrations.DefaultDb
  5. {
  6. /// <inheritdoc />
  7. public partial class a1 : Migration
  8. {
  9. /// <inheritdoc />
  10. protected override void Up(MigrationBuilder migrationBuilder)
  11. {
  12. migrationBuilder.CreateTable(
  13. name: "BannerPosition",
  14. columns: table => new
  15. {
  16. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  17. .Annotation("SqlServer:Identity", "1, 1"),
  18. Code = table.Column<string>(type: "nvarchar(30)", maxLength: 30, nullable: false, comment: "위치 구분"),
  19. Subject = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: false, comment: "위치 명"),
  20. IsActive = table.Column<bool>(type: "bit", nullable: false, comment: "사용 여부"),
  21. UpdatedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "수정 일시"),
  22. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  23. },
  24. constraints: table =>
  25. {
  26. table.PrimaryKey("PK_BannerPosition", x => x.ID);
  27. });
  28. migrationBuilder.CreateTable(
  29. name: "Config",
  30. columns: table => new
  31. {
  32. ID = table.Column<int>(type: "int", nullable: false)
  33. .Annotation("SqlServer:Identity", "1, 1"),
  34. Key = table.Column<string>(type: "nvarchar(450)", nullable: false),
  35. Value = table.Column<string>(type: "nvarchar(max)", nullable: true),
  36. Description = table.Column<string>(type: "nvarchar(max)", nullable: true),
  37. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false)
  38. },
  39. constraints: table =>
  40. {
  41. table.PrimaryKey("PK_Config", x => x.ID);
  42. });
  43. migrationBuilder.CreateTable(
  44. name: "Document",
  45. columns: table => new
  46. {
  47. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  48. .Annotation("SqlServer:Identity", "1, 1"),
  49. Code = table.Column<string>(type: "nvarchar(30)", maxLength: 30, nullable: false, comment: "주소"),
  50. Subject = table.Column<string>(type: "nvarchar(120)", maxLength: 120, nullable: false, comment: "제목"),
  51. Content = table.Column<string>(type: "nvarchar(max)", nullable: true, comment: "내용"),
  52. IsActive = table.Column<bool>(type: "bit", nullable: false, comment: "사용 여부"),
  53. Views = table.Column<int>(type: "int", nullable: false, comment: "조회 수"),
  54. UpdatedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "수정 일시"),
  55. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  56. },
  57. constraints: table =>
  58. {
  59. table.PrimaryKey("PK_Document", x => x.ID);
  60. });
  61. migrationBuilder.CreateTable(
  62. name: "EmailVerifyNumber",
  63. columns: table => new
  64. {
  65. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  66. .Annotation("SqlServer:Identity", "1, 1"),
  67. Type = table.Column<int>(type: "int", nullable: false, comment: "인증 유형 (이메일 인증 / 비밀번호 재설정)"),
  68. Email = table.Column<string>(type: "nvarchar(60)", maxLength: 60, nullable: false, comment: "이메일"),
  69. Code = table.Column<string>(type: "nvarchar(10)", maxLength: 10, nullable: false, comment: "Token"),
  70. IsVerified = table.Column<bool>(type: "bit", nullable: false, comment: "인증 여부"),
  71. Expiration = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "만료 일시"),
  72. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  73. },
  74. constraints: table =>
  75. {
  76. table.PrimaryKey("PK_EmailVerifyNumber", x => x.ID);
  77. },
  78. comment: "이메일 인증 번호들");
  79. migrationBuilder.CreateTable(
  80. name: "EmailVerifyToken",
  81. columns: table => new
  82. {
  83. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  84. .Annotation("SqlServer:Identity", "1, 1"),
  85. Type = table.Column<int>(type: "int", nullable: false, comment: "인증 유형 (이메일 인증 / 비밀번호 재설정)"),
  86. Email = table.Column<string>(type: "nvarchar(60)", maxLength: 60, nullable: false, comment: "이메일"),
  87. Token = table.Column<string>(type: "nvarchar(256)", maxLength: 256, nullable: false, comment: "Token"),
  88. IsVerified = table.Column<bool>(type: "bit", nullable: false, comment: "인증 여부"),
  89. Expiration = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "만료 일시"),
  90. Additional = table.Column<string>(type: "nvarchar(max)", nullable: true, comment: "추가 정보(JSON)"),
  91. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  92. },
  93. constraints: table =>
  94. {
  95. table.PrimaryKey("PK_EmailVerifyToken", x => x.ID);
  96. },
  97. comment: "이메일 인증 토큰들");
  98. migrationBuilder.CreateTable(
  99. name: "FaqCategory",
  100. columns: table => new
  101. {
  102. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  103. .Annotation("SqlServer:Identity", "1, 1"),
  104. Code = table.Column<string>(type: "nvarchar(30)", maxLength: 30, nullable: false, comment: "주소"),
  105. Subject = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: false, comment: "분류 명"),
  106. Order = table.Column<int>(type: "int", nullable: false, comment: "순서"),
  107. IsActive = table.Column<bool>(type: "bit", nullable: false, comment: "사용 여부"),
  108. UpdatedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "수정 일시"),
  109. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  110. },
  111. constraints: table =>
  112. {
  113. table.PrimaryKey("PK_FaqCategory", x => x.ID);
  114. });
  115. migrationBuilder.CreateTable(
  116. name: "MemberGrade",
  117. columns: table => new
  118. {
  119. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  120. .Annotation("SqlServer:Identity", "1, 1"),
  121. KorName = table.Column<string>(type: "nvarchar(120)", maxLength: 120, nullable: false, comment: "한글 명"),
  122. EngName = table.Column<string>(type: "nvarchar(120)", maxLength: 120, nullable: false, comment: "영문 명"),
  123. Description = table.Column<string>(type: "nvarchar(1000)", maxLength: 1000, nullable: true, comment: "설명"),
  124. Order = table.Column<short>(type: "smallint", nullable: false, comment: "순서"),
  125. Image = table.Column<string>(type: "nvarchar(max)", nullable: true, comment: "이미지"),
  126. RequiredExp = table.Column<int>(type: "int", nullable: false, comment: "최소 경험치(Exp)"),
  127. RequiredCoin = table.Column<int>(type: "int", nullable: false, comment: "최소 코인(Coin)"),
  128. IsActive = table.Column<bool>(type: "bit", nullable: false, comment: "사용 여부"),
  129. UpdatedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "수정 일시"),
  130. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  131. },
  132. constraints: table =>
  133. {
  134. table.PrimaryKey("PK_MemberGrade", x => x.ID);
  135. },
  136. comment: "회원 등급");
  137. migrationBuilder.CreateTable(
  138. name: "Popup",
  139. columns: table => new
  140. {
  141. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  142. .Annotation("SqlServer:Identity", "1, 1"),
  143. Subject = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: false, comment: "제목"),
  144. Content = table.Column<string>(type: "nvarchar(max)", nullable: true, comment: "내용"),
  145. Link = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: true, comment: "주소"),
  146. StartAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "사용 기간 - 시작"),
  147. EndAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "사용 기간 - 종료"),
  148. Order = table.Column<short>(type: "smallint", nullable: false, comment: "순서"),
  149. IsActive = table.Column<bool>(type: "bit", nullable: false, comment: "사용 여부"),
  150. Views = table.Column<int>(type: "int", nullable: false, comment: "조회 수"),
  151. UpdatedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "수정 일시"),
  152. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  153. },
  154. constraints: table =>
  155. {
  156. table.PrimaryKey("PK_Popup", x => x.ID);
  157. });
  158. migrationBuilder.CreateTable(
  159. name: "RefreshToken",
  160. columns: table => new
  161. {
  162. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  163. .Annotation("SqlServer:Identity", "1, 1"),
  164. Token = table.Column<string>(type: "nvarchar(128)", maxLength: 128, nullable: false, comment: "Token"),
  165. MemberID = table.Column<int>(type: "int", nullable: false, comment: "회원 ID"),
  166. Expiration = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "만료 일시"),
  167. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  168. },
  169. constraints: table =>
  170. {
  171. table.PrimaryKey("PK_RefreshToken", x => x.ID);
  172. });
  173. migrationBuilder.CreateTable(
  174. name: "BannerItem",
  175. columns: table => new
  176. {
  177. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  178. .Annotation("SqlServer:Identity", "1, 1"),
  179. PositionID = table.Column<int>(type: "int", nullable: false, comment: "배너 위치 ID"),
  180. Subject = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: false, comment: "배너 명"),
  181. Image = table.Column<string>(type: "nvarchar(1024)", maxLength: 1024, nullable: true, comment: "이미지"),
  182. Width = table.Column<int>(type: "int", nullable: true, comment: "가로 크기"),
  183. Height = table.Column<int>(type: "int", nullable: true, comment: "세로 크기"),
  184. Link = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: true, comment: "주소"),
  185. Order = table.Column<int>(type: "int", nullable: false, comment: "순서"),
  186. IsActive = table.Column<bool>(type: "bit", nullable: false, comment: "사용 여부"),
  187. StartAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "사용 기간 - 시작"),
  188. EndAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "사용 기간 - 종료"),
  189. Views = table.Column<int>(type: "int", nullable: false, comment: "조회 수"),
  190. UpdatedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "수정 일시"),
  191. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  192. },
  193. constraints: table =>
  194. {
  195. table.PrimaryKey("PK_BannerItem", x => x.ID);
  196. table.ForeignKey(
  197. name: "FK_BannerItem_BannerPosition_PositionID",
  198. column: x => x.PositionID,
  199. principalTable: "BannerPosition",
  200. principalColumn: "ID",
  201. onDelete: ReferentialAction.Cascade);
  202. });
  203. migrationBuilder.CreateTable(
  204. name: "FaqItem",
  205. columns: table => new
  206. {
  207. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  208. .Annotation("SqlServer:Identity", "1, 1"),
  209. CategoryID = table.Column<int>(type: "int", nullable: false, comment: "분류 ID"),
  210. Question = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: false, comment: "질문"),
  211. Answer = table.Column<string>(type: "nvarchar(max)", nullable: true, comment: "답변"),
  212. Order = table.Column<int>(type: "int", nullable: false, comment: "순서"),
  213. IsActive = table.Column<bool>(type: "bit", nullable: false, comment: "사용 여부"),
  214. Views = table.Column<int>(type: "int", nullable: false, comment: "조회 수"),
  215. UpdatedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "수정 일시"),
  216. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  217. },
  218. constraints: table =>
  219. {
  220. table.PrimaryKey("PK_FaqItem", x => x.ID);
  221. table.ForeignKey(
  222. name: "FK_FaqItem_FaqCategory_CategoryID",
  223. column: x => x.CategoryID,
  224. principalTable: "FaqCategory",
  225. principalColumn: "ID",
  226. onDelete: ReferentialAction.Cascade);
  227. });
  228. migrationBuilder.CreateTable(
  229. name: "Member",
  230. columns: table => new
  231. {
  232. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  233. .Annotation("SqlServer:Identity", "1, 1"),
  234. GradeID = table.Column<int>(type: "int", nullable: true, comment: "회원등급 ID"),
  235. SID = table.Column<string>(type: "nvarchar(20)", maxLength: 20, nullable: false, comment: "SID"),
  236. Email = table.Column<string>(type: "nvarchar(60)", maxLength: 60, nullable: false, comment: "이메일"),
  237. Name = table.Column<string>(type: "nvarchar(20)", maxLength: 20, nullable: true, comment: "별명"),
  238. FullName = table.Column<string>(type: "nvarchar(40)", maxLength: 40, nullable: true, comment: "본명"),
  239. FirstName = table.Column<string>(type: "nvarchar(20)", maxLength: 20, nullable: true, comment: "본명(성)"),
  240. LastName = table.Column<string>(type: "nvarchar(40)", maxLength: 40, nullable: true, comment: "본명(이름)"),
  241. Password = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: true, comment: "비밀번호"),
  242. Intro = table.Column<string>(type: "nvarchar(1000)", maxLength: 1000, nullable: true, comment: "자기소개"),
  243. Summary = table.Column<string>(type: "nvarchar(50)", maxLength: 50, nullable: true, comment: "한마디"),
  244. Coin = table.Column<long>(type: "bigint", nullable: false, comment: "코인"),
  245. Exp = table.Column<int>(type: "int", nullable: false, comment: "경험치"),
  246. Phone = table.Column<string>(type: "nvarchar(15)", maxLength: 15, nullable: true, comment: "연락처"),
  247. Birthday = table.Column<DateOnly>(type: "date", nullable: true, comment: "생년월일"),
  248. Gender = table.Column<int>(type: "int", nullable: true, comment: "성별"),
  249. Photo = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: true, comment: "사진"),
  250. Icon = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: true, comment: "아이콘"),
  251. IsEmailVerified = table.Column<bool>(type: "bit", nullable: false, comment: "이메일 인증 여부"),
  252. IsAuthCertified = table.Column<bool>(type: "bit", nullable: false, comment: "본인 인증 여부"),
  253. IsDenied = table.Column<bool>(type: "bit", nullable: false, comment: "차단 여부"),
  254. IsAdmin = table.Column<bool>(type: "bit", nullable: false, comment: "운영진 여부"),
  255. IsWithdraw = table.Column<bool>(type: "bit", nullable: false, comment: "탈퇴 여부"),
  256. Following = table.Column<int>(type: "int", nullable: false, comment: "구독 중"),
  257. Followed = table.Column<int>(type: "int", nullable: false, comment: "구독자"),
  258. DeviceInfo = table.Column<string>(type: "nvarchar(400)", maxLength: 400, nullable: true, comment: "로그인 단말기 정보"),
  259. SignupIP = table.Column<string>(type: "nvarchar(15)", maxLength: 15, nullable: false, comment: "회원가입 시 IP"),
  260. LastLoginIp = table.Column<string>(type: "nvarchar(15)", maxLength: 15, nullable: true, comment: "마지막 로그인 IP"),
  261. LastLoginAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "마지막 로그인 일시"),
  262. LastEmailChangedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "마지막 이메일 변경 일시"),
  263. LastNameChangedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "마지막 별명 변경 일시"),
  264. EmailVerifiedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "이메일 인증 일시"),
  265. AuthCertifiedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "본인인증 일시"),
  266. PasswordUpdatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "비밀번호 변경 일시"),
  267. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "가입 일시"),
  268. UpdatedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "수정 일시"),
  269. DeletedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "탈퇴 일시")
  270. },
  271. constraints: table =>
  272. {
  273. table.PrimaryKey("PK_Member", x => x.ID);
  274. table.ForeignKey(
  275. name: "FK_Member_MemberGrade_GradeID",
  276. column: x => x.GradeID,
  277. principalTable: "MemberGrade",
  278. principalColumn: "ID");
  279. },
  280. comment: "회원 정보");
  281. migrationBuilder.CreateTable(
  282. name: "EmailChangeLog",
  283. columns: table => new
  284. {
  285. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  286. .Annotation("SqlServer:Identity", "1, 1"),
  287. MemberID = table.Column<int>(type: "int", nullable: false, comment: "회원 ID"),
  288. BeforeEmail = table.Column<string>(type: "nvarchar(40)", maxLength: 40, nullable: true, comment: "이전 이메일"),
  289. AfterEmail = table.Column<string>(type: "nvarchar(40)", maxLength: 40, nullable: false, comment: "바꾼 이메일"),
  290. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  291. },
  292. constraints: table =>
  293. {
  294. table.PrimaryKey("PK_EmailChangeLog", x => x.ID);
  295. table.ForeignKey(
  296. name: "FK_EmailChangeLog_Member_MemberID",
  297. column: x => x.MemberID,
  298. principalTable: "Member",
  299. principalColumn: "ID");
  300. },
  301. comment: "이메일 변경 내역");
  302. migrationBuilder.CreateTable(
  303. name: "EmailLog",
  304. columns: table => new
  305. {
  306. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  307. .Annotation("SqlServer:Identity", "1, 1"),
  308. MemberID = table.Column<int>(type: "int", nullable: true, comment: "회원 ID"),
  309. Status = table.Column<string>(type: "nvarchar(20)", nullable: false, comment: "처리 여부"),
  310. Subject = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: false, comment: "제목"),
  311. Message = table.Column<string>(type: "nvarchar(max)", nullable: true, comment: "내용"),
  312. ToAddress = table.Column<string>(type: "nvarchar(120)", maxLength: 120, nullable: false, comment: "수신 주소"),
  313. ToName = table.Column<string>(type: "nvarchar(60)", maxLength: 60, nullable: true, comment: "수신자"),
  314. FromAddress = table.Column<string>(type: "nvarchar(120)", maxLength: 120, nullable: false, comment: "발신 주소"),
  315. FromName = table.Column<string>(type: "nvarchar(60)", maxLength: 60, nullable: true, comment: "발신자"),
  316. ProcessedAt = table.Column<DateTime>(type: "datetime2", nullable: true, comment: "처리 일시"),
  317. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  318. },
  319. constraints: table =>
  320. {
  321. table.PrimaryKey("PK_EmailLog", x => x.ID);
  322. table.ForeignKey(
  323. name: "FK_EmailLog_Member_MemberID",
  324. column: x => x.MemberID,
  325. principalTable: "Member",
  326. principalColumn: "ID",
  327. onDelete: ReferentialAction.SetNull);
  328. });
  329. migrationBuilder.CreateTable(
  330. name: "LoginLog",
  331. columns: table => new
  332. {
  333. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  334. .Annotation("SqlServer:Identity", "1, 1"),
  335. MemberID = table.Column<int>(type: "int", nullable: true, comment: "회원 ID"),
  336. Success = table.Column<bool>(type: "bit", nullable: false, comment: "로그인 성공 여부 (0: 실패, 1: 성공)"),
  337. Account = table.Column<string>(type: "nvarchar(120)", maxLength: 120, nullable: false, comment: "로그인 시도한 계정"),
  338. Reason = table.Column<string>(type: "nvarchar(255)", maxLength: 255, nullable: true, comment: "실패 이유"),
  339. Referer = table.Column<string>(type: "nvarchar(max)", nullable: true, comment: "이전 페이지 주소"),
  340. Url = table.Column<string>(type: "nvarchar(500)", maxLength: 500, nullable: true, comment: "요청 주소"),
  341. IpAddress = table.Column<string>(type: "nvarchar(15)", maxLength: 15, nullable: true, comment: "IP Address"),
  342. UserAgent = table.Column<string>(type: "nvarchar(512)", maxLength: 512, nullable: true, comment: "User Agent"),
  343. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  344. },
  345. constraints: table =>
  346. {
  347. table.PrimaryKey("PK_LoginLog", x => x.ID);
  348. table.ForeignKey(
  349. name: "FK_LoginLog_Member_MemberID",
  350. column: x => x.MemberID,
  351. principalTable: "Member",
  352. principalColumn: "ID",
  353. onDelete: ReferentialAction.SetNull);
  354. },
  355. comment: "로그인 기록");
  356. migrationBuilder.CreateTable(
  357. name: "MemberApprove",
  358. columns: table => new
  359. {
  360. MemberID = table.Column<int>(type: "int", nullable: false, comment: "회원 ID"),
  361. IsReceiveSMS = table.Column<bool>(type: "bit", nullable: false, comment: "SMS 수신 여부"),
  362. IsReceiveEmail = table.Column<bool>(type: "bit", nullable: false, comment: "E-MAIL 수신 여부"),
  363. IsReceiveNote = table.Column<bool>(type: "bit", nullable: false, comment: "쪽지 수신 여부"),
  364. IsDisclosureInvest = table.Column<bool>(type: "bit", nullable: false, comment: "투자 현황 공개 여부")
  365. },
  366. constraints: table =>
  367. {
  368. table.PrimaryKey("PK_MemberApprove", x => x.MemberID);
  369. table.ForeignKey(
  370. name: "FK_MemberApprove_Member_MemberID",
  371. column: x => x.MemberID,
  372. principalTable: "Member",
  373. principalColumn: "ID");
  374. },
  375. comment: "회원 동의 및 수신 여부");
  376. migrationBuilder.CreateTable(
  377. name: "NameChangeLog",
  378. columns: table => new
  379. {
  380. ID = table.Column<int>(type: "int", nullable: false, comment: "PK")
  381. .Annotation("SqlServer:Identity", "1, 1"),
  382. MemberID = table.Column<int>(type: "int", nullable: false, comment: "회원 ID"),
  383. BeforeName = table.Column<string>(type: "nvarchar(40)", maxLength: 40, nullable: true, comment: "이전 별명"),
  384. AfterName = table.Column<string>(type: "nvarchar(40)", maxLength: 40, nullable: false, comment: "바꾼 별명"),
  385. CreatedAt = table.Column<DateTime>(type: "datetime2", nullable: false, comment: "등록 일시")
  386. },
  387. constraints: table =>
  388. {
  389. table.PrimaryKey("PK_NameChangeLog", x => x.ID);
  390. table.ForeignKey(
  391. name: "FK_NameChangeLog_Member_MemberID",
  392. column: x => x.MemberID,
  393. principalTable: "Member",
  394. principalColumn: "ID");
  395. },
  396. comment: "별명 변경 내역");
  397. migrationBuilder.CreateIndex(
  398. name: "IX_BannerItem_IsActive",
  399. table: "BannerItem",
  400. column: "IsActive");
  401. migrationBuilder.CreateIndex(
  402. name: "IX_BannerItem_Order",
  403. table: "BannerItem",
  404. column: "Order");
  405. migrationBuilder.CreateIndex(
  406. name: "IX_BannerItem_PositionID",
  407. table: "BannerItem",
  408. column: "PositionID");
  409. migrationBuilder.CreateIndex(
  410. name: "IX_BannerPosition_Code",
  411. table: "BannerPosition",
  412. column: "Code",
  413. unique: true);
  414. migrationBuilder.CreateIndex(
  415. name: "IX_BannerPosition_IsActive",
  416. table: "BannerPosition",
  417. column: "IsActive");
  418. migrationBuilder.CreateIndex(
  419. name: "IX_Config_Key",
  420. table: "Config",
  421. column: "Key",
  422. unique: true);
  423. migrationBuilder.CreateIndex(
  424. name: "IX_Document_Code",
  425. table: "Document",
  426. column: "Code",
  427. unique: true);
  428. migrationBuilder.CreateIndex(
  429. name: "IX_Document_IsActive",
  430. table: "Document",
  431. column: "IsActive");
  432. migrationBuilder.CreateIndex(
  433. name: "IX_EmailChangeLog_MemberID",
  434. table: "EmailChangeLog",
  435. column: "MemberID");
  436. migrationBuilder.CreateIndex(
  437. name: "IX_EmailLog_MemberID",
  438. table: "EmailLog",
  439. column: "MemberID");
  440. migrationBuilder.CreateIndex(
  441. name: "IX_EmailLog_Status",
  442. table: "EmailLog",
  443. column: "Status");
  444. migrationBuilder.CreateIndex(
  445. name: "IX_EmailVerifyNumber_Email",
  446. table: "EmailVerifyNumber",
  447. column: "Email");
  448. migrationBuilder.CreateIndex(
  449. name: "IX_EmailVerifyNumber_Expiration",
  450. table: "EmailVerifyNumber",
  451. column: "Expiration");
  452. migrationBuilder.CreateIndex(
  453. name: "IX_EmailVerifyNumber_IsVerified",
  454. table: "EmailVerifyNumber",
  455. column: "IsVerified");
  456. migrationBuilder.CreateIndex(
  457. name: "IX_EmailVerifyNumber_Type",
  458. table: "EmailVerifyNumber",
  459. column: "Type");
  460. migrationBuilder.CreateIndex(
  461. name: "IX_EmailVerifyToken_Email",
  462. table: "EmailVerifyToken",
  463. column: "Email");
  464. migrationBuilder.CreateIndex(
  465. name: "IX_EmailVerifyToken_Expiration",
  466. table: "EmailVerifyToken",
  467. column: "Expiration");
  468. migrationBuilder.CreateIndex(
  469. name: "IX_EmailVerifyToken_IsVerified",
  470. table: "EmailVerifyToken",
  471. column: "IsVerified");
  472. migrationBuilder.CreateIndex(
  473. name: "IX_EmailVerifyToken_Type",
  474. table: "EmailVerifyToken",
  475. column: "Type");
  476. migrationBuilder.CreateIndex(
  477. name: "IX_FaqCategory_Code",
  478. table: "FaqCategory",
  479. column: "Code",
  480. unique: true);
  481. migrationBuilder.CreateIndex(
  482. name: "IX_FaqCategory_Order",
  483. table: "FaqCategory",
  484. column: "Order");
  485. migrationBuilder.CreateIndex(
  486. name: "IX_FaqItem_CategoryID",
  487. table: "FaqItem",
  488. column: "CategoryID");
  489. migrationBuilder.CreateIndex(
  490. name: "IX_FaqItem_IsActive",
  491. table: "FaqItem",
  492. column: "IsActive");
  493. migrationBuilder.CreateIndex(
  494. name: "IX_FaqItem_Order",
  495. table: "FaqItem",
  496. column: "Order");
  497. migrationBuilder.CreateIndex(
  498. name: "IX_LoginLog_MemberID",
  499. table: "LoginLog",
  500. column: "MemberID");
  501. migrationBuilder.CreateIndex(
  502. name: "IX_Member_Email",
  503. table: "Member",
  504. column: "Email",
  505. unique: true);
  506. migrationBuilder.CreateIndex(
  507. name: "IX_Member_FullName",
  508. table: "Member",
  509. column: "FullName");
  510. migrationBuilder.CreateIndex(
  511. name: "IX_Member_GradeID",
  512. table: "Member",
  513. column: "GradeID");
  514. migrationBuilder.CreateIndex(
  515. name: "IX_Member_IsAdmin",
  516. table: "Member",
  517. column: "IsAdmin");
  518. migrationBuilder.CreateIndex(
  519. name: "IX_Member_IsAuthCertified",
  520. table: "Member",
  521. column: "IsAuthCertified");
  522. migrationBuilder.CreateIndex(
  523. name: "IX_Member_IsDenied",
  524. table: "Member",
  525. column: "IsDenied");
  526. migrationBuilder.CreateIndex(
  527. name: "IX_Member_IsEmailVerified",
  528. table: "Member",
  529. column: "IsEmailVerified");
  530. migrationBuilder.CreateIndex(
  531. name: "IX_Member_IsWithdraw",
  532. table: "Member",
  533. column: "IsWithdraw");
  534. migrationBuilder.CreateIndex(
  535. name: "IX_Member_Name",
  536. table: "Member",
  537. column: "Name",
  538. unique: true,
  539. filter: "[Name] IS NOT NULL");
  540. migrationBuilder.CreateIndex(
  541. name: "IX_Member_Phone",
  542. table: "Member",
  543. column: "Phone");
  544. migrationBuilder.CreateIndex(
  545. name: "IX_Member_SID",
  546. table: "Member",
  547. column: "SID",
  548. unique: true);
  549. migrationBuilder.CreateIndex(
  550. name: "IX_MemberGrade_EngName",
  551. table: "MemberGrade",
  552. column: "EngName",
  553. unique: true);
  554. migrationBuilder.CreateIndex(
  555. name: "IX_MemberGrade_KorName",
  556. table: "MemberGrade",
  557. column: "KorName",
  558. unique: true);
  559. migrationBuilder.CreateIndex(
  560. name: "IX_NameChangeLog_MemberID",
  561. table: "NameChangeLog",
  562. column: "MemberID");
  563. migrationBuilder.CreateIndex(
  564. name: "IX_Popup_IsActive",
  565. table: "Popup",
  566. column: "IsActive");
  567. migrationBuilder.CreateIndex(
  568. name: "IX_Popup_Order",
  569. table: "Popup",
  570. column: "Order");
  571. }
  572. /// <inheritdoc />
  573. protected override void Down(MigrationBuilder migrationBuilder)
  574. {
  575. migrationBuilder.DropTable(
  576. name: "BannerItem");
  577. migrationBuilder.DropTable(
  578. name: "Config");
  579. migrationBuilder.DropTable(
  580. name: "Document");
  581. migrationBuilder.DropTable(
  582. name: "EmailChangeLog");
  583. migrationBuilder.DropTable(
  584. name: "EmailLog");
  585. migrationBuilder.DropTable(
  586. name: "EmailVerifyNumber");
  587. migrationBuilder.DropTable(
  588. name: "EmailVerifyToken");
  589. migrationBuilder.DropTable(
  590. name: "FaqItem");
  591. migrationBuilder.DropTable(
  592. name: "LoginLog");
  593. migrationBuilder.DropTable(
  594. name: "MemberApprove");
  595. migrationBuilder.DropTable(
  596. name: "NameChangeLog");
  597. migrationBuilder.DropTable(
  598. name: "Popup");
  599. migrationBuilder.DropTable(
  600. name: "RefreshToken");
  601. migrationBuilder.DropTable(
  602. name: "BannerPosition");
  603. migrationBuilder.DropTable(
  604. name: "FaqCategory");
  605. migrationBuilder.DropTable(
  606. name: "Member");
  607. migrationBuilder.DropTable(
  608. name: "MemberGrade");
  609. }
  610. }
  611. }