BBS论坛数据库设计
BBS论坛系统数据库设计

BBS论坛系统数据库设计0.后台用户管理(TAB_USER)序号字段名称字段英文名数据类型长度PK(Y/N) NULL(Y/N) 备注1 自增ID id int Y N2 用户帐号usercode varchar 20 N 登录用3 姓名username varchar 20 N3 密码pwd varchar 11 N 用MD5加密算法4 性别ssex varchar 105 角色role int6 Email地址email varchar 301.前台用户注册表(TAB_USER_REGISTER)序号字段名称字段英文名数据类型长度PK(Y/N) NULL(Y/N) 备注1 自增ID id int Y N2 用户帐号usercode varchar 50 N 登录用3 姓名username varchar 50 N3 密码userpsw varchar 11 N 用MD5加密算法4 昵称nickname varchar 505 头像image6 Email地址email varchar 807 验证码checkno bigint 102.用户发帖表(TAB_USER_SENDCARD)序号字段名称字段英文名数据类型长度PK(Y/N) NULL(Y/N) 备注1 发帖ID sendcardid int Y N 自增2 发帖区ID sendzoneid int 参照发帖区3 用户帐号usercode varchar 304 主题title varchar 200 N5 发帖内容cardcontent varchar 10006 日期date date7 验证码checkno bigint发帖ID的值来判断级别。
3.用户跟帖表(TAB_USER_FOLLOWCARD)序号字段名称字段英文名数据类型长度PK(Y/N) NULL(Y/N) 备注1 跟帖ID followcardid int Y N 自增2 讨论区ID discussid int 参照推荐讨论区ID和技术讨论区ID3 用户帐号usercode varchar 304 发帖ID sendcardid int 参照发帖表sendcardID(1:n)5 跟帖内容followcardcontent varchar 10006 日期date date7 验证码checkno4.公告管理表(TAB_NOTICEMANAGE )序号字段名称字段英文名数据类型长度PK(Y/N) NULL(Y/N) 备注1 公告ID noticeid int Y N 自增2 公告时间noticetime date3 公告内容content varchar 200 N4 作者author varchar 505 备注remark varchar 1005.推荐讨论区表(TAB_RECOMMANDMANAGE)长度PK(Y/N) NULL(Y/N) 备注序号字段名称字段英文名数据类型1 自增ID id int Y N 自增2 推荐讨论区号ID recommandid int Y N3 推荐主题号recomcontentid int4 推荐主题content varch100 Nardate5 推荐主题时间recommandInftime506 作者author varchar7 备注remark varch100ar6.技术交流区表(TAB_TECHENIQUEMANAGE )序号字段名称字段英文名数据类型长度PK(Y/N) NULL(Y/N) 备注1 自增ID id int Y N 自增techeniqueid int Y N2 技术讨论区号ID2 发稿时间techeniqueInftime datecontent varchar 100 N3 技术交流主题4 作者author varchar 505 备注remark varchar 1007.文章阅读区表(TAB_ARTICLEMANAGE)序号字段名称字段英文名数据类型长度PK(Y/N) NULL(Y/N) 备注1 文章ID articleid int Y N 自增2 文章主题articletitle varchar 2003 文章内容articlecontent varchar 1000 N4 作者author varchar 505 备注remark varchar 1008.发帖主题审核表(TAB_SENDAUDITING)序号字段名称字段英文名数据类型长度PK(Y/N) NULL(Y/N) 备注1 自增ID articleid int Y N 自增2 发帖ID sendcardid int 203 审批状态auditingstatus varchar 20 N 通过审批/取消4 排序状态compositor varchar 10 置顶/一般通过审批用1表示,取消用0表示。
BBS论坛数据库设计代码

