SQL Server 数据库设计

SQL Server 数据库设计,第1张

SQL Server 系统数据库在安装软件时自动创建,用于协助系统共同完成对数据库的 *** 作;也是数据库运行的基础;

1,master数据库

是SQL Server 2012的核心数据库,如果损坏则数据库软件无法运行,主要包含如下主要信息:

1)所有用户登陆名和用户ID所属角色

2)数据库存储路径

3)服务器中数据库的名称和相关信息

4)系统配置设置, SQL Server 初始化信息

2,model数据库

在创建数据库时,总是以一套预定义的标准为模板进行创建的。以model数据库为模板来创建其他数据库。且model数据库是tempdb数据库的基础。

3,tempdb数据库

它是一个临时数据库,用来存储用户建立的临时表和临时存储过程,存储用户定义的全局变量值。它存在于SQL Server会话期间,会话结束,则关闭tempdb数据库,且数据库丢失。

4,msdb数据库

用于代理计划警报和作业

SQL Server 数据库存储文件

数据库文件是由数据文件和事务日志文件组成。

1,数据库文件指数据库中用来存储数据库数据和数据库对象的文件,一个数据库只能由一个主数据库文件,扩展名为 mdf

2, 次数据库文件包含除主数据库文件外的所有数据文件,一个数据库可以没有次数据库文件,也可以由多个,扩展名为 ndf

3, 日志文件由一系列日志记录组成,它记录了存储数据库的更新情况等事务日志信息,用户对数据库进行的插入,删除,更新都会记录在日志文件中。数据库发生损坏时可根据日志文件分析出错原因,或者数据丢失时,使用事务日志恢复数据库。每个数据库至少要有一个日志文件。

SQL Server 数据库创建,使用T-SQL语言创建:

使用T-SQL语言删除数据库:

SQL Server 数据库迁移:

方法1:“分离/附加”数据库,即把数据库文件(MDF)和对应的日志文件(LDF)拷贝到其它磁盘上作备份,然后把这两个文件再拷贝到任何需要这个数据库的系统之中。

分离数据库就是将某个数据库从SQL Server数据库列表中删除,使其不再被SQL Server管理和使用,但该数据库的文件(MDF)和对应的日志文件(LDF)完好无损。分离成功后,就可以把该数据库文件(MDF)和对应的日志文件(LDF)拷贝到其它磁盘中作为备份保存。

分离之前,设置数据库为单个用户,并记住该数据库所在路径。

“任务”—“分离”

然后分离数据库页面选中“更新统计信息”复选框。若“消息”列中没有显示存在活动连接,则“状态”列显示为“就绪”;否则显示“未就绪”,此时必须勾选“删除连接”列的复选框。分离后资源管理器中数据库消失

将需要附加的数据库文件和日志文件拷贝到某个已经创建好的文件夹中。

右击数据库对象,并在快捷菜单中选择“附加”命令,打开“附加数据库”窗口。

添加—选择需要附件的数据库的MDF文件。“附件为”数据库名称可修改。

是的,数据库可以查看日志。数据库会记录所有对其进行的 *** 作和事件,这些记录被称为“日志”。数据库日志可以用于多种用途,例如:

恢复:如果数据库崩溃或发生其他问题,可以使用日志来还原数据库到崩溃前的状态。

故障排除:日志可以帮助确定发生故障的原因。如果数据库中的某些 *** 作失败了,可以查看日志以了解是哪个 *** 作出了问题。

安全审计:日志可以记录数据库中的所有活动,包括登录尝试、查询和更新 *** 作等。这些记录可以用于安全审计和法律合规性。

在大多数数据库系统中,可以使用特定的命令或工具来查看日志文件。例如,在MySQL中,可以使用“SHOW BINARY LOGS”命令来查看二进制日志文件。

用户表:{用户编号(PK),用户名,密码,用户类别, 所属专业号(FK)}

课程表:{课程编号(PK),课程名,用户编号(FK) ,学分}

院 系:{院系编号(PK),院名}

专 业:{专业号(PK),专业名称 ,专业简介 ,总学时,所属院号(FK)}

