数据库开发基本操作-SQL Server数据库技术(上)
数据库是软件开发人员必须掌握的一门技术,在信息网络技术突飞猛进的今天,数据对于人们生活和工作的重要性可想而知,如何合理安全的管理各种数据信息,对于软件IT行业的发展起到了至关重要的作用。下面我来为大家从最基础的数据库应用开始慢慢揭开数据库的神秘的面纱,嘿嘿,当然面向对象是那些事先对数据库没有基础但又对这项技术颇感兴趣的朋友。
1.数据、数据库、数据管理系统基本概念:
数据:人类有用信息的符号化表示。
数据库:按照数据结构来组织、存储和管理数据的一个仓库。
数据库管理系统(DBMS):可维护、存储并为应用系统提供数据的软件系统(软件+数据库+数据管理员)。
可以客观描述的事物被称为“实体”,不同的数据体现了不同的实体。数据每一行(Row)对应一个实体,被称为“记录(record)”,每个输入项称为“列”(Column),如编号,姓名,学号等。数据“表”是实体的集合,用于存储具体的数据。 “数据库”是“表”的集合。 “关系”也是数据库重要的一部分(从关系表达式到键、类型、规则、权限、约束、触发器等抽象概念来表达)。
数据库发展史:
·萌芽阶段——文件系统:提供简单数据共享和管理,类似于Winxp的资源管理器。
·初级阶段——第一代数据库:层次模型与网状模型数据库系统(如IMS信息管理系统)
·中级阶段——第二代数据库:关系数据库(如IBM的DB2,Oracle),使用结构化查询语言SQL作为数据库定义语言DDL和数据库操作语言DML。(目前依然是商务应用领域的天下)
·高级阶段——新一代数据库:如关系-对象型数据库系统,但像不同的方向上变迁以适应数据库厂商的各种需要。
2.常用数据库类型:
·层次结构模型:IMS
·网状结构模型:DBTG(Data Base Task Group)
·关系结构模型:二维表格形式(字段记录)
3.常用数据库产品
SQL Server(Microsoft)、Oracle(Oracle甲骨文)、DB2(IBM)、MySQL(Sun) 、Access(MS Office)。
目前Intenet流行网站架构方式:LAMP(Linux + Apache + MySQL + PHP)。(MySQL开源软件,成本低)
在这里我们先了解并掌握SQL Sever数据库的应用,故用时下最流行的SQL Sever 2005数据库作为研究对象
SQL Server 2005 有哪些主要的版本:
SQL Sever 2005 Enterprise Edition 企业版(超大型企业)、SQL Sever 2005 Standard Edition 标准版(中小型企业)、SQL Server 2005 Workgroup Edition 工作群版(小型企业用于生产服务)、SQL Server 2005 Development Edition 开发版(小型企业用于开发测试)、SQL Sever 2005 Express Edition 简易版
4.SQL Server 2005 Express 基于WinXP的安装:
(1)安装 Windows Installer 3.0
(2) 安装 Microsoft .NET Framework 2.0
(3) 安装 Microsoft .NET 2.0 Language Pack 语言包
(4) 安装 SQL Server 2005 Express Edition(SQLEXPR32_SP2_CHS_20070218)
(5) 安装 Management Studio Express(SQLServer2005_SSMSEE_SP2_20070217)
(6) 安装 SQL Sever 2005 联机丛书(SqlServer2K5_BOL_Dec2008_CHS)
【注意】如果你已经安装了 Visual Studio 2005/2008 开发软件,只需要安装第(5)即可。
5.SQL Server 2005 创建数据库和数据表:
SQL Server 2005 数据库包含的物理文件:数据文件 + 日志文件
主要数据文件(.mdf)——包含数据库启动信息,并指向数据库其他文件(只有一个)。
次要数据文件(.ndf)——由用户定义并存储用户数据(可选),可分散到多个磁盘(可扩展)。
事务日志文件(.ldf)——保存用于恢复数据库的日志信息(至少一个)。
【注意】为便于管理和分配,每个数据库有一个主要文件组(Primary):包含主要数据文件和分散到各磁盘但未分组的所有次要文件。
SQL Server 2005 系统数据库(5个):master、msdb、model、Resource、tempdb
系统数据库 |
作 用 |
master | 记录了所有数据库系统级信息(端点、登录账户、系统配置等),记录其他所有数据库的存在、文件位置和初始化信息。 |
msdb | 作为SQL Server代理用于计划警报和作业,或完成其他功能。 |
model | 用于在实例上创建所有数据库的模板(必须存在)。 |
Resource | 包含所有数据库系统对象(只读),即所有系统资源数据库(前缀sys) |
tempdb | 临时工作空间,用于保存临时对象或中间结果集,不允许对tempdb进行备份和还原操作。 |
·创建用户数据库:
A.首先连接服务器:(服务器名(本机):.\SQLEXPRESS;身份验证:Windows身份验证)
【注意】Windows身份验证、SQL Server身份验证的区别:
Windows身份验证将按Windows指定的用户账户来识别客户端进行身份验证(即代表每台计算机的用户账户)
SQL Server身份验证则通过客户端提供的用户名和密码与SQL Server中维护的有效用户名和密码列表比较进行客户端的身份验证。
B.新建数据库:
C.选项面板中设置数据库的相关选项。确定即完成数据库的创建。
·创建并管理数据表:(新建表->添加表的列(字段)->保存)
·修改表结构、字段、建立约束关系等:
·添加或修改表中的数据:
附:SQL Server 2005 常用数据类型:
精确数字型:bigint(8字节)、int(4字节)、smallint(2字节)、tinyint(1字节)
近似数字型:float(取决于位数)、real(4字节)
来源:(http://blog.sina.com.cn/s/blog_5f84d3a30100fplm.html) - SQL Server数据库技术(上)_蜗牛_新浪博客
日期时间型:datetime(1753年1月1日~9999年12月31日,可精确到3.33毫秒)、smalldatetime(1900年1月1日~2079年6月6日,可精确到1分钟)
字符串型:char(1字符1字节,长度不足时自动补空)、nchar(1字符占2字节,数据长度不足自动补空)、varchar(1字符占1字节,(max)输入实际长度再加2字节)、nvarchar(1字符2字节,(max)输入实际长度再加2字节)、text(1字符占1字节\最大2GB)、ntext(1字符占2字节\最大2GB)、binary(固定长度,长度不够自动补0x00)、varbinary(可变长度,输入数据的实际长度)、image(可变长度,输入数据的实际长度)
其他类型:cursor、sql_variant、table、timestamp、uniqueidentifier、xml
【注意】区别nchar和nvarchar字符串:一般较常使用varchar和nvarchar,而很少使用char和nchar,因为我们不需要字符补足空白而占用字节空间,相比于varchar,nvarchar更支持中文格式字符串而不保留空白。
·创建视图(进行数据的筛选与排序等操作):
将视图进行保存,以便以后随时调用视图(而无需表)来实现特定数据的复用。
·数据库架构的作用:
独立于数据库用户的非重复命名空间,可视架构为对象的容器,可以创建和更改。也可以设置用户访问架构的权限。这样用户能在同一数据库中调用不同架构下的相同命名的表。比如:dbo.Students 和db_datareader.Students。
6.数据库的管理和维护:
·数据库的迁移:
分离:将数据库文件从当前SQL Server实例脱离(数据库从某台计算机上移走)
附加:将数据库文件附加到其他SQL Server实例(数据库实例移动到另一个数据库实例)
虽然数据库进行了分离,但在SQL Server安装目录下(如下地址)的Data文件夹中依然存在被分离的Students数据库物理文件,此时的数据库可以进行复制和移动等迁移操作而不受服务器的影响。
那么怎么找回该数据库重新操作呢?
点“添加”找到之前的数据库文件所在路径:
点“确定”添加成功后,该数据库重新回到我们视线(此时它再次与此服务器实例关联起来,不能迁移)。
·数据库的备份和还原:
备份:数据的副本,用于在系统发生故障后,还原和恢复数据。
还原:将数据库的备份加载到系统中的过程。
点击“添加”,将备份文件保存在其他目录下。
【注意】不能备份到单独的盘符路径下(以上截图操作中有错误),必须备份到指定文件夹目录中。
例如:我将备份文件存放在D:\temp目录下,
下面我们来执行还原操作,首先假设Students的数据库物理文件已经因系统故障而被意外删除(这里为操作方便,我们故意删除它),那么可以调用D:\temp中的students.bak进行数据库的还原,以免因这种事的发生而让你陷入焦头烂额的境地。
选择还原的源文件:即备份文件的路径
点击确定后,将出现如下对话框(如果报错不能还原,很可能是你没有把数据库中的两个物理文件删除。)
以后我们可以带着我们的备份文件去不同的服务器操作,而不需要携带那么多的数据库物理文件。
·数据库的网络配置:
希望网络中的其他计算机能够访问SQL Server 2005,就需要配置系统支持的网络协议和外围功能。
配置相同的网络协议(TCP/IP协议(Internet)、IPX/SPX(局域网)、NetBEUI(网络邻居广播型)等):
打开SQL Server Configuration Manager(SQL配置管理器):
配置了相关网络协议,不代表可以被访问,我们还要配置SQL Server允许远程连接:
(1)打开SQL Server 外围应用配置器。
(2)点击“服务和连接的外围应用配置器”,打开配置面板进行如下操作
·创建用户登录账户
选择“常规”选项卡:
选择“用户映射”选项卡:
然后断开与原服务器的连接(当然也可以直接点左边那个“打开连接”而不关闭原来的),用SQL Server帐号重新进行连接:
登录成功后,出现了登录名为sa和sun的两个用户名。
看看是否能登录成功,如果没有登录成功,那么请新增服务器角色如下:
怎么样,登录成功了吧?在这里特别提醒一下,sa 是SQL Server登录用户的默认最高权限。
7.创建约束和添加关系:
这将在《SQL Server数据库技术(下)》中作详细介绍。