BBS论坛数据库设计代码use mastergo----------------------------------------新建数据bbsDB的库---------------------------------------------------------判断数据库是否存在使用exists关键字,在用sysdatabases关键字查询--if exists(select * from sysdatabases where name = 'bbsDB')--如果数据库存在就删除此数据库用drop(删除)database(数据库对象)bbsDB (数据库名)--drop database bbsDB--删除后在添加一个数据库create(添加)database(数据库对象)bbsDB(数据库名)on--create database bbsDBon(name = 'bbsDB_MDF', --数据库主文件名--filename = 'F:\SQL\第四阶段\bbsDB_MDF.mdf', --数据库存储的路径--size = 10mb, --数据库初使大小--filegrowth = 10% --增长变化--)--设置日志文件--log on(name = 'bbsDB_LDF', --日志文件名--filename = 'F:\SQL\第四阶段\bbsDB_LDF.ldf', --日志文件存储路径--size = 1mb, --日志文件初使大小--maxsize = 20mb, --日志文件最大的可储存--filegrowth = 10% --增长变化--)go---------------------------------------以上信息为新建的数据库-------------------------------------------------use bbsDBgo---------------------------------------新建bbsUsers表(用户表)---------------------------------------------------判断bbsDB库是否有表bbsUser的存在exists关键字+sysobjects判断当前数据库表--if exists(select * from sysobjects where name='bbsUsers')--如果表存在就删除此表--drop table bbsUser--新建bbsUser表--create table bbsUsers(UID int identity(1,1) not null, --用户编号,自动增长列,不允许空--Uname varchar(50) not null, --用户名,不允许空--Upassword varchar(50) not null, --密码,不允许空--Uemail varchar(50), --邮箱--Usex char(2) not null, --性别,不允许空--Uclass int, --用户等级--Uremark varchar(50), --备注信息--UregDate datetime not null, --注册日期,不允许空--Ustate int, --状态,是否在线等--Upoint int, --用户的积分--)go--------------------------------------为用户表添加各种约束----------------------------------------------------------为bbsUser表添加约束,add constraint关键字PK_UID约束名,primary key (主键)设置UID字段为主键--alter table bbsUsersadd constraint PK_UID primary key(UID)--为Upassword添加约束,check(Upassword length>=6)字段长度大于等于6位,default设置默认值为888888--alter table bbsUsersadd constraint CK_Upassword check(len(Upassword) >= 6)alter table bbsUsersadd constraint DF_Upassword default('888888') for Upassword--为Uemail字段添加约束,必须包含@号--alter table bbsUsersadd constraint CK_Uemail check(Uemail like '%@%')--为User字段添加约束,设置默认值为男,并且值只能是男或女--alter table bbsUsersadd constraint DF_Usex default('男') for Usexalter table bbsUsersadd constraint CK_Usex check(Usex='男' or Usex='女')--为Uclass字段添加约束,默认值为1--alter table bbsUsersadd constraint DF_Uclass default(1) for Uclass--为UregDate字段添加约束,默认值为当前日期--alter table bbsUsersadd constraint DF_UregDate default(getDate()) for UregDate--为Ustate添加约束,默认值为0--alter table bbsUsersadd constraint DF_Ustate default(0) for Ustate--为Upoint字段添加约束,默认值为20--alter table bbsUsersadd constraint DF_Upoint default(20) for Upoint-----------------------------------以上信息为以建立的bbsUser(用户表)及各种约束-----------------------------------go-----------------------------------新建bbsSection表(版块表)-------------------------------------------------------判断数据库内是否有表bbsSection的存在--if exists(select * from sysobjects where name = 'bbsSection')--如果有此表执行删除--drop table bbsSection--新建bbsSection表,及个字段--create table bbsSection(SID int identity(1,1) not null, --版块编号,自动增长列--Sname varchar(50) not null, --版块名称,不允许空--SmasterID int not null, --版主ID--Sprofile varchar(50), --版面简介--SclickCount int, --点击率--StopicCount int --发贴数--)-----------------------------------为表bbsSection(版块表)添加约束-----------------------------------------------go--将SID字段设置为主键--alter table bbsSectionadd constraint PK_SID primary key(SID)--为SmasterID设置外键,他的主键是bbsUsers表的UID字段foreign key(外键) references 主键表(主键表字段)--alter table bbsSectionadd constraint FK_SmasterID foreign key(SmasterID) references bbsUsers (UID)--为SclickCount字段添加默认值为0--alter table bbsSectionadd constraint DF_SclickCount default(0) for SclickCount--为字段StopicCount设置默认值为0--alter table bbsSectionadd constraint DF_StopicCount default(0) for StopicCount---------------------------------以上为表bbsSection(版块表)建立及添加相应约束-----------------------------------------------------------------------------新建bbsTopic表(主贴表)---------------------------------------------------go--判断数据库中是否有bbsTopic表的存在--if exists(select * from sysobjects where name = 'bbsTopic')--删除此表--drop table bbsTopic--新建bbaTopic表及个字段--create table bbsTopic(TID int identity(1,1) not null, --帖子编号--TsID int not null, --版块编号--TuID int not null, --发贴人ID--TreplyCount int, --回复数量--Tface int, --发贴表情--Ttopic varchar(50) not null, --标题--Tcontents varchar(50) not null, --正文--Ttime datetime, --发贴时间--TclickCount int, --点击数--Tstate int not null, --状态--TlastReply datetime --最后回复时间--)----------------------------------------为bbsTopic(主贴表)表个字段添加约束-----------------------------------------go--将TID字段设置为主键--alter table bbsTopicadd constraint PK_TID primary key(TID)--将TsID设置为外键,引用bbsSection表的主键SID字段--alter table bbsTopicadd constraint FK_TsID foreign key(TsID) references bbsSection (SID) --将TuID字段设置为外键盘,引用bbsUsers表的主键UID字段-- alter table bbsTopicadd constraint FK_TuID foreign key(TuID) references bbsUsers (UID) --设置TreplyCount字段的默认值为0--alter table bbsTopicadd constraint DF_TreplyCount default(0) for TreplyCount--为Tcontents字段添加约束,他的值必须大于等于6位--alter table bbsTopicadd constraint CK_Tcontents check(len(Tcontents) >= 6)--为Ttime字段添加默认值,为当前日期--alter table bbsTopicadd constraint DF_Ttime default(getDate()) for Ttime--设置TclickCount字段默认值为0--alter table bbsTopicadd constraint DF_TclickCount default(0) for TclickCount--设置Tstate字段默认值为1--alter table bbsTopicadd constraint DF_Tstate default(1) for Tstate--为TlastReply字段添加约束,最后回复时间必须要晚于发贴时间--alter table bbsTopicadd constraint CK_TlastReply check(TlastReply > Ttime)-----------------------------------------以上为bbsTopic(主贴表)表建立及建立个字段------------------------------------------------------------------------------新建表bbsReply(回帖表)及个字段--------------------------------------go--判断数据库中是否有bbsReply(回帖表)的存在--if exists(select * from sysobjects where name = 'bbsReply')--删除bbsReply表--drop table bbsReply--创建bbsReply(回帖)表及个字段--create table bbsReply(RID int identity(1,1) not null, --帖子编号--RtID int not null, --主贴ID--RsID int not null, --版块ID--RuID int not null, --回帖人ID--Rface int, --回帖表情--Rcontents varchar(50) not null, --正文--Rtime datetime, --回帖时间--RclickCount int --点击数--)-----------------------------------------为bbsReply(回帖)表个字段添加约束----------------------------------------go--设置RID字段为主键--alter table bbsReplyadd constraint PK_RID primary key(RID)--设置RtID字段为外键引用bbsTopic表的主键TID字段--alter table bbsReplyadd constraint FK_RtID foreign key(RtID) references bbsTopic(TID)--设置RsID为外键引用bbsSection表的主键SID--alter table bbsReplyadd constraint FK_RsID foreign key(RsID) references bbsSection(SID)--设置RuID为外键引用bbsUsers表的主键UID字段--alter table bbsReplyadd constraint FK_RuID foreign key(RuID) references bbsUsers(UID)--设置Rcontents字段必须大于6位--alter table bbsReplyadd constraint DF_Rcontents check(len(Rcontents) >= 6)--设置Rtime字段默认值为当前日期--alter table bbsReplyadd constraint DF_Rtime default(getDate()) for Rtime------------------------------------------------以上为创建bbsReply(回帖)表的内容---------------------------------------------------------------------------------------向表格中插入数据-----------------------------------------go--向bbsUsers(用户表插入数据)--insert intobbsUsers(Uname,Upassword,Uemail,Usex,Uclass,Uremark,Ustate,Upoint) values('天天','123456','zhong@','女',2,'我们的家乡在希望的田野上',3,100)insert intobbsUsers(Uname,Upassword,Uemail,Usex,Uclass,Uremark,Ustate,Upoint) values('可卡因','HYXS007','ss@','女',1,'我要去公安局自首',1,200) insert intobbsUsers(Uname,Upassword,Uemail,Usex,Uclass,Uremark,Ustate,Upoint) values('心酸果冻','888888','yy@','男',2,'牵匹瘦马闯天涯',2,600)insert intobbsUsers(Uname,Upassword,Uemail,Usex,Uclass,Uremark,Ustate,Upoint) values('冬篱儿','fangdong','bb@','女',3,'爱迷失在天堂',4,1200) insert intobbsUsers(Uname,Upassword,Uemail,Usex,Uclass,Uremark,Ustate,Upoint) values('Supper','master','dd@','女',5,'BBS大斑竹',1,500)--向bbsSection(版块表插入数据)--insert into bbsSection(Sname,SmasterID,Sprofile,SclickCount,StopicCount) values('Java技术核心',3,'包含框架,开源',500,1)insert into bbsSection(Sname,SmasterID,Sprofile,SclickCount,StopicCount) values('.Net技术',5,'包含C#,ASP',800,1)insert into bbsSection(Sname,SmasterID,Sprofile,SclickCount,StopicCount) values('Linux/Unix社区',5,'包含系统维护运行',0,0)--向bbsTopic(主贴表)插入数据--insert intobbsTopic(TsID,TuID,TreplyCount,Tface,Ttopic,Tcontents,TclickCount,Tstate,T lastReply)values(1,3,3,1,'还是JAVA','JAVA文件如何读取',200,1,'2008-8-1')insert intobbsTopic(TsID,TuID,TreplyCount,Tface,Ttopic,Tcontents,TclickCount,Tstate,T lastReply)values(2,2,1,2,'.NET文件部署','项目包含、WINFROM',0,1,'2007-8-5')--向bbsReply(跟贴表)插入数据--insert into bbsReply(RtID,RsID,RuID,Rface,Rcontents,RclickCount)values(1,1,5,2,'JAVA中乱码问题怎么解决好?',100)insert into bbsReply(RtID,RsID,RuID,Rface,Rcontents,RclickCount)values(1,1,4,4,'你好你好我们我们',200)insert into bbsReply(RtID,RsID,RuID,Rface,Rcontents,RclickCount)values(1,1,4,4,'呵呵哈哈嘿嘿西西',200)insert into bbsReply(RtID,RsID,RuID,Rface,Rcontents,RclickCount)values(2,1,4,4,'JSP文件转换',200)insert into bbsReply(RtID,RsID,RuID,Rface,Rcontents,RclickCount)values(2,1,4,4,'啊大安定大安定',200)---------------------------------------------------以上为各表格插入测试数据------------------------------------------------------------------------------------------------查询数据库情况-------------------------------------------print 'SQL Server的版本是:'+@@versionprint 'SQL Server的服务器名称是:'+@@servername--------------------------------------------------------------------------------------------------------------------------------------------------------------------系统变量查询上一条语句错误--------------------------------------update bbsUsers set Upassword = '1234' where Uname = '天天'print '执行上条语句产生错误: '+convert(varchar(5),@@error) --输出上一条语句的错误信息----------------------------------------------------------------------------------------------------------------------------------------------------------------------查询用户天天的信息---------------------------------------------set nocount on --不打印影响的信息----查询个人信息--print '天天个人信息如下'select Uname,Uremark,Upoint from bbsUsers where Uname = '天天'--用变量存储ID查询信息--declare @id int --声明变量--select @id = UID from bbsUsers where Uname = '天天' --将bbsUsers表中的UID字段赋值给id变量--print '发贴情况如下'selectconvert(varchar(10),Ttime,111),TclickCount,Ttopic,Tcontents,TclickCount,Tco ntents from bbsTopic where TuID = @idprint '回贴情况如下'select convert(varchar(10),Rtime,111),RclickCount,Rcontents from bbsReplywhere RuID = @idif(@id > 30) --if判断--print '有权发贴' --条件为真输出--else --否则--print '无权发贴' --输出-----------------------------------------------------------------------------------------------------------------------------------------------------------查询心酸果冻用户发贴回帖显示级别---------------------------------------------声明变量用于存储用户ID--declare @uNameID int--声明变量用于存储用户发贴数量--declare @count int--声明变量用于存储用户回帖数量--declare @count1 int--将心酸果冻用户的ID号存到变量@uNameID中--select @uNameID = UID from bbsUsers where Uname = '心酸果冻'--用count统计函数将用户的发贴数量存到变量@count中--select @count = count(*) from bbsTopic where TuID = @uNameID--输出--print '心酸果冻发贴数量为:' + convert(varchar(10),@count)print ''print '具体内容如下:'--显示信息,判断用户发贴数量大于0时显示帖子的信息--if(@count > 0)select Ttime as 发贴时间,TclickCount as 点击率,Ttopic as 主题,Tcontents as 内容from bbsTopic where TuID = @uNameID--用count统计函数将用户的回贴数量存到变量@count1中--select @count1 = count(*) from bbsReply where RuID = @uNameID--输出--print '心酸果冻的回帖数量为: '+convert(varchar(10),@count1)--显示信息,用户回帖数量大于0时显示帖子信息--if(@count1 > 0)select Rtime as 回帖时间,RclickCount as 点击数量,Rcontents as 回帖内容from bbsReply where RuID = @uNameID--判断用户的等级--if((@count + @count1) < 10)print '心酸果冻贴数总计为: '+convert(varchar(10),@count + @count1)+' 功臣级别为: 新手上路'if(((@count + @count1) >= 10) and ((@count + @count1) < 20))print '心酸果冻贴数总计为: '+convert(varchar(10),@count + @count1)+' 功臣级别为: 侠客'if(((@count + @count1) >= 20) and ((@count + @count1) < 30))print '心酸果冻贴数总计为: '+convert(varchar(10),@count + @count1)+' 功臣级别为: 骑士'if(((@count + @count1) >= 30) and ((@count + @count1) < 40))print '心酸果冻贴数总计为: '+convert(varchar(10),@count + @count1)+' 功臣级别为: 精灵王'if(((@count + @count1) >= 40) and ((@count + @count1) < 50))print '心酸果冻贴数总计为: '+convert(varchar(10),@count + @count1)+' 功臣级别为: 光明使者'if((@count + @count1) >= 50)print '心酸果冻贴数总计为: '+convert(varchar(10),@count + @count1)+' 功臣级别为: 法老'----------------------------------------------------------------------------------------------------------------------------------------------------------回帖最多的为精华贴-----------------------------------------------------------声明整形变量用于存储主贴编号,和作者编号--declare @tidid intdeclare @zhuzheid intdeclare @huifu int--将主贴标号存到@tidid变量中--select top 1 @tidid = TID from bbsTopic order by TreplyCount desc--将用户编号存到@zhuzheid变量中--select @zhuzheid = TuID from bbsTopic where TID = @tidid--输出--print '第一精华贴的信息如下:'--查出回贴最多的主贴,(用户表与主贴表两表连查)--select Ttime as 发贴时间,TclickCount as 点击率,Uname as 作者,Ttopic as 主题,Tcontents as 内容from bbsTopicinner join bbsUserson bbsUsers.UID = bbsTopic.TuIDwhere bbsUsers.UID = @zhuzheid and bbsTopic.TID = @tidid--为了美观输出空行--print ''--利用@tidid(主贴编号)变量查出回复数量存到@huifu变量中--select @huifu = TreplyCount from bbsTopic where TID = @tidid--输出--print '回帖数量'+convert(varchar(10),@huifu)+',如下所示:'--查询回帖信息--select Rtime as 回帖时间,RclickCount as 点击率,回帖表情= case--case多分之语句判断回帖表情--when Rface = 1 then '~(00)~猪头'when Rface = 2 then '*:0)小丑'when Rface = 3 then '[:|]机器人'when Rface = 4 then '{~0~0~}老人家'when Rface = 5 then '(:<)吹水大王'end,Rcontents as 回帖内容from bbsReply where RtID = @tidid-----------------------------------------------------------------------------------------------------------------/*实现:1、论坛人气,点击率>1000为“人气熊旺旺”,否则为“一般般”2、年度品牌版块:主贴量最多的版块3、年度倒胃版块:主贴量最少的版块4、年度回帖人气最旺奖:回帖的点击率排名前2名5、年度最差斑竹:版块点击率低于500或主贴等于0-------------------------------------------------*/--1、论坛人气,点击率>1000为“人气熊旺旺”,否则为“一般般”--print '---->>>>各位大虾注意了,本论坛即将发布年度奖项<<<<----'if(select sum(SclickCount) from bbsSection) > 1000print '论坛人气评估: 人气熊旺旺大家辛苦了'elseprint '论坛人气评估: 一般般,大家加油了'--2、年度品牌版块:主贴量最多的版块--print '年度最佳版块'select Sname as 版块名称,StopicCount as 主贴数量,Sprofile as 简介from bbsSectionwhere StopicCount = (select max(StopicCount) from bbsSection)--3、年度倒胃版块:主贴量最少的版块--print '年度倒胃版块'select Sname as 版块名称,StopicCount as 主贴数量,Sprofile as 简介from bbsSectionwhere StopicCount = (select min(StopicCount) from bbsSection)--4、年度回帖人气最旺奖:回帖的点击率排名前2名--print '年度回帖人气最旺的前两位'select Uname as 大名,Uclass as 星级from bbsUsers where uid in(select top 2 TuID from bbsTopic order by TclickCount desc)--5、年度最差斑竹:版块点击率低于500或主贴等于0--if exists(select * from bbsSection where StopicCount = 0 or SclickCount <= 500)beginprint '请以下斑竹加油哦'select Sname as 版块名称,StopicCount as 主贴数量,SclickCount as 点击率from bbsSectionwhere StopicCount = 0 or SclickCount <= 500end-----------------------------------------------------------------------------------------------------------------*-------------------------------------------用户发主贴---------------------------------------------------------*/--声明变量存放用户ID和版块ID--declare @id intdeclare @bankuai int--将发贴人心酸果冻的ID存到变量@id中--select @id = UID from bbsUsers where Uname = '心酸果冻'--将版块编号放入@bankuai变量中--select @bankuai = SID from bbsSection where Sname like '%.Net%'--将发贴内容插入到主贴表--insert into bbsTopic(TsID,TuID,Tface,Ttopic,Tcontents)values(@bankuai,@id,3,'什么是.Net啊?','我靠!微软的.Net广告超过半个北京城啊....')--更新主贴表,.Net技术版块主贴数加1--update bbsSection set StopicCount = StopicCount + 1 where SID = @bankuai --更新用户积分,如果是新主题则积分加100否则加50分--if not exists(select * from bbsTopic where Ttopic like '什么是.Net啊?' and TuID <> @id)update bbsUsers set Upoint = Upoint + 100 where UID = @idelseupdate bbsUsers set Upoint = Upoint + 50 where UID = @id--更新积分后更新级别--update bbsUsers set Uclass = casewhen Upoint < 500 then 1when Upoint between 500 and 1000 then 2when Upoint between 1001 and 2000 then 3when Upoint between 2001 and 4000 then 4when Upoint between 4001 and 5000 then 5else 6end--所有用户等级从新排名--select 妮称= Uname,星级= casewhen Uclass = 0 then ' 'when Uclass = 1 then '★'when Uclass = 2 then '★★'when Uclass = 3 then '★★★'when Uclass = 4 then '★★★★'when Uclass = 5 then '★★★★★'else '★★★★★★'end,积分= Upoint from bbsUsers------------------------------------------------------------------------------------------------------------------/*----------------------跟贴----------------------------------------------------------------*/--声明变量用于存放回帖人编号及主贴ID--declare @GTid intdeclare @ZTid intdeclare @BKid int--获得可卡因的编号--select @GTid = UID from bbsUsers where Uname = '可卡因'--获得主贴的编号--select @ZTid = TID from bbsTopic where Ttopic like '%什么是.Net%'--获得版块编号--select @BKid = SID from bbsSection where Sname like '%.Net%'--插入回帖内容--insert into bbsReply(RtID,RsID,RuID,Rface,Rcontents)values(@ZTid,@BKid,@GTid,2,'.NET是微软极力推崇的企业级信息网络共享平台.')--回帖后主贴回复数量加1,点击率加1--update bbsTopic set TreplyCount = TreplyCount + 1,TclickCount = TclickCount + 1 where TID = @ZTid--回帖后相应的版块点击率加1--update bbsSection set SclickCount = SclickCount + 1 where SID = @BKid--回帖后给用户加分,如果是第一个回帖加100分,否则加50分--if ((select top 1 RuID from bbsReply where RtID = @ZTid order by Rtime) = @GTid)update bbsUsers set Upoint = Upoint + 100 where UID = @GTidelseupdate bbsUsers set Upoint = Upoint + 50 where UID = @GTid--更新用户相应的信息--update bbsUsers set Uclass = casewhen Upoint < 500 then 1when Upoint between 500 and 1000 then 2when Upoint between 1001 and 2000 then 3when Upoint between 2001 and 4000 then 4when Upoint between 4001 and 5000 then 5else 6end--发布主贴和跟贴--select 主贴作者= '心酸果冻',主贴发布时间= convert(varchar(10),Ttime,111),主题= Ttopic,内容= Tcontentsfrom bbsTopic where TID = @@identityselect 回帖作者= '可卡因',回帖时间= convert(varchar(10),Rtime,111),回帖内容= Rcontentsfrom bbsReply where RID = @@identity--星级从新排名--select 妮称= Uname,星级= casewhen Uclass = 0 then ' 'when Uclass = 1 then '★'when Uclass = 2 then '★★'when Uclass = 3 then '★★★'when Uclass = 4 then '★★★★'when Uclass = 5 then '★★★★★'else '★★★★★★'end,积分= Upoint from bbsUsers-----------------------------------------------------------------------------------------------------------------/*------------------------------------------删除帖子-----------------------------------------------------------*/--声明变量用于存放回帖人编号及主贴ID--declare @GTid intdeclare @BZid intdeclare @ZTid intdeclare @BKid int--获得斑竹心酸果冻的编号--select @BZid = UID from bbsUsers where Uname = '心酸果冻'--获得主贴的编号--select @ZTid = TID from bbsTopic where Ttopic like '%什么是.Net%'--获得所有回帖人的编号--select @GTid = RuID from bbsReply where RtID = @ZTid--获得版块编号--select @BKid = SID from bbsSection where Sname like '%.Net%'--被删帖的斑竹心酸果冻减去积分100分--update bbsUsers set Upoint = Upoint - 100 where UID = @BZid--回贴的帖主均减积分50分--update bbsUsers set Upoint = Upoint - 50 where UID = @GTid--帖子所在版块的主贴量减1--update bbsSection set StopicCount = StopicCount - 1 where SID = @BKid --如果回帖数量大于10给予严重警告,否则给予警告--if((select TreplyCount from bbsTopic where TID = @ZTid) > 10)print '影响很坏,给予严重警告一次'elseprint '给予警告一次'--开始删除,先删除跟贴在删除主贴--delete from bbsReply where RtID = @ZTiddelete from bbsTopic where TID = @ZTid--重新排名--update bbsUsers set Uclass = casewhen Upoint < 500 then 1when Upoint between 500 and 1000 then 2when Upoint between 1001 and 2000 then 3when Upoint between 2001 and 4000 then 4when Upoint between 4001 and 5000 then 5else 6end--重新星级排名--select 妮称= Uname,星级= casewhen Uclass = 0 then ' 'when Uclass = 1 then '★'when Uclass = 2 then '★★'when Uclass = 3 then '★★★'when Uclass = 4 then '★★★★'when Uclass = 5 then '★★★★★'else '★★★★★★'end,积分= Upoint from bbsUsers-----------------------------------------------------------------------------------------------------------------select * from bbsUsersselect * from bbsSectionselect * from bbsTopicselect * from bbsReply。
BBS论坛数据库设计文档

