五、Java多人博客系统-2.0版本-数据库设计
数据库设计表如下:文章类别表、文章表、评论表、留言表。
文章列表表:存放文章类别,首页菜单生成也是从这个表取的。
文章表:存放文章标题、发表时间、内容等信息。
评论表:文章评论内容。
留言表:用户发表的留言。
有两个触发器,用于管理文章的评论次数。评论表增加一条记录,则文章表对应记录的评论数增加1,评论表删除一条记录,则文章表对应记录的评论数减去1。
详细的sql如下:
-- 1、创建库
drop database if exists blog; -- 直接删除数据库,不提醒
create database blog; -- 创建数据库
use blog; -- 选择数据库 -- 2、创建表
--
-- table structure for table `bll_article` 文章
--
drop table if exists `bll_article`;
create table `bll_article` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
`createtime` datetime default current_timestamp comment '创建时间',
`creator` varchar(60) not null comment '创建人',
`typeid` bigint(20) default null comment '文章所属类型id',
`title` varchar(50) default null comment '文章标题',
`content` varchar(10000) default null comment '文章内容',
`comcount` int(11) default '0' comment '文章被评论条数',
`readcount` int(11) default '0' comment '文章被阅读条数',
`suggestcount` int(11) default '0' comment '文章被点赞次数',
primary key (`id`)
) engine=innodb default charset=utf8 comment='用户发表的文章'; --
-- table structure for table `bll_articletype` 文章类别
--
drop table if exists `bll_articletype`;
create table `bll_articletype` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
`createtime` datetime default current_timestamp comment '创建时间',
`creator` varchar(60) not null comment '创建人',
`typename` varchar(50) default null comment '文章类型名称',
`description` varchar(50) default null comment '描述',
primary key (`id`)
) engine=innodb default charset=utf8 comment='文章类型'; --
-- table structure for table `bll_commont` 评论
--
drop table if exists `bll_comment`;
create table `bll_comment` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
`createtime` datetime default current_timestamp comment '创建时间',
`creator` varchar(60) not null comment '创建人',
`articleid` bigint(20) default null comment '被评论的文章id',
`comcontent` varchar(2000) default null comment '评论内容',
`email` varchar(200) default null comment '评论人邮箱',
primary key (`id`)
) engine=innodb default charset=utf8 comment='对文章的评论信息'; --
-- table structure for table `bll_leavemessage` 留言
--
drop table if exists `bll_leavemessage`;
create table `bll_leavemessage` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
`createtime` datetime default current_timestamp comment '创建时间',
`creator` varchar(60) not null comment '创建人',
`content` varchar(2000) default null comment '留言内容',
`email` varchar(200) default null comment '留言人邮箱',
primary key (`id`)
) engine=innodb default charset=utf8 comment='留言'; -- 3、创建触发器
-- (1)评论表增加一条记录,则文章表对应记录的评论数增加1
create trigger addcomcount
after insert on bll_comment
for each row
update bll_article set comcount=comcount+1 where id=new.articleid; -- (2)评论删除一条记录,则文章表对应记录的评论数减去1
create trigger pluscomcount
after delete on bll_comment
for each row
update bll_article set comcount=comcount-1 where id=old.articleid; -- 初始化数据
insert into bll_articletype(creator,typename,description) values ('tim','编程','编程技术、设计等');
insert into bll_articletype(creator,typename,description) values ('tim','感悟','人生感悟等');
insert into bll_articletype(creator,typename,description) values ('tim','摄影','拍摄的照片等');
insert into bll_articletype(creator,typename,description) values ('tim','英语','英语文章');
五、Java多人博客系统-2.0版本-数据库设计的更多相关文章
- 四、Java多人博客系统-2.0版本
由于时间关系,多人博客系统这里穿插一个2.0版本. 2.0版本本来是打算用于建立个人网站,但是后来发现个人建站需要购买域名服务器,还需要备案,很繁琐.最终放弃.完成此版本,最终也只是作为技术演练.此版 ...
- 七、Java多人博客系统-2.0版本-docker部署
docker是当下很热门的技术,是对之前的部署系统方式的彻底改变.之前部署系统,需要安装数据库.初始化数据库,安装jdk,配置jdk,部署应用程序,修改配置文件等,很繁琐.一般现场运维人员很难搞定,现 ...
- 六、Java多人博客系统-2.0版本-代码实现
1.前后端分离,后端使用spring boot,只负责提供数据,对外暴露Restful API.前端使用vue,只负责展示数据和向后台提交数据. 2.数据库使用mariadb,存储所有数据. 3.前端 ...
- 三、Java多人博客系统-技术架构
多人博客系统1.0版本,架构和技术还是很简单和很传统的. 1.技术 前端:jsp.html.css.javascript.jquery.easyui.echarts 后端:spring mvc.Hib ...
- 二、Java多人博客系统-演变
任何项目都是由小到大,逐步演变的.自己写的这个博客系统也不例外. 更新日志如下: 一.2014年底-2015年初 功能及技术: 1.定位为个人网站,介绍自己情况和发布文章等. 2.首页模块有:个人简介 ...
- 一、Java多人博客系统-开篇
作为一个程序员,工作之外的不断学习是必须的.这个项目是我个人课外学习和练手的项目.最开始是一个个人网站.当时发现京东云可以免费部署网站的,就立即写了一个网站,当时就使用jsp技术,可以实现发布博客.评 ...
- 【完全开源】Django多人博客系统——支持MarkDown和tinyMce
目录 说明 功能 如何使用 说明 这是一个用Django开发的多人博客系统,功能简单,但完全满足公司内部或个人的博客使用需求.支持普通富文本编辑器(tinyMCE)和MarkDown编辑器 由于嫌弃D ...
- Java程序员博客系统推荐!我调研了100来个 Java 开源博客系统,发现这 5 个最好用!
大家好!我是 Guide 哥,Java 后端开发.一个会一点前端,喜欢烹饪的自由少年. 最近想倒腾一下博客,看了很多现成的比较成熟的开源博客系统,自己也简单从下面几个维度总结对比了一下: star数量 ...
- 推荐一款自研的Java版开源博客系统OneBlog
OneBlog 一款超好用的Java版开源博客 Introduction 简介 OneBlog 一个简洁美观.功能强大并且自适应的Java博客.使用springboot开发,前端使用Boot ...
随机推荐
- (最完美)小米平板3的USB调试模式在哪里开启的流程
经常我们使用安卓手机链上电脑的时候,或者使用的有些应用软件比如我们公司营销小组经常使用的应用软件引号精灵,之前的老版本就需要开启usb调试模式下使用,现经常新版本不需要了,如果手机没有开启usb调试模 ...
- Android远程桌面助手(Build 0737)
Android Remote Displayer and Controller Build 0737, Aug 02, 2017 新增功能: 录制MP4文件,突破了Android原生180S的限制 截 ...
- WPF:DropShadowEffect 生效
1.BorderThickness = “XX”,xx可以当作阴影四周的宽度 2.BorderBrush="Transparent"
- 容器化系列 - Zookeeper启动和配置 on Docker
本文简要说明了如何在Docker容器中启动和配置Zookeeper. 1 准备工作 1.1 下载zookeeper镜像 $ docker pull zookeeper:3.4 1.2 单点模式 安装D ...
- jsoup爬取网站图片
package com.ij34.JsoupTest; import java.io.File; import java.io.FileOutputStream; import java.io.Inp ...
- 【转载】FPGA算法映射要点
近期一直在学习利用FPGA完成算法的定点运算,转载些相关的博客方面回顾查找.本博文原文链接为:https://blog.csdn.net/u013989284/article/details/7899 ...
- AXI-Lite总线及其自定义IP核使用分析总结
ZYNQ的优势在于通过高效的接口总线组成了ARM+FPGA的架构.我认为两者是互为底层的,当进行算法验证时,ARM端现有的硬件控制器和库函数可以很方便地连接外设,而不像FPGA设计那样完全写出接口时序 ...
- Think_in_java_4th(并发学习一)
Java的并发是在顺序语言的基础上提供对线程的支持的. 并发能够更加有效的执行我们的代码,也就是更加合理的应用CPU资源. 并发程序往往CPU和内存使用率,要高于同等的非并发程序. 下面就用Think ...
- python:过滤字符串中的字母数字特殊符号
今天遇到的字符串处理的问题,记录一下方便使用 str1 = input('请输入一个字符:') #初始化字符.数字.空格.特殊字符的计数 lowercase = 0 uppercase = 0 num ...
- c# 判断一个string[]是否全包含另一个string[]
// list = normalList.Except(repairList).ToList(); //差集 // list = normalList.Union(repairList).ToList ...