导航:首页 > 数据处理 > 数据库怎么设计

数据库怎么设计

发布时间:2022-02-25 17:53:24

数据库怎么设计呢

create table 角色表( 编号 int primary key identity(1,1) not null, 角色名称 varcahr(20) not null, 角色状态 int default(1))create table 用户表( 编号 int primary key identity(1,1) not null, 用户名称 varchar(20) not null, 用户密码 varchar(10) not null, 用户状态 int default(1))create table 权限表( 编号 int primary key identity(1,1) not null, 职权名称 varchar(30) not null, 状态 int default(1))create table 角色_权限( 编号 int primary key identity(1,1) not null, 角色编号 int foreign key references 角色表 not null, 权限编号 int foreign key references 权限表 not null, 状态 int default(1)
)create table 角色_用户( 编号 int primary key identity(1,1) not null, 角色编号 int foreign key references 角色表 not null, 用户编号 int foreign key references 用户表 not null, 状态 int default(1)
)没在SQL上写有些错了的话不好意识的咯,每张表都有状态,因为在表直接有约束,所以删除信息的时候很难删掉,如果要删掉的话就直接修改状态,0为有效,1为有效。

⑵ 数据库服务器怎么设计

我理解你问的是硬件,一般思路: 1.选平台:windows,linux还是unix 2.挑主机:哪个厂商,什么样的性能要求(TPCC,TPCH),什么样的RAS要求,什么特殊要求如分区、虚拟化等 3.搭架构:这个和你自身的应用以及选的数据库有关,比如oracle数据库,是单机单实例还是RAC或者其他方式 4.配存储:I/.O常常是数据库的瓶颈,要配合适的存储才能发挥服务器性能 当然理论设计还要看实际预算,暂时想到的,供你参考 蓝屏

⑶ 网站的数据库如何设计


什么是好的数据库设计?

一些原则可为数据库设计过程提供指导。第一个原则是,重复信息(也称为冗余数据)很糟糕,因为重复信息会浪费空间,并会增加出错和不一致的可能性。第二个原则是,信息的正确性和完整性非常重要。如果数据库中包含不正确的信息,任何从数据库中提取信息的报表也将包含不正确的信息。因此,基于这些报表所做的任何决策都将提供错误信息。

所以,良好的数据库设计应该是这样的:


设计过程

设计过程包括以下步骤:


参考:数据库设计基础

⑷ 数据库如何设计

数据库设计的基本步骤

按照规范设计的方法,考虑数据库及其应用系统开发全过程,将数据库设计分为以下6个阶段

1.需求分析

2.概念结构设计

3.逻辑结构设计

4.物理结构设计

5.数据库实施

6.数据库的运行和维护


数据库设计通常分为6个阶段1分析用户的需求,包括数据、功能和性能需求;2概念结构设计:主要采用E-R模型进行设计,包括画E-R图;3逻辑结构设计:通过将转换成表,实现从E-R模型到关系模型的转换;4:主要是为所设计的数据库选择合适的和存取路径;5数据库的实施:包括编程、测试和试运行;6数据库运行与维护:系统的运行与数据库的日常维护。),主要讨论其中的第3个阶段,即逻辑设计。



在数据库设计过程中,需求分析和概念设计可以独立于任何数据库管理系统进行,逻辑设计和物理设计与选用的DAMS密切相关。

1.需求分析阶段(常用自顶向下)

进行数据库设计首先必须准确了解和分析用户需求(包括数据与处理)。需求分析是整个设计过程的基础,也是最困难,最耗时的一步。需求分析是否做得充分和准确,决定了在其上构建数据库大厦的速度与质量。需求分析做的不好,会导致整个数据库设计返工重做。

需求分析的任务,是通过详细调查现实世界要处理的对象,充分了解原系统工作概况,明确用户的各种需求,然后在此基础上确定新的系统功能,新系统还得充分考虑今后可能的扩充与改变,不仅仅能够按当前应用需求来设计。

调查的重点是,数据与处理。达到信息要求,处理要求,安全性和完整性要求。

分析方法常用SA(Structured Analysis) 结构化分析方法,SA方法从最上层的系统组织结构入手,采用自顶向下,逐层分解的方式分析系统。