第1章绪论随着互联网日益深入社会生活,BBS开发技术发展至今,从CGI,ASP,到PHP已经日趋成熟,功能也更加丰富,但携着Sun公司的Java技术所实现的“一次编写,到处运行”的优势,继承这一衣钵的JSP技术越来越受到人们的注视。
BBS作为一种对外的展示窗口,进行内外信息交流,已成为大众的广泛需要。
为了进行更好的交流,用户想就自己的专业和爱好能和其他的用户进行及时专业的交流,这就有了论坛,这样以来我们就可以在网络这个虚拟的空间中方便地实现交流,BBS论坛是我们在这个地球村中生活的重要交流工具。
所以我选择使用JSP开发BBS论坛这一课题作为毕业设计。
Java是未来的主流开发技术,具有很多优势。
JSP则是Java在Internet/Intranet Web上的重要应用技术,得到了广泛的支持和承认,它可以和各种Java技术完好地结合在一起,从而实现非常复杂的应用。
本网站使用JSP + Mysql在MyEclipse系统开发的,从而创建一个更为稳定,高效,安全的运行环境。
本文主要实现了基于B/S模式的一种JSP论坛的设计与实现,主要功能是实现客户端和服务器端的动态交互。
BBS论坛系统最基本的功能首先是发表主题,其次是其他人员根据主题发表自己的看法。
此外,为了记录主题的发表者和主题的加复者信息民,系统还需要提供用户注册和登录的功能。
只有注册的用户登录后才能够发表和回复主题,浏览者(游客)只能浏览主题信息。
根据用户的需求及以上的分析,BBS论坛需要具备以下功能:显示各论坛类别及版面、查看自己发表的帖子、搜索帖子、查看根帖内容、用户注册、用户登录、用户留言、发表帖子、回复帖子、进入后台、论坛类别管理、版面管理、用户管理和用户注册。
设计BBS论坛系统所要考虑的问题主要有如何通过资源文件显示文字和使用静态代码块。
设计中力求界面友好、简洁,易于操作。
代码部分尽量避免逻辑错误,算法设计简单合理,尽量使程序具有较好的可读性,有利于其他的设计者对程序的阅读;力求对数据库操作的安全与稳定,尽量避免数据库操作异常,并要保证查询的快速无误。
BBS论坛数据库设计

