求生之路是由风靡全球的模组游戏《反恐精英》的开发商VALVE公司开发的新作。游戏主题是下单机游戏中非常流行的丧尸题材动作射击游戏。然而与大部分同类题材游戏或影视作品截然不同的是,在本作中,玩家并非扮演一个冲入丧尸群中如入无人之境的孤胆英雄,而是要扮演一名为了求得最后一丝生存的曙光奋起斗争的普通人,玩家是一名恐怖灾难后的幸存者,为了逃出生天而拿起手中的武器与死神做殊死搏斗。值得一提的是,玩家在游戏中并非孤军奋战,通过Xbox Live玩家还可以与好友组队合作进行挑战,这也算是在一定程度上降低了玩家穿越充满丧尸的恐怖城市时的孤独与恐惧。
玩家要和其他幸存者角色(共四人)一起合作,逃离被病毒感染的区域并对抗沿路上的感染者。玩家要根据提示逃到下一个安全的地方(安全室),到达指定地点后便要抵抗不断来袭的僵尸,直到救援的来临以离开疫区。
游戏有四种难度可供选择(容易、一般、进阶和专家)。游戏还设有“成就”供玩家解开,只要玩家能完成成就列表中的要求(如:单独战胜tank,完成所有“专家”难度的战役一次),就可以解开成就并记录在游戏中。
目前游戏模式有四种:
求生之路2将于09年11月17日发售,登陆PC/XBOX360平台。
关于二代
· 场景设在美国南部,起始于乔治亚州的萨凡纳,最后一路杀到路易斯安那的新奥尔良
· 五个新关卡(同时适用于对抗模式及合作通关)
· 新的幸存者造型及全新人物配音Coach是萨凡纳某个高中校队的橄榄球教练;Rochelle来自克利夫兰,为一家有线新闻网工作,僵尸潮爆发时她正在萨凡纳制作节目;Ellis是名典型的南方小子,机修工出身;Nick,赌徒兼老千,履历不详,对这些意外牢骚满腹
· 新的特殊感染者,比如Charge及Wandering Witch等
Charge像是Tank与普通感染者的杂合体,拥有一只极为粗壮的变异胳膊,一记重击就能让玩家飞出老远;目前还看不出普通感染者有什么进化,唯一值得注意的是某些普通感染者被防护服包裹,这意味莫洛托夫燃烧瓶对它们不再有效,它们能穿过火墙直扑过来;防护服的弱点在于护目镜容易被爆头所产生的汁液遮蔽。
顾名思义,Wandering Witch不再规规矩矩地盘坐在地上等着你绕过她,现在她四处逡巡游荡,或许与你不期而遇,或是跟在你身后,哼着咿咿呀呀的小曲等着被你激怒。
· 新增近战武器(平底煎锅、棒球棍、消防斧、链锯)及q械(新的霰dq、自动步q、狙击步q)
· 新的可捡拾游戏物品
· 改进型AI Director及地图动态调节
“两面夹攻(Gauntlets)”模式是游戏新增的SM成份,意在为玩家带来更多让人心惊肉跳的游戏体验。比如在关卡的最后阶段,玩家被迫通过一座长铁桥,路途漫漫且毫无遮蔽,只能被AI Director任意蹂躏——像原作那样就地结阵是行不通的,最好是在车辆残骸上跳来跳去,两人挥舞煎锅在前开路,一人负责殿后,逐步推进到获救地点
配置要求
最低配置
*** 作系统: Microsoft Windows XP / Vista /windows7
CPU: Intel Pentium 4 3+GHz
内存: 1GB
显卡: NVIDIA GeForce 6 系列 6600/ ATI 9600 (及更高)
硬盘空间: 75 GB
*** 作模式: 键盘鼠标
PS:最好全特效调最低要不FPS上不去你就哭了
推荐配置
*** 作系统: Microsoft Windows XP / Vista
CPU: Intel Core 2 Duo 24 GHz
内存: 2 GB
显卡: nVidia GeForce 7600 or ATI X1600 (及更高)
硬盘空间: 75 GB
*** 作模式: 键盘鼠标
*** 作指南
首先主界面 Options -> Keyboard/Mouse -> Allow Developers Console
(选项-> 键盘/鼠标- >允许开启控制台)
然后游戏中按 ~ 开启控制台,输入 Sv_Cheats 1 回车确认开启秘籍模式。
最后游戏中按 ~ 开启控制台,输入以下秘籍回车确认可得到对应效果
god 1 无敌
noclip 穿墙
sv_infinite_ammo 1 无限d药
give pistol 手q
give pumpshotgun 散dq
give autoshotgun 连散
give rifle M4/M16
give smg 乌兹
give hunting_rifle 狙击
give pipe_bomb 土制炸d
give molotov 燃烧瓶
give oxygentank 氧气瓶
give propanetank 煤气罐
give gascan 油桶
give pain_pills 药瓶
give first_aid_kit 急救包
give health 满血100
give ammo d药
z_spawn hunter(创造Hunter)
z_spawn smoker(创造smoker)
z_spawn boomer (创造boomer)
z_spawn tank (创造tank)
z_spawn witch(创造witch)
ent_fire !self setteam 1 变目击者
ent_fire !self setteam 2 变幸存者
ent_fire !self setteam 3 被感染
changelevel 地图名 快速改变地图
give物品名 制造指定物品(武器等等)
nb_blind 1 让僵尸看不到你,不过碰到僵尸的话他们还是会发现你
nb_delete_all 清除所有被感染的头目及幸存者
z_add 增加一只僵尸在游戏中
z_spawn bossname 增加一只Boss怪物,bossname分别是:
tank, boomer, smoker, witch, hunter
cl_drawhud 0 消除抬头状态列HUD
r_drawviewmodel 0 使你的武器隐形
sv_lan 0 启用Internet网络;
在 "Campaign Lobby" 界面开启
map地图名 启动网络服务器;
在 "Campaign Lobby" 界面开启
openserverbrowser 显示可用的服务器
OP命令全解释
rcon_password 获得OP权限 (=OP密码)
rcon sv_password 锁上服务器
rcon sv_password '' 解锁服务器
rcon changelevel 地图名 立即换地图,所有玩家不退出
rcon map 地图名 立即立即换地图,所有玩家退出
z_difficulty "Easy" 游戏难度简单
z_difficulty "Normal" 正常
z_difficulty "Hard" 困难
z_difficulty "Impossible" 专家
下面列出游戏目前所有的游戏地图名称 方便大家使用(~直接复制粘贴-除掉bsp):
毫不留情
map l4d_hospital01_apartmentbsp (1公寓)
map l4d_hospital02_subwaybsp (2:地铁)
map l4d_hospital03_sewersbsp (3:下水道)
map l4d_hospital04_interiorbsp (4:医院)
map l4d_hospital05_rooftopbsp (5:屋顶终局)
死亡丧钟
map l4d_smalltown01_cavesbsp (1:收费公路)
map l4d_smalltown02_drainagebsp (2:水沟)
map l4d_smalltown03_ranchhousebsp (3:教堂)
map l4d_smalltown04_mainstreetbsp (4:小镇)
map l4d_smalltown05_houseboatbsp (5:船库终局)
静寂时分
map l4d_airport01_greenhousebsp (1:花房)
map l4d_airport02_officesbsp (2:起重机)
map l4d_airport03_garagebsp (3:建筑工地)
map l4d_airport04_terminalbsp (4:终点)
map l4d_airport05_runwaybsp (5:跑道终局)
血腥收获
map l4d_farm01_hilltopbsp (1:森林)
map l4d_farm02_traintunnelbsp (2:隧道)
map l4d_farm03_bridgebsp (3:桥)
map l4d_farm04_barnbsp (4:火车站)
map l4d_farm05_cornfieldbsp (5:农舍终局)
生存灯塔
map l4d_sv_lighthousebap (生存灯塔地图)
模式变更激活命令
mp_gamemode survival 激活生存模式
mp_gamemode coop 合作模式的命令,然后选一幅合作地图就行了。
mp_gamemode versus 对抗模式地图,然后选一副合作地图
>
系统故障,卸载重新安装。
《求生之路2》是由Valve开发的一款以丧尸为主题的恐怖射击类游戏,于2009年11月18日发行。
背景:
游戏故事发生的时间与原作几乎相同,将呈现另外四名幸存者在僵尸横行的四个场景中奋力求生的艰辛历程,地点及时间背景与当前的L4D一致,只不过角色是新角色,场景是同一地点的另一位面,敌人中也将出现新的僵尸,新的近战武器,新的对抗僵尸武器和电锯。
得到船长的帮助,四人终于到达新奥尔良。表面看来军方仍然在疏散幸存者,但当四人抵达疏散点才发现军方为了防止病毒进一步扩散,准备轰炸桥梁。最后四人成功摆脱大量的感染者,赶及在桥被炸毁之前逃进安全区域。
开秘籍方法:进游戏后用"~"键打开控制台,然后输入baisv_cheats 1 回车打开控制台,然后把你想要的秘籍代码打在控制台上。
输入以下秘籍即可:
god 1 无敌
noclip 穿墙
sv_infinite_ammo 1 无限d药不换d夹
give health 满血100
give ammo d药
give adrenaline 肾上腺素针
give defibrillator 电震仪器
give first_aid_kit 医药包
give pain_pills 药丸
获得燃烧子d upgrade_add Incendiary_ammo
获得爆炸子d upgrade_add explosive_ammo
获得激光瞄准 upgrade_add laser_sight
give adrenaline 肾上腺素针
give defibrillator 电震仪
give first_aid_kit 医药包
give pain_pills 阵痛药
give gascan 汽油红桶
give propanetank 煤气罐
give oxygentank 氧气瓶
give pipe_bomb 土制炸d
give molotov 燃烧瓶
give vomitjar 胆汁瓶
give autoshotgun 1代的连发霰dq
give shotgun_spas 2代的连发霰dq
give pumpshotgun 1代的单发霰dq
give shotgun_chrome 2代的单发霰dq
give hunting_rifle 1代的半自动狙击步q
give sniper_military 2代的半自动狙击步q
give rifle M16步q
give rifle_m60 m60机q 需求生2追加内容许可
give rifle_ak47 AK47步q
give rifle_desert SCAR步q
give smg 小型冲锋q
give smg_silenced 消声冲锋q
give pistol 手q
give pistol_magnum 玛格南手q
give weapon_grenade_launcher 获得榴d发射器
give crowbar 铁撬棍(仅限第1、2、4大关战役可用)
give fireaxe 斧头(仅限第1、2、4大关战役可用)
give katana 倭刀(武士刀)(仅限第1、2、4大关战役可用)
give golfclub 高尔夫球杆 需求生2追加内容许可
give chainsaw 电锯
give cricket_bat 板球棒(仅限第1、3大关战役可用)
give baseball_bat 棒球棍(不可用或未知)
give frying_pan 平底锅(仅限第3、4、5大关战役可用)
give electric_guitar 吉他(仅限第2、5大关战役可用)
give tonfa 警棍(仅限第5大关战役可用)
give machete 砍刀(仅限第3、5大关战役可用)
give weapon_upgradepack_explosive 爆炸子d升级铁盒
give weapon_upgradepack_incendiary 燃烧子d升级铁盒
give melee 猎人僵尸的手
give weapon_gnome 圣诞老人
give weapon_fireworkcrate 一盒烟花
(2)隐藏武器
以下隐藏武器重新读取地图才有伤害
give weapon_sniper_awp AWP/M大型狙击q
give weapon_sniper_scout Scout小型狙击q
give weapon_smg_mp5 MP5冲锋q
give weapon_rifle_sg552 SIG SG552步q
(3)其他
melee_range 70 (预设为70)近战武器的伤害范围 (数值越高能砍得越远)
sb_dont_bash 1 电脑控制的幸存者都不能用q托攻击
sb_dont_shoot 1 电脑控制的幸存者不能开q
sb_takecontrol 人物之间切换(代表Ellis,Nick,Rochelle,Coach也可以不要后缀为随机切换)
sb_move 0 所有电脑控制的幸存者停止移动
sb_escort 1 所有电脑控制的幸存者保护你紧跟在你身边
sb_open_fire 1 所有电脑控制的幸存者不停的开火
sb_crouch 1 所有电脑控制的幸存者蹲下
sb_flashlight 1 所有电脑控制的幸存者使用手电筒(-1为强制不用手电筒)
sb_give 给所有电脑控制的幸存者一个道具或武器(代码详细看上面)
sb_give_random_weapon 给所有电脑控制的幸存者随机分配一把武器
cl_showfps (改为1=显示帧数和地图名 2=显示帧数和平滑率 3=服务器信息 4=显示帧数和日志文件)
thirdpersonshoulder 第三人称模式(再次输入可还原为第一人称)
nb_delete_all 踢掉所有电脑控制的幸存者和附近的感染者和所有的特殊特殊感染者(暂时性的感染者还是会刷出)
nb_blind 1 所有电脑控制的感染者都看不到你(但是撞到感染者还是会攻击你)
cl_drawhud 0 关闭所有的界面包括准星(真实模式)
(4)感染者
z_add 创造一个普通感染者
z_spawn jockey 创造一个Jockey
z_spawn charger 创造一个Charger
z_spawn spitter 创造一个Spitter
z_spawn hunter 创造一个Hunter
z_spawn smoker 创造一个Smoker
z_spawn boomer 创造一个Boomer
z_spawn tank 创造一个Tank
z_spawn witch 创造一个Witch
z_speed 250 普通感染者的移动速度(数值越大速度越快)
z_health 50 普通感染者的生命值 (数值越大生命值越长)
z_tank_health 4000 Tank的生命值 (数值越大生命值越长)
z_tank_speed 210 Tank的移动速度 (数值越大移动速度越快)
z_witch_speed 300 Witch的移动速度 (数值越大移动速度越快)
z_witch_health 1000 Witch的生命值 ((数值越大生命值越长)
z_witch_damage 100 Witch的伤害值 (100为直接打倒在地低于100我没试过)
z_exploding_health 50 Boomer的生命值 (数值越大生命值越大)
z_exploding_speed 175 Boomer的移动速度 (数值越大移动速度越快)
z_gas_health Smoker的生命值 (数值越大生命值越长)
z_gas_speed Smoker的移动速度 (数值越大移动速度越快)
z_hunter_health 250 Hunter的生命值 (数值越大生命值越长)
z_hunter_speed 300 Hunter的移动速度 (数值越大移动速度越长
z_spitter_health 100 Spitter的生命值 (数值越大生命值越长)
z_spitter_speed 210 Spitter的移动速度 (数值越大移动速度越快)
z_charger_health 600 Charger的生命值 (数值越大 生命值越快)
z_charge_max_speed Charger的移动速度 (数值越大移动速度越快)
z_charge_max_damage Charger的摔击伤害 (数值越大伤害越大)
z_jockey_health 325 Jockey的生命值 (数值越大生命值越长)
z_jockey_speed 250 Jockey的移动速度 (数值越大移动速度越快)
z_jockey_ride_damage Jockey的每秒伤害 (数值越大伤害越大)
z_special_spawn_interval 45 刷特殊感染者的时间间隔
(数值越大刷特殊感染者的时间间隔越长)
:
使用“MAP”命令开启战役,单人战役无法使用秘籍(MAP 建图命令在第二页 直接跳到第二页)。
使用秘籍前在控制台输入“Sv_Cheats 1”开启作弊。(成功后会有提示信息 Server cvar 'sv_cheats' changed to 1 )
百度百科---求生之路2
数据库设计(Database Design)是指对于一个给定的应用环境,构造最优的数据库模式,建立数据库及其应用系统,使之能够有效地存储数据,满足各种用户的应用需求(信息要求和处理要求)。
在数据库领域内,常常把使用数据库的各类系统统称为数据库应用系统。
一、数据库和信息系统
(1)数据库是信息系统的核心和基础,把信息系统中大量的数据按一定的模型组织起来,提供存储、维护、检索数据的
功能,使信息系统可以方便、及时、准确地从数据库中获得所需的信息。
(2)数据库是信息系统的各个部分能否紧密地结合在一起以及如何结合的关键所在。
(3)数据库设计是信息系统开发和建设的重要组成部分。
(4)数据库设计人员应该具备的技术和知识:
数据库的基本知识和数据库设计技术
计算机科学的基础知识和程序设计的方法和技巧
软件工程的原理和方法
应用领域的知识
二、数据库设计的特点
数据库建设是硬件、软件和干件的结合
三分技术,七分管理,十二分基础数据
技术与管理的界面称之为逗干件地
数据库设计应该与应用系统设计相结合
结构(数据)设计:设计数据库框架或数据库结构
行为(处理)设计:设计应用程序、事务处理等
结构和行为分离的设计
传统的软件工程忽视对应用中数据语义的分析和抽象,只要有可能就尽量推迟数据结构设计的决策早期的数据库设计致力于数据模型和建模方法研究,忽视了对行为的设计
如图:
三、数据库设计方法简述
手工试凑法
设计质量与设计人员的经验和水平有直接关系
缺乏科学理论和工程方法的支持,工程的质量难以保证
数据库运行一段时间后常常又不同程度地发现各种问题,增加了维护代价
规范设计法
手工设计方
基本思想
过程迭代和逐步求精
规范设计法(续)
典型方法:
(1)新奥尔良(New Orleans)方法:将数据库设计分为四个阶段
SBYao方法:将数据库设计分为五个步骤
IRPalmer方法:把数据库设计当成一步接一步的过程
(2)计算机辅助设计
ORACLE Designer 2000
SYBASE PowerDesigner
四、数据库设计的基本步骤
数据库设计的过程(六个阶段)
1需求分析阶段
准确了解与分析用户需求(包括数据与处理)
是整个设计过程的基础,是最困难、最耗费时间的一步
2概念结构设计阶段
是整个数据库设计的关键
通过对用户需求进行综合、归纳与抽象,形成一个独立于具体DBMS的概念模型
3逻辑结构设计阶段
将概念结构转换为某个DBMS所支持的数据模型
对其进行优化
4数据库物理设计阶段
为逻辑数据模型选取一个最适合应用环境的物理结构(包括存储结构和存取方法)
5数据库实施阶段
运用DBMS提供的数据语言、工具及宿主语言,根据逻辑设计和物理设计的结果
建立数据库,编制与调试应用程序,组织数据入库,并进行试运行
6数据库运行和维护阶段
数据库应用系统经过试运行后即可投入正式运行。
在数据库系统运行过程中必须不断地对其进行评价、调整与修改
设计特点:
在设计过程中把数据库的设计和对数据库中数据处理的设计紧密结合起来将这两个方面的需求分析、抽象、设计、实现在各个阶段同时进行,相互参照,相互补充,以完善两方面的设计
设计过程各个阶段的设计描述:
如图:
五、数据库各级模式的形成过程
1需求分析阶段:综合各个用户的应用需求
2概念设计阶段:形成独立于机器特点,独立于各个DBMS产品的概念模式(E-R图)
3逻辑设计阶段:首先将E-R图转换成具体的数据库产品支持的数据模型,如关系模型,形成数据库逻辑模式;然后根据用户处理的要求、安全性的考虑,在基本表的基础上再建立必要的视图(View),形成数据的外模式
4物理设计阶段:根据DBMS特点和处理的需要,进行物理存储安排,建立索引,形成数据库内模式
六、数据库设计技巧
1 设计数据库之前(需求分析阶段)
1) 理解客户需求,询问用户如何看待未来需求变化。让客户解释其需求,而且随着开发的继续,还要经常询问客户保证其需求仍然在开发的目的之中。
2) 了解企业业务可以在以后的开发阶段节约大量的时间。
3) 重视输入输出。
在定义数据库表和字段需求(输入)时,首先应检查现有的或者已经设计出的报表、查询和视图(输出)以决定为了支持这些输出哪些是必要的表和字段。
举例:假如客户需要一个报表按照邮政编码排序、分段和求和,你要保证其中包括了单独的邮政编码字段而不要把邮政编码糅进地址字段里。
4) 创建数据字典和ER 图表
ER 图表和数据字典可以让任何了解数据库的人都明确如何从数据库中获得数据。ER图对表明表之间关系很有用,而数据字典则说明了每个字段的用途以及任何可能存在的别名。对SQL 表达式的文档化来说这是完全必要的。
5) 定义标准的对象命名规范
数据库各种对象的命名必须规范。
2 表和字段的设计(数据库逻辑设计)
表设计原则
1) 标准化和规范化
数据的标准化有助于消除数据库中的数据冗余。标准化有好几种形式,但Third Normal Form(3NF)通常被认为在性能、扩展性和数据完整性方面达到了最好平衡。简单来说,遵守3NF 标准的数据库的表设计原则是:逗One Fact in One Place地即某个表只包括其本身基本的属性,当不是它们本身所具有的属性时需进行分解。表之间的关系通过外键相连接。它具有以下特点:有一组表专门存放通过键连接起来的关联数据。
举例:某个存放客户及其有关定单的3NF 数据库就可能有两个表:Customer 和Order。Order 表不包含定单关联客户的任何信息,但表内会存放一个键值,该键指向Customer 表里包含该客户信息的那一行。
事实上,为了效率的缘故,对表不进行标准化有时也是必要的。
2) 数据驱动
采用数据驱动而非硬编码的方式,许多策略变更和维护都会方便得多,大大增强系统的灵活性和扩展性。
举例,假如用户界面要访问外部数据源(文件、XML 文档、其他数据库等),不妨把相应的连接和路径信息存储在用户界面支持表里。还有,如果用户界面执行工作流之类的任务(发送邮件、打印信笺、修改记录状态等),那么产生工作流的数据也可以存放在数据库里。角色权限管理也可以通过数据驱动来完成。事实上,如果过程是数据驱动的,你就可以把相当大的责任推给用户,由用户来维护自己的工作流过程。
3) 考虑各种变化
在设计数据库的时候考虑到哪些数据字段将来可能会发生变更。
举例,姓氏就是如此(注意是西方人的姓氏,比如女性结婚后从夫姓等)。所以,在建立系统存储客户信息时,在单独的一个数据表里存储姓氏字段,而且还附加起始日和终止日等字段,这样就可以跟踪这一数据条目的变化。
字段设计原则
4) 每个表中都应该添加的3 个有用的字段
dRecordCreationDate,在VB 下默认是Now(),而在SQL Server • 下默认为GETDATE()
sRecordCreator,在SQL Server 下默认为NOT NULL DEFAULT • USER
nRecordVersion,记录的版本标记;有助于准确说明记录中出现null 数据或者丢失数据的原因 •
5) 对地址和电话采用多个字段
描述街道地址就短短一行记录是不够的。Address_Line1、Address_Line2 和Address_Line3 可以提供更大的灵活性。还有,电话号码和邮件地址最好拥有自己的数据表,其间具有自身的类型和标记类别。
6) 使用角色实体定义属于某类别的列
在需要对属于特定类别或者具有特定角色的事物做定义时,可以用角色实体来创建特定的时间关联关系,从而可以实现自我文档化。
举例:用PERSON 实体和PERSON_TYPE 实体来描述人员。比方说,当John Smith, Engineer 提升为John Smith, Director 乃至最后爬到John Smith, CIO 的高位,而所有你要做的不过是改变两个表PERSON 和PERSON_TYPE 之间关系的键值,同时增加一个日期/时间字段来知道变化是何时发生的。这样,你的PERSON_TYPE 表就包含了所有PERSON 的可能类型,比如Associate、Engineer、Director、CIO 或者CEO 等。还有个替代办法就是改变PERSON 记录来反映新头衔的变化,不过这样一来在时间上无法跟踪个人所处位置的具体时间。
7) 选择数字类型和文本类型尽量充足
在SQL 中使用smallint 和tinyint 类型要特别小心。比如,假如想看看月销售总额,总额字段类型是smallint,那么,如果总额超过了$32,767 就不能进行计算 *** 作了。
而ID 类型的文本字段,比如客户ID 或定单号等等都应该设置得比一般想象更大。假设客户ID 为10 位数长。那你应该把数据库表字段的长度设为12 或者13 个字符长。但这额外占据的空间却无需将来重构整个数据库就可以实现数据库规模的增长了。
8) 增加删除标记字段
在表中包含一个逗删除标记地字段,这样就可以把行标记为删除。在关系数据库里不要单独删除某一行;最好采用清除数据程序而且要仔细维护索引整体性。
3 选择键和索引(数据库逻辑设计)
键选择原则:
1) 键设计4 原则
为关联字段创建外键。 •
所有的键都必须唯一。 •
避免使用复合键。 •
外键总是关联唯一的键字段。 •
2) 使用系统生成的主键
设计数据库的时候采用系统生成的键作为主键,那么实际控制了数据库的索引完整性。这样,数据库和非人工机制就有效地控制了对存储数据中每一行的访问。采用系统生成键作为主键还有一个优点:当拥有一致的键结构时,找到逻辑缺陷很容易。
3) 不要用用户的键(不让主键具有可更新性)
在确定采用什么字段作为表的键的时候,可一定要小心用户将要编辑的字段。通常的情况下不要选择用户可编辑的字段作为键。
4) 可选键有时可做主键
把可选键进一步用做主键,可以拥有建立强大索引的能力。
索引使用原则:
索引是从数据库中获取数据的最高效方式之一。95%的数据库性能问题都可以采用索引技术得到解决。
1) 逻辑主键使用唯一的成组索引,对系统键(作为存储过程)采用唯一的非成组索引,对任何外键列采用非成组索引。考虑数据库的空间有多大,表如何进行访问,还有这些访问是否主要用作读写。
2) 大多数数据库都索引自动创建的主键字段,但是可别忘了索引外键,它们也是经常使用的键,比如运行查询显示主表和所有关联表的某条记录就用得上。
3) 不要索引memo/note 字段,不要索引大型字段(有很多字符),这样作会让索引占用太多的存储空间。
4) 不要索引常用的小型表
不要为小型数据表设置任何键,假如它们经常有插入和删除 *** 作就更别这样作了。对这些插入和删除 *** 作的索引维护可能比扫描表空间消耗更多的时间。
4 数据完整性设计(数据库逻辑设计)
1) 完整性实现机制:
实体完整性:主键
参照完整性:
父表中删除数据:级联删除;受限删除;置空值
父表中插入数据:受限插入;递归插入
父表中更新数据:级联更新;受限更新;置空值
DBMS对参照完整性可以有两种方法实现:外键实现机制(约束规则)和触发器实现机制
用户定义完整性:
NOT NULL;CHECK;触发器
2) 用约束而非商务规则强制数据完整性
采用数据库系统实现数据的完整性。这不但包括通过标准化实现的完整性而且还包括数据的功能性。在写数据的时候还可以增加触发器来保证数据的正确性。不要依赖于商务层保证数据完整性;它不能保证表之间(外键)的完整性所以不能强加于其他完整性规则之上。
3) 强制指示完整性
在有害数据进入数据库之前将其剔除。激活数据库系统的指示完整性特性。这样可以保持数据的清洁而能迫使开发人员投入更多的时间处理错误条件。
4) 使用查找控制数据完整性
控制数据完整性的最佳方式就是限制用户的选择。只要有可能都应该提供给用户一个清晰的价值列表供其选择。这样将减少键入代码的错误和误解同时提供数据的一致性。某些公共数据特别适合查找:国家代码、状态代码等。
5) 采用视图
为了在数据库和应用程序代码之间提供另一层抽象,可以为应用程序建立专门的视图而不必非要应用程序直接访问数据表。这样做还等于在处理数据库变更时给你提供了更多的自由。
5 其他设计技巧
1) 避免使用触发器
触发器的功能通常可以用其他方式实现。在调试程序时触发器可能成为干扰。假如你确实需要采用触发器,你最好集中对它文档化。
2) 使用常用英语(或者其他任何语言)而不要使用编码
在创建下拉菜单、列表、报表时最好按照英语名排序。假如需要编码,可以在编码旁附上用户知道的英语。
3) 保存常用信息
让一个表专门存放一般数据库信息非常有用。在这个表里存放数据库当前版本、最近检查/修复(对Access)、关联设计文档的名称、客户等信息。这样可以实现一种简单机制跟踪数据库,当客户抱怨他们的数据库没有达到希望的要求而与你联系时,这样做对非客户机/服务器环境特别有用。
4) 包含版本机制
在数据库中引入版本控制机制来确定使用中的数据库的版本。时间一长,用户的需求总是会改变的。最终可能会要求修改数据库结构。把版本信息直接存放到数据库中更为方便。
5) 编制文档
对所有的快捷方式、命名规范、限制和函数都要编制文档。
采用给表、列、触发器等加注释的数据库工具。对开发、支持和跟踪修改非常有用。
对数据库文档化,或者在数据库自身的内部或者单独建立文档。这样,当过了一年多时间后再回过头来做第2 个版本,犯错的机会将大大减少。
6) 测试、测试、反复测试
建立或者修订数据库之后,必须用用户新输入的数据测试数据字段。最重要的是,让用户进行测试并且同用户一道保证选择的数据类型满足商业要求。测试需要在把新数据库投入实际服务之前完成。
7) 检查设计
在开发期间检查数据库设计的常用技术是通过其所支持的应用程序原型检查数据库。换句话说,针对每一种最终表达数据的原型应用,保证你检查了数据模型并且查看如何取出数据。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)