参考书:{索书号(PK),课程编号(FK),ISBN/ISSN,责任者,出版日期,校图书馆连接地址,电子书连接地址}

专业课程表{专业号,课程编号} 联合主键

系统库。数据库是用友的“系统库”,所有的账套信息、用户、权限等都是在这个数据库中保存,此数据库非常重要 UFPortal数据库是存放企业应用平台。能够完成一种或者几种生理功能的多个器官按照一定的次序组合在一起的结构叫做系统。

请检查一下数据库的系统日志表,看看哪个字段是主键或唯一索引,主键或唯一索引是不能重复插入的。

你更新的那几个字段,应该有某个字段是这种情况。

你可以将那个字段设为可重复索引,再在系统日志表中添加一个自增字段作为主键

祝你成功!

随着计算机技术越来越广泛地应用于国民经济的各个领域 在计算机硬件不断微型化的同时 应用系统向着复杂化 大型化的方向发展 数据库是整个系统的核心 它的设计直接关系系统执行的效率和系统的稳定性 因此在软件系统开发中 数据库设计应遵循必要的数据库范式理论 以减少冗余 保证数据的完整性与正确性 只有在合适的数据库产品上设计出合理的数据库模型 才能降低整个系统的编程和维护难度 提高系统的实际运行效率 虽然对于小项目或中等规模的项目开发人员可以很容易地利用范式理论设计出一套符合要求的数据库 但对于一个包含大型数据库的软件项目 就必须有一套完整的设计原则与技巧

一 成立数据小组

大型数据库数据元素多 在设计上有必要成立专门的数据小组 由于数据库设计者不一定是使用者 对系统设计中的数据元素不可能考虑周全 数据库设计出来后 往往难以找到所需的库表 因此数据小组最好由熟悉业务的项目骨干组成

数据小组的职能并非是设计数据库 而是通过需求分析 在参考其他相似系统的基础上 提取系统的基本数据元素 担负对数据库的审核 审核内容包括审核新的数据库元素是否完全 能否实现全部业务需求 对旧数据库(如果存在旧系统)的分析及数据转换 数据库设计的审核 控制及必要调整

二 设计原则

规范命名 所有的库名 表名 域名必须遵循统一的命名规则 并进行必要说明 以方便设计 维护 查询

控制字段的引用 在设计时 可以选择适当的数据库设计管理工具 以方便开发人员的分布式设计和数据小组的集中审核管理 采用统一的命名规则 如果设计的字段已经存在 可直接引用 否则 应重新设计

库表重复控制 在设计过程中 如果发现大部分字段都已存在 开发人员应怀疑所设计的库表是否已存在 通过对字段所在库表及相应设计人员的查询 可以确认库表是否确实重复

并发控制 设计中应进行并发控制 即对于同一个库表 在同一时间只有一个人有控制权 其他人只能进行查询

必要的讨论 数据库设计完成后 数据小组应与相关人员进行讨论 通过讨论来熟悉数据库 从而对设计中存在的问题进行控制或从中获取数据库设计的必要信息

数据小组的审核 库表的定版 修改最终都要通过数据小组的审核 以保证符合必要的要求

头文件处理 每次数据修改后 数据小组要对相应的头文件进行修改(可由管理软件自动完成) 并通知相关的开发人员 以便进行相应的程序修改

三 设计技巧

分类拆分数据量大的表 对于经常使用的表(如某些参数表或代码对照表) 由于其使用频率很高 要尽量减少表中的记录数量 例如 银行的户主账表原来设计成一张表 虽然可以方便程序的设计与维护 但经过分析发现 由于数据量太大 会影响数据的迅速定位 如果将户主账表分别设计为活期户主账 定期户主账及对公户主账等 则可以大大提高查询效率