任务五 使用Servlet实现BBS论坛
数据库设计汪燕本节ຫໍສະໝຸດ 标完成BBS论坛数据库设计
6.1.3 BBS论坛数据库设计
论坛数据库中主要包括四张表,分别是:
用户信息表(Userinfo): 表中记录注册用户名与登录口令 论坛版块表(Board): 表中存储着论坛中版块的标题名称与版块的ID 论坛主帖表(Topic): 表中记录了某个版块中的所有主题帖相关信息,其中通过BoardID与版块 建立了主从关系 论坛回帖表(Reply): 表中记录了针对某个主题帖发表的评论意见,通过TopicID与主题帖建立 了主从关系
6.1.3 BBS论坛数据库设计
BBS结构设计

永远在一起论坛2.0版(数据库结构设计) Bbs_MenuBig(论坛大类菜单表) 数据类型 长度 默认值 Int 4 主键,自动编号 Varchar 50 text 16 Varchar 200 Varchar 100 Int 4 0 DateTime 8 getdate() Bbs_MenuSmall(论坛小类菜单表) 数据类型 长度 默认值 Int 4 主键,自动编号 Varchar 50 Varchar 200 Varchar 500 Varchar 100 Int 4 0 DateTime 8 getdate() int 4 0 int 4 0 int 4 0 int 4 0 int 4 0 int 4 0 Bbs_Post(论坛帖子表) 长度 默认值 4 主键,自动编号 200 16 4 0 8 getdate() 4 0 50 4 0 4 0 4 0 4 0 8 getdate() 4 0 4 0
字段名称 User_Id User_Name User_Pwd User_Ask User_Answer User_Email User_Adddate User_Qx User_Online User_Ip User_LoginDate User_LoginCount
数据类型 int varchar varchar varchar varchar varchar datetime int int varchar datetime int
字段名称 UserState_Id UserState_PostCount UserState_BackCount UserState_ClassicCount UserState_Exp
BBS论坛系统设计--数据库课程设计