数据流图表达了数据和处理过程的关系,在SA方法中,处理过程的处理逻辑常常借助判定表或判定树来描述。在处理功能逐步分解的同事,系统中的数据也逐级分解,形成若干层次的数据流图。系统中的数据则借助数据字典(data dictionary,DD)来描述。数据字典是系统中各类数据描述的集合,数据字典通常包括数据项,数据结构,数据流,数据存储,和处理过程5个阶段。

2.概念结构设计阶段(常用自底向上)

概念结构设计是整个数据库设计的关键,它通过对用户需求进行综合,归纳与抽象,形成了一个独立于具体DBMS的概念模型。

设计概念结构通常有四类方法:

⑸ 怎么去设计一个数据库

第一:首先分析数据库应该包含几个表,每个表里面有多少项内容,这些需要根据数据库管理系统功能来说的!
第二:开始建立数据库表以及里面的字段
第三:就是数据库开发了
第四:功能的完善

建议你先分析一下都需要什么功能!然后在网络里面搜索一下!现在有很多现成的数据库管理系统的,直接下载一个根据你所需要的功能进行修改就可以了!

网上很多,如果自己开发太累,也没有那些高手开发的功能全的!

⑹ 怎么设计这个数据库

问这种问题通常都不容易说清楚,只能勉强做一下。要更清楚得详谈。
对于第2个问题:
分成:
一级类表:一级类id(主键),类名称 .....(描述,备注等字段),43条记录
二级类表:二级类id(主键),类名称 .....(描述,备注等字段),855条记录
属性表:属性id(主键),属性名称 .....(描述,备注等字段),6000条记录左右,这里我假设你的意思不是6000种属性值呢,而是6000种属性,不同产品规格型号不同。
下面的产品记录若理解为产品,而不是同一产品的不同个体都有一条记录。则
产品类型表:产品类型id(主键),产品名称(同一类型产品名字是一样的),属性1 id,属性1值,属性2 id,属性2值,属性3 id,属性3值 .....(描述,备注等非关键字段),220万条记录左右。其中属性id都是外键,和属性表关联。这不太符合实际:因为有220万种产品,似乎规模太大了。可能空间很浪费,因为如果某产品有最多100个属性,则其它产品记录中会有大量空属性,如果使用关系和XML混合数据库,可避免该问题,可是在检索中效率如何等方面需要仔细考虑。另外可能还需要考虑诸如生产厂家、销售者等问题,所以问题的规模不见得仅仅是这一点。
若是产品个体的记录,则:
产品类型表还是要的。然后
产品表:产品id(主键),其余诸如出厂日期,描述,备注等非关键字段。
对于第1个问题:
则是数据库优化问题,要根据数据库访问特点,包括提高硬件性能(更好的机器、服务器群集)、加适当索引、采用适当的并发机制等方式来解决问题。而且最好有一个具体需求,然后尽快测试系统原型是否满足要求,不满足就设法改进直到满足要求为止。

⑺ 论坛的数据库怎么设计

常用的论坛设计方法,总结如下:
一 分割思想:
1 数据库切分:用户库、主题库、回复库
2 数据表水平切分:用户库1-n、主题库1-n、回复库1-n (比如按时间分)
3 分布式数据库:每台计算机中都有DBMS的一份完整拷贝副本,并具有自己局部的数据库,位于不同地点的许多计算机通过网络互相连接,共同组成一个完整的、全局的大型数据库。
4 论坛功能可以进行分隔,不同的服务器负责不同的功能
5 用主从数据库,master是写, slave是读
6 把内容与其它信息分开,好处就是可以让每个表的文件最小化,对数据库操作压力会减小,这样保证每张表数据量很小,操作速度会快,也可以在这里使用缓存
二 索引:
针对是否建立索引有着一定的分歧:
我觉得建立索引还是很有必要的。理由如下:
1)建立索引可以加快检索速度,对于论坛读和写的比例相差很大,用户体验当然是读多写少,所以综合考虑还是要用索引,而且是加在常用的读关键字上。
2)索引之所以会降低更新的速度,是因为更新还包括对索引的更新,从更新帖子10万左右,这句话是说,我们可能对发帖标题,发帖内容,回复标题,回复内容这4个字段做更新。需要注意的是,这四个字段并不是用来建立表连接的字段,为了优化查询速度我们不会在这四个字段上建立索引,所以从这道题目出发,我们建立的索引不会影响更新帖子的性能。只要被索引的列(例如回复表的标题ID)不被频繁更新,即使索引所在地行的其它列被频繁update,索引也不会被更新从而产生性能消耗,一张表一天30万次的索引更新,因它引起的性能消耗小到即使数据库安装在奔腾3单核CPU下都能轻松承担下来。
3)对于更新的速度慢的问题,我们有解决的方法,你提交更新了后,前台可以让程序返回一个正确结果,后台开个线程异步慢慢跟新数据库就是了,反正更新成功的前提就是假设数据库连接永远正确并处于可靠状态。在数据库和用户之间建立一个缓冲区。(如,将更新的数据放到内存中,达到一定数量的时候再统一更新数据库。假如以100条为例,一旦内存中达到100条数据量将这100条数据统一入库。减少insert操作)

