【帶你從零開始,開發一個閱讀站】第三章,資料庫表結構

来源:http://www.cnblogs.com/input4hua/archive/2017/06/16/7028861.html
-Advertisement-
Play Games

整個項目只有四張表 book-書籍主表,記錄書籍的詳情信息,包括類別,作者描述等 type-類別表,書籍類別管理 menu-目錄章節表 properties-配置表 book表是書籍主表 code:用於圖書code記錄,可認為該欄位能確定圖書唯一 typeId:關聯type表主鍵id,標識圖書類別 ...


整個項目只有四張表

book-書籍主表,記錄書籍的詳情信息,包括類別,作者描述等

type-類別表,書籍類別管理

menu-目錄章節表

properties-配置表

 

book表是書籍主表

code:用於圖書code記錄,可認為該欄位能確定圖書唯一

typeId:關聯type表主鍵id,標識圖書類別

title:書名

author:作者

lastMenuId:最新章節目錄,關聯menu表主鍵id

description:圖書描述

originalUrl(廢棄不用)

imageUri:圖片地址,這個地址是相對地址。記錄了圖書展示圖片的文件名

createTime:圖書錄入時間

updateTime:最後更新時間

rootTypeId:主類別id,tpye表主鍵id,詳情看type表記錄

menuNum:圖書目錄數量

textSize:當前圖書有多少字

 

menu章節表:

description:章節名

prevMenuId:上一章節id(menu表主鍵id)

nextMenuId:下一章節id(menu表主鍵id)

bookId:圖書id(book表主鍵id)

contentUri:正文地址(此地址是正文文件存儲在伺服器上的地址)

createTime:章節錄入時間

code :章節編碼(沒有具體作用)

mversion:章節版本控制(防止重覆錄入)

 

type表為圖書類別表:

description:類別描述

level:類別等級

parentId:所屬父類別

類別建立如上所述,level為1的是主類別,其下lever為2的即為子類別。子類別的parentId關聯父類別的主鍵id。主類別沒有父類別,即parentId為0

這裡需要提一點的是,父類主鍵*100再遞增作為子類別的主鍵id。如id為101的父類別的id為1

 

properties表做配置用,考慮下一版本將程式里的配置放在properties里。

現在這張表只有一條配置

pKey:為程式讀取到相應pValue的值,在首頁做跑馬燈顯示

 

 

此處給出表創建腳本,供大家參考:

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------
-- Table structure for book
-- ----------------------------
DROP TABLE IF EXISTS `book`;
CREATE TABLE `book` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '圖書主表',
  `code` varchar(45) COLLATE utf8_bin DEFAULT NULL COMMENT '圖書編碼(預設圖書目錄地址,也是圖書文件保留目錄)',
  `typeId` int(11) DEFAULT NULL COMMENT '類別',
  `title` varchar(45) COLLATE utf8_bin DEFAULT NULL COMMENT '書名',
  `author` varchar(45) COLLATE utf8_bin DEFAULT NULL COMMENT '作者',
  `lastMenuId` int(11) DEFAULT '0' COMMENT '最新章節目錄Id',
  `description` varchar(500) COLLATE utf8_bin DEFAULT NULL COMMENT '簡介描述',
  `originalUrl` varchar(200) COLLATE utf8_bin DEFAULT NULL COMMENT '已廢棄',
  `imageUri` varchar(45) COLLATE utf8_bin DEFAULT NULL COMMENT '圖片地址',
  `createTime` timestamp NULL DEFAULT NULL COMMENT '創建時間',
  `updateTime` timestamp NULL DEFAULT NULL COMMENT '更新時間',
  `rootTypeId` int(11) DEFAULT NULL COMMENT '主類別',
  `menuNum` int(11) DEFAULT '0' COMMENT '章節總數',
  `textSize` bigint(18) DEFAULT '0' COMMENT '小說字數',
  PRIMARY KEY (`id`),
  UNIQUE KEY `index_title` (`code`) USING BTREE,
  KEY `FK_mxn08ipa84r1evyt2cnn7jkpi` (`typeId`,`rootTypeId`),
  KEY `FK_6ji3nbliycexuj771dlqn25s3` (`lastMenuId`)
) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
-- Table structure for menu
-- ----------------------------
DROP TABLE IF EXISTS `menu`;
CREATE TABLE `menu` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `description` varchar(100) COLLATE utf8_bin DEFAULT NULL COMMENT '描述',
  `prevMenuId` int(11) DEFAULT '0' COMMENT '上一章id',
  `nextMenuId` int(11) DEFAULT '0' COMMENT '下一章id',
  `bookId` int(11) DEFAULT NULL COMMENT '圖書id',
  `contentUri` varchar(100) COLLATE utf8_bin DEFAULT NULL COMMENT '文本路徑',
  `createTime` timestamp NULL DEFAULT NULL COMMENT '創建時間',
  `code` varchar(45) COLLATE utf8_bin DEFAULT NULL COMMENT '編碼(做索引)',
  `mversion` varchar(45) COLLATE utf8_bin DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `mvserion` (`mversion`) USING BTREE,
  KEY `FK_c6rhyxr26doitte59912cid6v` (`bookId`),
  CONSTRAINT `menu_ibfk_1` FOREIGN KEY (`bookId`) REFERENCES `book` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=231 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