《数据库系统原理》课程设计报告BBS论坛系统设计一、问题描述与要求为了给同学们提供一个信息交流的平台,使同学们能够在论坛上发表一些新消息,使同学们能够在论坛上讨论一些专业知识,以通过BBS系统来和别人讨论计算机软件、硬件、Internet、多媒体、程序设计等等各种有趣的话题,更可以利用BBS系统来刊登一些“征友”、“廉价转让”及“电子产品”等启事。
而且BBS用户还可以相互之间交换各种文件。
只需简单地把文件置于BBS系统,其它用户就可以极其方便地下载这些文件。
为同学提供了很大的方便。
二、系统分析本系统分为注册模块,登录模块,浏览帖子模块,回复帖子模块,阅读帖子内容模块等几大模块。
注册模块:在登录论坛之前首先会检查该用户是不是全法用户,即是不是已经注册过,如果没有注册,则不能进行发表文章,只能浏览等有受限的功能,只有注册为合法用户后才能具有应用的各项功能。
登录模块:在进行浏览和回复帖子等操作之前要先进行登录,否则不能进行一些相关的操作,不能成为一个合法的用户。
浏览模块:进入该模块后就可以看到别人发表的各个帖子标题,对自己感兴趣的主题可以进行发表自己的意见,进行与其他人讨论相关的问题。
浏览详细内容模块:该模块是用来打开相关帖子的详细内容,对相关主题的内容都是显示在该模块中。
新建主题:该模块是用来发表自己的新帖子,建立一个自己的讨论的焦点。
别人可以对你发表的主题进行讨论参与。
回复帖子:该模块是对自己已经看到的帖子进行发表自己的观点进行的一个模块,在内容可以对以上主题进行回复相应的内容。
个人信息:用来查看和修改自己的个人相关的信息。
三、数据库设计3.1 数据结构的设计数据库在一个信息管理系统中占有非常重要的地位,数据库结构设计的好坏将直接对应用系统的效率以及实现的效果产生影响。
合理的数据库结构设计可以提高数据存储的效率,保证数据库的完整和一致。
同时,合理的数据库结构也将有得程序的实现。
1.数据库需求分析用户的需求具体体现在各种信息的提供、保存、更新和查询方面,这就要求数据库结构能充分满足各种信息的输出和输入。
BBS论坛数据库设计 及ER图

