A. 数据库设计时,是使用多表格好还是少表格好呢
这要看你处理的对象、、表格尽量少、、但类别必须分清楚。。
B. 数据库设计时,表越多是不是越好呢
很明显不是,表的存在只为了业务的需要,甚至可以忽略三大范式,
分子表的原因在于 子表作为独立的实体存在,或者子表经常被更新或者修改
C. 在数据库设计时,存在多张表有关系时该怎么设计为最优
所谓的三范式了解就行,完全照做死得快
像你这种表,一定要先定义需求
比如用户有多个角色,就需要建立一个用户角色对应表
比如用户只有一个角色,那在用户表加个字段就行
另外最好不要弄什么外键之类的,原来我也弄,后来烦得要死,总是约束错误之类的,编个程序都不省心,结果全给去了,只要逻辑没有错误,数据就不会出错。
D. SQL中设计为一张表好还是二张表好
根绝情况而定吧。
如果你商品类别繁多,每种商品的属性繁多的话,还是用2张表吧。
一张表优点: 一条SQL语句解决问题,省事; 缺点是扩展性不强,结构性不强,层次性不强。
两张表的优点: 层次结构清晰,灵活性强; 缺点是有一定的数据冗余,SQL语句稍稍优点长,数据增删改比一个表稍微麻烦点。
E. 设计数据库时是设计表越少越好,还是越多越好
1,数据表与数据表之间有关联(Relationship)是肯定的,但是不一定要用外键(ForeignKey),为什么?外键本质是一种约束(Constraint),该约束决定了你在增删改查的时候都会有额外开销。【实际上数据库在处理外键的时候估计也是创建一个中间表根据中间表来做关联操作,完成后再删除】2,“对于“N对N”的关系,两个Model之间肯定是需要一张中间表的,比如Student、Class之间选课关系,是多对多的,肯定需要一张Enroll的表来维持,记录两个表的主键(PrimaryKey),但是不需要在数据库层加外键约束,只需要加两个索引,或作为联合主键。3,至于查询,尽量不用JOIN。但是问题是我确确实实是需要知道多个表的信息。比如我要知道某门课(Class,已知ID)的信息,同时还有选上该课(Enrolled)的学生信息(Student)。使用JOIN?没问题,我相信你可以写出一个很长的JOIN语句。但是,可能有的地方大概这样实现的(伪代码):getClassInfo(@class_id){SELECTclass_col1,class_col2FROMclassWHEREclass.id=@class_id}getStudentInfo(@class_id){SELECTstudent_col1,student_col2FROMstudentWHEREstudent.idIN(SELECTenroll.student_idFROMenrollWHEREenroll.class_id=@class_id)}两种方案各有优缺。后者最大的一个优点是灵活,比如我们引入缓存(Caching)。一般来说,一个学校class数量不多,并且经常被查询,系统可能会引入缓存层(如memcached、redis)来存放class对象。那么上面的getClassInfo其实会变为{if(memcached.has(@class_id)!=null){returnmemcached.get(@class_id);}//查询数据库(只有class表),和上面的SQL一样memcached.set(@class_id,class_object);returnclass_object;}
F. 请教:性能上,Access是一个数据库多个表好,还是多个数据库各自一个表好
当然在一个数据库多个表好,原因有三个:
1.多表联合查询方便
2.连接字符串用变量存储简单,增加运行效率,太多的连接路径占用系统内存,也容易造成溢出,你不好维护,每个连接都要求做异常处理麻烦不说还影响性能。
3.占用资源,ACCESS驱动器多开占用资源,本身ACCESS就是一个独占形式的数据库,你开发的软件也不能增加客户端。
完全可以测试一下,用两种方法连接分别做套程序,一起运行最小化到后台,查看一下任务管理器,占用内存大小一比较就可以知道答案了,我是觉得用ACCESS不如SQL,不支持多用户,跟一个数据库建多少表是没多大关系的,只要不超过他的阀值。
一库一表真的不是很好的办法,查询逻辑烦琐不说还及其消耗内存,真是数据量太大,那就早点用SQL,SQL可以把几个数据库整合在一起
G. 数据库表设计:用户单表(添加用户角色字段)还是多用户表(每种角色一个表)
如果你的用户和角色是多对多的关系,单表肯定是不行的!
H. 数据库的表越多越好吗还是能省就省
数据库的表的多少取决于设计阶段,也关系到整个应用系统的稳定和强壮。
根据项目逻辑以及数据三范式标准来设计,当然三范式可能相对苛刻,那么最好能保证二范式
来保证数据完整性,对后期需求扩张,维护起到至关重要的作用。
希望你能去认真的看看这方面的设计,对你会有用的
希望能帮到你