三 缓冲:
读的时候的缓冲:缓存路由表
主题缓存表(这个取每个区的前面100条记录),一般来说负载最大的就是主题的第一页,所以缓存表是个小表。

另外使用hibernate,在数据库上面加了一层缓存。
生成静态页,缓存最热,最新的帖子。
对于经常更新的数据都设计成单独表 ,这样可以最大程度的利用hibernate缓存
缓存常用的数据和表,利用缓存来将经常被访问的帖子留在内存中,为每条缓存的记录添加一个访问时间,如果长时间没被访问就从缓存中删除掉,
避免内存过大,每次用户看帖的时候,首先检索缓存中时候有需要的帖子,没有的话再访问数据库,然后将数据库返回的帖子信息存储到缓存中。

写的时候的缓冲:数据库和用户之间建立缓存,将更新的数据放在内存中,异步操作的。所有的写贴操作 放到一个队列然后批量执行插入数据库操作。

预估计的缓冲:假如用户第一次打开某标题,那将此标题的相关的前100条数据缓存到客户断。这样避开对数据库的直接查询,减少数据库压力。
四 代码优化
1尽量避免表的连接约束通过代码来实现约束 例如用户id的验证在用户登录时验证这样就可以把帖子表的用户id外键去掉这样就成了单表操作、查询 而连接可以通过触发来实现这样最多是查询了3个表而不是连接中的笛卡尔笛卡尔积 回复表的查询限定每次查询的记录数例如限定10条其它的通过点击触发来操作"注代码优化容易出现bug 原因有些开发工具本身有优化"
五 数据库性能调优
尽量用硬件来代替软件优化 原则就是能用硬件的尽量用硬件 比如磁盘阵列 RAID0 有条件用RAID10 加大内存 .避免小表上建索引 对论坛来说数据帖子和回复不是很重要 可以定期删除一些垃圾帖子 楼主说的几百万条记录的论坛对现在的数据库管理系统和计算机来说永不着刻意的优化,定期维护打包备份数据库就可以了
提高速度的关键:
1.建立合理的索引并在查询时充分利用;
2.避免使用关联,这样避免整表扫描;使用关联不如多次使用主键查询来的快;
3.一些处理的功能尽可能放到内存中来做,比如组织主题和回复;
4.海量缓存(使用静态页面也是个不错的做法)
5 定期对表进行转储

阅读全文

与数据库怎么设计相关的资料

热点内容
换季产品怎么玩 浏览:904
南充有哪些乡土菜市场 浏览:482
神州买买车代理费多少 浏览:993
夜游产品体系如何构建 浏览:142
怎么让公司的产品入驻自营超市 浏览:497
有什么祛痘印好的产品 浏览:67
刷脸支付技术在哪里 浏览:839
企业年审里的即时信息怎么填 浏览:381
消防产品公司如何管理物料 浏览:98
三无产品索赔依据是什么 浏览:202
期货开户用哪个交易所 浏览:107
如何打开施耐德程序 浏览:965
为什么要解析串口数据 浏览:757
本月收入数据填错怎么办 浏览:950
怎么修改疫情数据可视化的格式 浏览:799
北京卖狗的市场在哪里 浏览:826
平安的理财产品有哪些 浏览:129
现代产业技术创新包含什么 浏览:22
邢台滴滴市场到底怎么样 浏览:689
如何完善汽车信息 浏览:169