2.2.1 用户 E-R 图
UID
Uname
UEmail
UBirtheday
Usex
BBSUsers
Uclass 2.2.2 主贴 E-R 图
UStatement
URegDate
UPoint UState
TID
TSID
TUID
TReplyCount
TEmotion
BBSTopic
说明 主帖编号 主帖版块编号 主帖用户编号 主帖回复次数 主帖表情 主帖标题 主帖内容 发帖时间 主帖点击次数 主帖最后点击时间
表 1-3-3
BBSSection 板块信息
表中列名
数据类型
sid
Int
SName
char
SMasterID
Int
SStatement
Varchar
SClickCount
Int
说明 版块编号
Sname SMasterID SStatement SClickCount STopicCount
Char Int varchar Int int
Not null Not null Not null Not null Not null
版块名称 版块编号 板块说明 版块点击次数 板块主题数
第二章 概要设计
2.1 基本概念介绍
⑴实体:现实世界中的各种事物的抽象。实体可以是具体的各种事物,如学生、教师、仓 库、图书馆等;也可以是抽象的概念,如课程、部门、学校等。
⑵联系:两个实体集之间的联系。可以分为三类: ①一对一联系(1:1) 如果对于实体集 A 中的每一个实体,实体集 B 中最多有一个实体与之联系,反之亦然,则 称实体集 A 和实体集 B 具有一对一联系,记作 1:1。 ②一对多联系(1:n) 如果对于实体集 A 中的每一个实体,实体集 B 中最多有 n(n≧1)个实体与之联系,对于实 体集 B 中的每一个实体,实体集 A 中最多有一个实体与之联系,则称实体集 A 和实体集 B 具有 一对多联系,记作 1:n。 ③多对多联系(m:n) 如果对于实体集 A 中的每一个实体,实体集 B 中最多有 n(n≧1)个实体与之联系,对于实 体集 B 中的每一个实体,实体 A 中最多有 m(m≧1)个实体与之联系,则称实体集 A 和实体集 B 具有多对多联系,记作 m:n。 ⑶属性:描述实体特征或性质。如学生实体的属性有:学号、姓名、性别、年龄等。课程 实体的属性有:课程号、课程名、学分等。
BBS论坛管理数据库数据库的设计与实现(ppt文档)