索引设计 对于大的数据库表 合理的索引能够提高整个数据库的 *** 作效率 在索引设计中 索引字段应挑选重复值较少的字段 在对建有复合索引的字段进行检索时 应注意按照复合索引字段建立的顺序进行 例如 如果对一个 万多条记录的流水表以日期和流水号为序建立复合索引 由于在该表中日期的重复值接近整个表的记录数 用流水号进行查询所用的时间接近 秒 而如果以流水号为索引字段建立索引进行相同的查询 所用时间不到 秒 因此在大型数据库设计中 只有进行合理的索引字段选择 才能有效提高整个数据库的 *** 作效率

数据 *** 作的优化 在大型数据库中 如何提高数据 *** 作效率值得关注 例如 每在数据库流水表中增加一笔业务 就必须从流水控制表中取出流水号 并将其流水号的数值加一 正常情况下 单笔 *** 作的反应速度尚属正常 但当用它进行批量业务处理时 速度会明显减慢 经过分析发现 每次对流水控制表中的流水号数值加一时都要锁定该表 而该表却是整个系统 *** 作的核心 有可能在 *** 作时被其他进程锁定 因而使整个事务 *** 作速度变慢 对这一问题的解决的办法是 根据批量业务的总笔数批量申请流水号 并对流水控制表进行一次更新 即可提高批量业务处理的速度 另一个例子是对插表的优化 对于大批量的业务处理 如果在插入数据库表时用普通的Insert语句 速度会很慢 其原因在于 每次插表都要进行一次I/O *** 作 花费较长的时间 改进后 可以用Put语句等缓冲区形式等满页后再进行I/O *** 作 从而提高效率 对大的数据库表进行删除时 一般会直接用Delete语句 这个语句虽然可以进行小表 *** 作 但对大表却会因带来大事务而导致删除速度很慢甚至失败 解决的方法是去掉事务 但更有效的办法是先进行Drop *** 作再进行重建

数据库参数的调整 数据库参数的调整是一个经验不断积累的过程 应由有经验的系统管理员完成 以Informix数据库为例 记录锁的数目太少会造成锁表的失败 逻辑日志的文件数目太少会造成插入大表失败等 这些问题都应根据实际情况进行必要的调整

必要的工具 在整个数据库的开发与设计过程中 可以先开发一些小的应用工具 如自动生成库表的头文件 插入数据的初始化 数据插入的函数封装 错误跟踪或自动显示等 以此提高数据库的设计与开发效率

避免长事务 对单个大表的删除或插入 *** 作会带来大事务 解决的办法是对参数进行调整 也可以在插入时对文件进行分割 对于一个由一系列小事务顺序 *** 作共同构成的长事务(如银行交易系统的日终交易) 可以由一系列 *** 作完成整个事务 但其缺点是有可能因整个事务太大而使不能完成 或者 由于偶然的意外而使事务重做所需的时间太长 较好的解决方法是 把整个事务分解成几个较小的事务 再由应用程序控制整个系统的流程 这样 如果其中某个事务不成功 则只需重做该事务 因而既可节约时间 又可避免长事务

适当超前 计算机技术发展日新月异 数据库的设计必须具有一定前瞻性 不但要满足当前的应用要求 还要考虑未来的业务发展 同时必须有利于扩展或增加应用系统的处理功能

lishixinzhi/Article/program/SQL/201311/16498

有两种做法

1、在设计数据库的时候,带入时间戳和是否删除字段,新增、修改都要更新这个字段,除此之外,删除是伪删除,也要更新时间戳,然后记录上次的时间戳,就可以取出增量数据了

2、如果设计数据库时未有该内容,只能在加一个类似日志表的东西,记录了什么时候,哪个表,哪行数据,干什么了,然后从这里读取增量

系统登录表单pass设计(口令验证窗口设计)

1.系统登录表单设计界面

系统登录表单设计界面如图1所示。

图1 “系统登录表单”设计界面

2.功能及设计说明

用户在文本框输入 *** 作员及口令,若正确则调用系统主界面(菜单)。允许输入三次,若三次输入均不正确则自动退出系统。

若用户输入的 *** 作员姓名及口令正确,要完成下列工作:

(1)设置一个全局变量operat,用于记录登录系统的 *** 作员姓名,系统中有三个地方要用到该 *** 作员的姓名或代号:一是进入主界面后在标题栏显示 *** 作员姓名;二是 *** 作员在系统管理模块的口令设置中更改自己的口令时,系统要知道是哪个 *** 作员;三是退出系统时系统日志中要记录该 *** 作员的退出时间。

(2)在系统日志表logdbf中增加一条记录,并同时记录该 *** 作员登录系统的时间。

(3)从权限表menurightdbf中读出该 *** 作员对应各菜单项的权限,并赋值给数组。

(4)调用菜单文件,显示系统主界面。

3.属性设置

表11-11 “系统登录表单”属性设置

对象名 属性 属性值 说明

Form1 Caption 口令输入窗口 设置表单标题

AutoCenture T 表单自动居中

Height 230

Width 350

Label1 Caption 人事工资管理系统 设置标签显示内容

AutoSize T

FontBold T

FontName 楷体_GB2312

FontSize 24

ForeColor 0,128,255

BackStyle 0-透明

Label2 Caption *** 作员

AutoSize T

BackStyle 0-透明

Label3 Caption 口 令

AutoSize T

BackStyle 0-透明

Text1

Text2 PasswordChar 指定用作占位符的字符

InputMask 指定文本框中数据的输入格式

Command1 Caption 确 定

Command2 Caption 退 出

4.事件代码

(1)Form1的Init事件代码:

SET EXACT ON &&精确比较

PUBLIC ARRAY rr[18] &&数组用于实现菜单项权限

PUBLIC i &&i用于记录用户名及口令输入次数

PUBLIC operat &&operat用于保存 *** 作员姓名

i=0 &&使开始计数登录次数变量的值为0

THISFORMText1Setfocus &&使表单的Text1文本框获得焦点

(2)Form1的Unload事件代码:

RELEASE i

SET EXACT OFF

(3)Form1的QueryUnload事件代码:

RELEASE THISFORM

CLEAR EVENTS

QUIT

(4)“确定”按钮(Command1)Click事件代码:

判断密码是否正确

i=i+1

use \dbsystem\operatordbf

LOCATE FOR *** 作员姓名=ALLTRIM(THISFORMText1Value)

DO CASE

CASE i<=3 AND FOUND() AND THISFORMText2Value=operator口令

输入次数未超过3次且用户名正确、口令正确

operat=THISFORMText1Value

INSERT INTO \dbsystem\log( *** 作员代号, *** 作员姓名,登录时间) VALUES(operator *** 作员代号,;

operator *** 作员姓名,DATETIME())

_SCREENCaption="人事工资管理系统"+SPACE(40)+DTOC(DATE())+SPACE(40);

+" *** 作员:"+operat

SELECT 权限 FROM \dbsystem\menuright INTO ARRAY rr WHERE *** 作员代号=operator *** 作员代号 ;

ORDER BY 菜单项编号

RELEASE THISFORM

DO main_menumpr

CASE i<=3 AND FOUND() AND THISFORMText2Value!=operator口令

输入次数未超过3次且用户名正确、口令不正确

MESSAGEBOX("密码错误,请重输!","警告")

THISFORMText2Value=""

THISFORMText2Setfocus

CASE i<=3 AND NOT FOUND() &&输入次数未超过3次且用户名不正确

MESSAGEBOX(" *** 作员姓名错误,请重输!","警告")

THISFORMText1Value=""

THISFORMText2Value=""

THISFORMText1Setfocus

CASE i>3 &&输入次数超过3次

MESSAGEBOX("禁止进入系统!","警告")

THISFORMRelease

ENDCASE

(5)“退出”按钮(Command2)Click事件代码:

RELEASE THISFORM

CLEAR EVENTS

5.运行结果

系统登录表单运行结果如图2所示。

图2 “系统登录表单”运行结果

6.上传文件

将文件passscx和passsct两个文件上传到服务器“应用系统”中的“main”文件夹下。

以上就是关于SQL Server 数据库设计全部的内容,包括:SQL Server 数据库设计、数据库能查看日志吗、数据库表的设计等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9313353.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存