-- Table structure for properties
-- ----------------------------
DROP TABLE IF EXISTS `properties`;
CREATE TABLE `properties` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `pKey` varchar(45) COLLATE utf8_bin NOT NULL,
  `pValue` varchar(256) COLLATE utf8_bin NOT NULL,
  `description` varchar(45) COLLATE utf8_bin DEFAULT NULL COMMENT '描述',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

-- ----------------------------
-- Table structure for type
-- ----------------------------
DROP TABLE IF EXISTS `type`;
CREATE TABLE `type` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `description` varchar(45) COLLATE utf8_bin DEFAULT NULL COMMENT '類別描述',
  `level` int(11) DEFAULT NULL COMMENT '類別等級',
  `parentId` int(11) unsigned DEFAULT '0' COMMENT '父類別',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=702 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 類視圖 使用原則 代碼越少越好 永遠不要重覆代碼 View應當只包含呈現邏輯, 不應包括業務邏輯 保持view邏輯清晰簡單 不要將CBVs用作403, 404, 500的錯誤處理程式 保持mixin簡單明瞭 mixin 在編程中mixin是指為繼承它的class提供額外的功能, 但它自身卻不能單獨使 ...
  • 題目描述 M 海運公司最近要對旗下倉庫的貨物進出情況進行統計。目前他們所擁有的唯一記錄就是一個記錄集裝箱進出情況的日誌。該日誌記錄了兩類操作:第一類操作為集裝箱入庫操作,以及該次入庫的集裝箱重量;第二類操作為集裝箱的出庫操作。這些記錄都嚴格按時間順序排列。集裝箱入庫和出庫的規則為先進後出,即每次出庫 ...
  • spring boot入門操作 創建HelloWorld + 新建maven project ,選擇artifact id 為maven archetype quicktype + 創建pom,在project中添加 org.springframework.boot spring boot star ...
  • 在計劃任務中經常可以看到。例如我們公司的計劃任務舉例: 對於& 1 更準確的說應該是文件描述符 1,而1標識標準輸出,stdout。對於2 ,表示標準錯誤,stderr。2>&1 的意思就是將標準錯誤重定向到標準輸出。這裡標準輸出已經重定向到了 /dev/null。那麼標準錯誤也會輸出到/dev/n ...
  • 公司所用計劃任務均是大概這樣子的: 可以看到把輸出與標準錯誤進行重定向到空設備了,這樣做是有一定原因的。查閱了一些資料,在這裡描述一下: 1.ssh登陸伺服器2.新建一個php文件test.php,代碼如下: 3.用以下命令執行test.php程式 查看 /tmp/test.txt 文件的內容為14 ...
  • 題目描述 牛牛最近迷上了一種叫鬥地主的撲克游戲。鬥地主是一種使用黑桃、紅心、梅花、方片的A到K加上大小王的共54張牌來進行的撲克牌游戲。在鬥地主中,牌的大小關係根據牌的數位表示如下:3<4<5<6<7<8<9<10<J<Q<K<A<2<小王<大王,而花色並不對牌的大小產生影響。每一局游戲中,一副手牌 ...
  • Java的記憶體分配上,主要分4個塊!一塊是用來裝代碼的,就是編譯的東西。一塊是用來裝靜態變數的,例如用static關鍵字的變數,例如字元串常量。一塊是stack,也就是棧,是用來裝變數和引用類型的!但區別在於,裝了變數以後,變數上是有值的,而引用類型本身在stack上是沒有值的。一塊是heap,也就 ...
  • 今天使用ab(apacheBench)測試了一下beego的性能。 3Kbytes動態文件,在i3上可以達到每秒1W次響應的性能。但是在測試靜態文件時,beego出現了問題。ab測試參數:100次請求,併發數5。問題表現:70%的請求直接失敗,連接斷開。按道理來說,一個web server框架,靜態 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...