--插入数据
insert into
bbsSection(Sname,SmasterID,Sprofile,SclickCount,StopicCount) values('Java技术',3,'包含框架,开源,非技术区,J2SE',500,1)
insert into
bbsSection(Sname,SmasterID,Sprofile,SclickCount,StopicCount) values('.Net技术',5,'包含C#,ASP,.NET Framework,Web
BBSTopic发主贴表
BBSReply回贴表
表间关系图
提出任务
BBS论坛管理数据库的设计 BBS论坛管理数据库的实现
阶段一、插入测试数据
--插入测试数据 insert into bbsReply (RTID,RSID,RUID,RFace,RContents,RTime,RClickCount) values (1,1,5,2,'jsp乱码问题该怎么解决最好,因为我发现这 个问题好象在好多地方都看见了',getdate(),100) insert into bbsReply (RTID,RSID,RUID,RFace,RContents,RTime,RClickCount) values (1,1,4,4,'转换jsp..',getdate(),200) insert into bbsReply (RTID,RSID,RUID,RFace,RContents,RTime,RClickCount) values (2,2,2,3,'.net很精彩,就像ppmm啊!',getdate(),200)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
武汉理工大学华夏学院课程设计报告书课程名称:数据库原理与应用题目:BBS论坛数据库设计开发系名:信息工程系专业班级:计网2093班姓名:王博学号: 10225509314指导教师:刘春燕2011 年 7 月 1 日课程设计任务书学生姓名:王博专业班级:计网2093指导教师:刘春燕工作单位:信息工程系设计题目:BBS论坛数据库设计开发要求完成的主要任务:(包括课程设计工作量及其技术要求,以及说明书撰写等具体要求)1.创建数据库 BBS,数据表,并建立主外键、约束、建立表测试数据;2.创建视图3.实现以下功能:(1)简单查询;(2)连接查询;(3)嵌套查询;(4)创建触发器;(5)创建存储过程;+设计报告撰写格式要求:1、明确课程设计的目的和重要性,认真领会课程设计的题目,读懂课程设计指导书的要求,学会设计的基本方法与步骤,学会如何运用前修知识与收集、归纳相关资料解决具体问题的方法。
严格要求自己,要独立思考,按时、独立完成课程设计任务。
2、设计报告:要求层次清楚、整洁规范、不得相互抄袭,凡正文内容有整段完全相同者一律以抄袭论处。
设计报告正文字数不少于0.2万字(不包括附录)时间安排:消化资料、系统调查 1天系统分析、总体设计,实施计划、撰写报告3天演示、验收 1天指导教师签字:2011年7 月 1 日系主任签字:2011 年7 月 1 日课程设计报告书第一章需求分析1.1 BBS的功能与应用需求1.1.1BBS的功能论坛又名BBS,全称为Bulletin Board System(电子公告板)或者Bulletin Board Service(公告板服务)。
它是Internet上的一种电子信息服务系统。
它提供一块公共电子白板,每个用户都可以在上面书写,可发布信息或提出看法。
它是一种交互性强,内容丰富而即使的电子信息服务系统。
用户在BBS站点上可以获得各种信息服务、发布信息、进行讨论、聊天等等。
像日常生活中的黑板报一样,论坛按不同的主题分为许多版块,版面的设立依据是大多数拥护的要求和喜好,用户可以阅读别人关于某个主题的看法,也可以将自己的想法毫无保留地帖到论坛中。
随着计算机网络技术的不断发展,BBS论坛的功能越来越强大,目前BBS的主要功能有以下几点:(1) 供用户自我选择阅读若干感兴趣的专业组和讨论组内的信息。
(2) 可随意检查是否有新消息发布并选择阅读。
(3) 用户可在站点内发布消息或文章供他人查阅。
(4) 用户可就站点内其他人的消息或文章进行评论。
(5) 同一站点内的用户互通电子邮件, 设定好友名单1.1.2应用需求现实生活中的交流存在时间和空间上的局限性,交流人群范围的狭小,以及间断的交流,不能保证信息的准确性和可取性。
因此,用户需要通过网上论坛也就是BBS的交流扩大交流面,同时可以从多方面获得自己的及时需求。
同时信息时代迫切要求信息传播速度加快,局部范围的信息交流只会减缓前进的步伐。
BBS系统的开发能为分散于五湖四海的人提供一个提供一个共同交流、学习、倾吐心声的平台,实现来自不同地方用户的极强的信息互动性,用户在获得自己所需要的信息的同时也可以广交朋友拓展自己的视野和扩大自己的社交面。
1.2需求设计根据BBS的功能与应用需求的简要介绍,可以得出设计BBS系统所要的基本实体有BBSUser(用户)、BBSSection(版块)、BBSTopic(主贴)、BBSReply(回复贴)。
1.3数据字典表1-3-1BBSUsers 用户信息表表1-3-2BBSTopic主贴信息表格表1-3-3BBSSection板块信息表1-3-4BBSReply回帖信息表第二章概要设计2.1基本概念介绍⑴实体:现实世界中的各种事物的抽象。
实体可以是具体的各种事物,如学生、教师、仓库、图书馆等;也可以是抽象的概念,如课程、部门、学校等。
⑵联系:两个实体集之间的联系。
可以分为三类:①一对一联系(1:1)如果对于实体集A中的每一个实体,实体集B中最多有一个实体与之联系,反之亦然,则称实体集A和实体集B具有一对一联系,记作1:1。
②一对多联系(1:n)如果对于实体集A中的每一个实体,实体集B中最多有n(n≧1)个实体与之联系,对于实体集B中的每一个实体,实体集A中最多有一个实体与之联系,则称实体集A和实体集B 具有一对多联系,记作1:n。
③多对多联系(m:n)如果对于实体集A中的每一个实体,实体集B中最多有n(n≧1)个实体与之联系,对于实体集B中的每一个实体,实体A中最多有m(m≧1)个实体与之联系,则称实体集A和实体集B具有多对多联系,记作m:n。
⑶属性:描述实体特征或性质。
如学生实体的属性有:学号、姓名、性别、年龄等。
课程实体的属性有:课程号、课程名、学分等。
2.2实体E-R图2.2.1用户E-R图2.2.2主贴E-R图2.2.3版块E-R图2.2.4回帖E-R图2.3实体总体E-R图3.2实体联系图第三章详细设计3.1程序设计3.1.1创建数据库create database BBSon primary(name = BBS_data, --逻辑名filename ='d:\BBS_data.mdf', --物理文件size = 20MB, --初始大小filegrowth=10%, --文件增长率maxsize = 200MB --初始大小)log on(name =bbs_log, --逻辑名filename ='d:\bbs_data.ldf', --物理文件size =10mb, --初始大小filegrowth = 10%,--文件增长率maxsize = 100MB --最大尺寸)3.1.2创建用户表create table BBSUsers(UID int constraint pk_UID primary key,--用户编号UName char(8) not null, --用户姓名UPassword char(16) constraint df_UPassword default '888888',--用户密码UEmail char(20) not null constraint ck_Uemail check(UEmail like'%@%.%'),--用户Email UBirthday datetime not null,--用户生日Usex int constraint df_Usex default '1', --用户性别UClass int constraint df_UClass default '1', --用户等级UStatement varchar(150)not null, --用户说明URegDate datetime not null default getdate(), --用户注册时间UState tinyint constraint df_UState default '1', --用户状态UPoint int constraint df_UPoint default '20' , --用户积分constraint ck_UPassword check(UPassword like '______'))3.1.3创建版块表create table BBSSection(SID int constraint pk_SID primary key,--版块编号SName char(20),--版块名称SMasterID int, --版主编号SStatement varchar(100), --版块说明SClickCount int constraint df_SClickCount default '0', --版块点击次数STopicCount int constraint df_STopicCount default '0' --版块主题数)3.1.3创建主贴表create table BBSTopic(TID int constraint pk_tid primary key, --主贴编号TSID int not null, --主贴板块编号TUID int not null, --主贴用户编号TReplyCount int not null, --主贴回复次数TEmotion char(10) not null, --主贴表情TTopic varchar(16) not null CONSTRAINT ck_TTopic check(TTopic not like'%''%'), --主贴标题TContents text not null, --主贴内容TTime datetime not null default getdate() ,--发帖时间TClickCount int not null, --主贴点击次数TLastClickT datetime not null ,CONSTRAINT [CK_TLC] CHECK ([TLastClickT]>=TTime) --主贴最后点击时间)3.1.4创建回复贴表create table BBSReply(RID int constraint pk_RID primary key,--回复编号RTID int,--回复帖子编号RSID int,--回复版块编号RUID int,--回复用户编号REmotion char(10),--回复表情RTopic varchar(20),--回帖主题RContents text,--回帖内容RTime datetime default getdate(),--回帖时间RClickCount int,--回帖点击次数)3.1.5创建各表之间的联系--建立联系alter table BBSTopicadd constraint fk1_BBSTopic_BBSUsers foreign key(tuid) references BBSUsers(UID) --一个用户可以发表多篇主帖内容alter table BBSReplyadd constraint fk1_BBSReply_BBSTopic foreign key(RTID) references BBSTopic(TID) --一篇主帖能够对应多条回帖alter table BBSReplyadd constraint fk1_BBSReply_BBSUsers foreign key(RUID) references BBSUsers(UID) --一个用户可以发表多条回帖内容alter table BBSTopicadd constraint fk1_BBSTopic_BBSSection foreign key(TSID) references BBSSection(SID) --一个版块可以包含多篇主帖alter table BBSReplyadd constraint fk1_BBSReply_BBSSection foreign key(RSID) references BBSSection(SID) --一个版块可以包含多篇回帖alter table BBSSectionadd constraint fk1_BBSSection_BBSUsers foreign key(SMasterID) references BBSUsers(UID) --一个用户可以管理多个版块3.1.6插入用户信息(注册新用户)insertintoBBSUsers(UID,UName,UPassword,UEmail,UBirthday,USex,UClass,UStatement,URegDate,USta te)values('1001' ,'无敌游客','159357','auroral@','1991-5-12','1','','疯子','2010-5-7','2')insertintoBBSUsers(UId,UName,UPassword,UEmail,UBirthday,USex,UClass,UStatement,URegDate,UStat e,UPoint)values('1002' ,'熬吧马','654321','shanhu@','1989-8-30','1','','爱吧','2011-4-7','2','25') insertintoBBSUsers(UID,UName,UPassword,UEmail,UBirthday,USex,UClass,UStatement,URegDate,USta te,UPoint)values('1003' ,'真伪遢','158664','cookie@','1992-1-3','2','','快乐','2009-5-7','2','103') insertintoBBSUsers(UID,UName,UPassword,UEmail,UBirthday,USex,UClass,UStatement,URegDate,USta te,UPoint)values('1004' ,'地球字幕','175175','ibook@','1990-7-4','2','','自我','2008-5-4','2','2') insertintoBBSUsers(UID,UName,UPassword,UEmail,UBirthday,USex,UClass,UStatement,URegDate,USta te,UPoint)values('1005' ,'无伤大雅','198755','ipd123@','1988-1-4','1','','和谐','2000-12-12','1','100')insertintoBBSUsers(UID,UName,UPassword,UEmail,UBirthday,USex,UClass,UStatement,URegDate,USta te,UPoint)values('1006' ,'回来吧主','192445','zhenmi@','1994-12-14','2','','低调','2000-12-12','1','97')insertinto BBSSection(SID,SName,SMasterID,SStatement,STopicCount)values('01' ,'灌水区','1006','有什么您就说','5')insertinto BBSSection(SID,SName,SMasterID,SStatement,SClickCount,STopicCount)values('02' ,'魔兽贴吧','1005','请不要放水贴!','4','10')3.1.8发帖insertintoBBSTopic(TID,TSID,TUID,TReplyCount,TEmotion,TTopic,TContents ,TTime,TClickCount,TLa stClickT)values('001' ,'01','1005','5',''-~','无聊来冒个泡的。