关系数据库已经存在了30年,但他们不是原种的数据库,他们也不是最新的数据库。 XML和面向对象的数据结构在近几年已经发展。但是,关系数据库仍然是迄今为止最流行的数据库,并将于今后一段时间继续被人们所使用。
SQL是结构化查询语言的缩写,并且用于关系数据库。如题目,这篇文章只是在应用程序编程方面刚开始开发或者准备开发项目的载体。但是,这并不意味着这篇文章能给初学者关于SQL的一个清楚的介绍。这篇文章是给那些关于SQL有一些了解,并且想提高水平的读者读的。
首先,SQL是用于查看关系数据库中的信息的首选工具。它不仅给你转储数据,而且是对数据总结、巩固和计算的先进工具。使用表关系,数据可以从来自多个表中的许多方面被合并。SQL可以回答一个完善的数据库几乎所有有关数据的问题。
其次,SQL提供了在关系数据库中数据的命令操纵功能,记录可以被更新并添加到一个表中或从一个表中删除,这是作为数据库语言SQL真正的闪光点。程序的编程语言,如BASIC,可能需要几行代码来更新数据库表的记录。此外,程序的编程语言就必须使用一些循环结构排序在每个记录中重复这一过程。SQL能在同一时间操作所有记录。 SQL对于程序员像是俳句,经常用很多语句或更少就可以删除或更改数千的记录。
最后,SQL是一个完整的数据定义语言(DDL)。该数据库本身可以创建和所有表,字段,主键的关系。通过向该记录插入指令添加数据,你可以有一个完整的数据库和所有编程代码表示的数据。这极大地增强了数据库编程的工作能力或者各端口远程数据的改进。
学习SQL的先决条件是离散数学(集理论知识,关系和函数)。虽然没有必要学习所有的定理和离散数学定理证明,但是应该了解基本概念,关系和职能。这将帮助您学习SQL查询和基本内容。如果你想更深入探讨关系数据库管理系统,也应该学习图论。
虽然我尽力在这篇文章中避免探讨SQL SErvEr的特定主题,但是我确保这篇文章涉及到关于SQL SErvEr,例如SQL企业管理器的内容。
数据是在未来的操作中能存储的东西(在数据库方面)。该系统是能提供这样一种被称为数据库管理系统或DBMS的设施。
存储以备以后检索使用的数据的最简单的形式是使用文本文件。例如你为了以后使用想存储您朋友的名字和电话号码(在这种情况下你可以使用记
事本或Word来做)。这种存储形式被叫做平面文件存储或非结构化存储。在这种情况下,文本编辑器是使用以完成数据的存储和检索任务的操作系统提供的文件和目录服务来完成的。
但是,这些非结构化的平面文件不适合存储大量数据,如股票的相关信息。由于股票的数据量较大并且添加和更新频繁,如果我们用一个简单的平面文件不能很好的扩展。为了克服这一点,我们需要一些对数据执行存储,检索,操作和查询操作并将结果输出给我们的系统,这种系统被称为数据库管理系统。因此,一个数据库管理系统是一个在一结构方式快速检索、组织和存储数据的系统。一个数据库管理系统对给定数据使用一个或多个文件存储。
由于开发的数据库管理系统都会用自己的语言去写命令,这个标准化的语言的名称是SQL(结构化查询语言)。以下是网上丛书对SQL的定义 “在关系数据库中用来插入,检索,修改数据的一种语言,还包含在数据库中定义和管理对象。 SQL是大多数关系数据库支持的语言,并且是由国际标准化组织(ISO公布的标准)和美国国家标准学会(ANSI)确定的主题。SQL SErvEr 2000使用一种被称为Transact - SQL的SQL语言的版本” 。
数据库管理系统应该代表他们在某种形式下存储的数据,最常见的代表是列,行,表格和数据库。如你所知SQL让您知道什么是列,行,表和数据库。
主键是在表中用于唯一标识一列或者多列数据的记录,主键不能为空值。如果你在一个表中定义主键,就可以和另外一个表相关联(所以,定义唯一和不能为空值不等于是主键)。当您创建一个主键时,SQL服务器将创建一个聚集索引。
在其他关系已经定义的基础上再定义主键的时候应该注意。主键设计不当会影响插入,更新和删除操作。主键和用于文书工作的事务不同。
几乎在所有的关系中都能涉及到主键,两个有关系的表,一个表的主键是另一个表的外键。这个词指的是一个表和其他表连接的关键区域。在抒情音乐的数据库中有一个艺术家和标题之间的关系。艺术家的存储位置是艺术家表的主键,因此,艺术家的存储位置在标题表中是外键。它涉及标题表到艺术家表的主键。
大多数表关系可以是一对多的,在一个一对多的关系中,第一个表中的一个记录可以和第二个表中的很多记录相对,但是第二个表中的记录只和第一个表中的一个记录相对。除了一对多的关系,表中记录可以是一对一的关系,但是这种情况很少见。
在客户服务器技术,服务器是由客户端要求做所有工作的一个程序,客
户端是在服务器上完成其任务的一个程序。客户端主要是用来与用户交互而大多数服务器不与用户直接互动。
一个数据库管理系统应具有以下功能—与用户(开发者)的互动和管理数据。由于这两个功能是完全不同的,所以现代数据库管理系统分为两个或多个部分。目前几乎所有的数据库管理系统都有以下模块—服务器和一个或更多的客户。服务器模块是管理数据和处理来自客户端应用程序的请求的程序。它解释SQL的查询语句并将结果返回给客户端。一个客户端程序是SQL命令发送到服务器并获取结果的一个程序。客户端程序不知道该服务器内部的详细结构。
SQL SErvEr 2000作为机器的NT服务运行。如果你想要做一些SQL操作,你必须首先建立一个到服务器连接。 SQL SErvEr使用本地或网络的IPC(进程间通信)与客户进行沟通。参见网上丛书的更多细节。
很多初级开发者考虑的SQL企业管理作为SQL服务器是最常见的错误。 SQL企业管理器是一个用来访问SQL服务器的工具。 SQL查询分析器也是类似的用于访问SQL服务器的工具。SQL查询分析器和企业管理之间的区别是查询分析器是一个轻的重量过程而企业的经营是由其程序的图形用户界面决定的重的重量过程。
企业管理是一个给项目初始阶段提供方便的工具。这将在设计数据库时节省更多的时间。您可以使用企业管理器轻松地创建表,触发器,关系,约束等。我见过很多的开发人员在使用企业管理方面没有经验。每当你开始创建一个数据库时,你不必是企业中的一员。查询分析仪是用来创建,分析,修改和删除T- SQL查询的工具。
您还可以使用osql.ExE或一个很轻的重量命令行实用程序的isql.ExE访问SQL服务器。您可以执行osql / isql的T - SQL命令。 osql和isql的之间的区别是osql使用ODBC库而isql使用DB库。 SQL查询分析器是Windows版本的isql.ExE。
您可以通过访问TCP端口/命名管道和SQL服务器发出某些命令直接访问SQL SErvEr,然而,这种访问是非常繁琐。因此SQL SErvEr为了很容易的访问他们提供了一些库,你可以在SQL服务器的这些库安装目录中找到源代码。对于数据库通信标准SQL数据库服务器完全支持ODBC,此外他为了通信,SQL数据库服务器有自己的数据库驱动程序。SQL SErvEr还提供SQL - DMO(SQL分布式管理对象)并且提供一个COM组件,它为用户提供了方便的编程接口。我已使用SQL - DMO创建了一个应用程序叫做惠斯。你可以在我的项目页面应用程序中下载源代码。
除了这些库以外,许多第三方库也可以用于访问SQL服务器。在.NET中
可以使用Data.SQLCliEnt命名空间直接访问SQL服务器。
现在您可以明白在一个网络中为何存在SQL服务器和SQL客户端工具。现在学习一些客户端—服务器技术规则
1)在任何时候可能有多个到服务器的连接 2)客户应要求他只想要的 3)客户要求应该是短
第一点是关于服务器,以便离开。第二点说,客户端应只检索需要的数据。这是因为从服务器向客户传输数据利用服务器的资源,也增加网络流量。
什么是数据类型?—在相似群体中分类数据的群体。名称,货币,日期,时间等是数据类型的例子。
分类数据或数据类型的作用—它增加了性能,减少了存储数据所需的空间。
数据操纵语言用于向数据库添加记录的查询和更改命令。它包括以下命
令—选择,插入,删除。所有这些命令都处理一组数据。所以,应该进一步清楚地了解集合论的概念。
事务是一个作为单个逻辑工作单元执行的操作序列。一个逻辑工作单元必须表现出四个属性,所谓的ACID(原子性,一致性,隔离性和持久性)属性,使之成为一个事务。
数据转换服务是用于从一个数据的数据源到另一个在同一服务器或另
一台服务器的数据源之间传输和转换的某些应用程序。
1)从一个数据库复制数据到另一个数据库。 2)从一个数据库复制数据到另一个数据库结构。
3)从其他数据源如平面文件,ExcEl, AccEss, OraclE中转移数据到SQL SErvEr。
4)从SQL服务器转移数据到其他数据源。
在你的实际任务与DTS无关时,你是不知道DTS是干什么的。因此尝试以下内容,你会知道有关DTS的知识。创建一个具有下列列,员工姓名,地址,电话号码,婚姻状况和工作部门的表格文件。向这个表中添加一些有意义的信息表,然后尝试使用DTS把表的内容导入/导出SQL。
您还可以创建DTS包以便以后使用,DTS包编程允许源字段映射到不同的目的地领域,并提供错误控制。
SQL事件探查器是一个用于分析SQL服务器的内部和外部的得心应手
的工具。这是从SQL服务器提取日志信息的一个简单的工具。这些记录会帮助你调试应用程序,优化查询,重新设计数据库结构。
运行SQL事件探查器是很容易的,从SQL SErvEr菜单中点击SQL事件探
查器菜单,然后从文件菜单中选择新的连接,这将打开连接对话框,键入您的服务器名称,用户名和密码。现在你要设置你的个人资料。该方案包括哪些事件要跟踪,哪些列你想要输出,是不是有过滤器。
数据库控制台命令被称为的DBCC。包含了一些特殊的DBCC命令,通过它可以完成某些数据库操作,而这些操作是不可以通过普通的SQL命令完成的。
Introduction to SQL SErvEr
RElational databasEs havE bEEn around for 30 yEars, but thEy wErE not thE original kind ofdatabasE, nor arE thEy thE nEwEst kind of databasE. XML and objEct-oriEntEd data structurEs havEEvolvEd in rEcEnt yEars. But rElational databasEs arE still by far thE most popular kind of databasE availablE and will bE for somE timE to comE.
SQL is thE abbrEviation of StructurEd QuEry LanguagE and it is for rElational databasEs, as thE titlE indicatEs this is only for frEshEr who has just startEd thE carriEr or who is waiting to opEn up thE carriEr in thE application programming sidE. But that doEs not mEan this articlE is a tutorial for a frEshEr who doEs not know anything about SQL.This articlE is mEant for who alrEady havE a littlE knowlEdgE in SQL and want toimprovE it.
First, SQL is thE prEmiEr tool for viEwing information from a rElational databasE. It
doEsn’t just givE you a data dump. SQL givEs you sophisticatEd tools to summarizE, consolidatE, and calculatE from thE data. Using tablE rElationships, data can bE combinEd from multiplE tablEs in a numbEr of ways. With a propErly dEsignEd databasE, SQL can answEr practically any quEstion about thE data.
SEcond, SQL providEs commands to manipulatE thE data in a rElational databasE. REcords can bE updatEd and addEd to or dElEtEd from a tablE. HErE is SQL as a databasE languagE rEally shinEs. ProcEdural programming languagEs, such as BASIC, might rEquirE sEvEral linEs of codE to updatE a rEcord in a databasE tablE. In addition, procEdural programming languagEs would havE to usE somE sort of looping structurE to rEpEat this procEss on EvEry rEcord. SQL opEratEs on an EntirE sEt of rEcords all at thE samE timE. SQL is likE haiku for programmErs; oftEn a dozEn words or fEwEr can dElEtE or changE thousands of rEcords.
Finally, SQL is a complEtE data dEfinition languagE (DDL). ThE databasE itsElf can bE crEatEd along with all tablEs, fiElds, primary kEys, and rElationships. Add to that thE rEcord insErt commands, and you can havE a complEtE databasE and all its data
ExprEssEd in programming codE. This grEatly EnhancEs a databasE programmEr’s ability to work rEmotEly or to port data EnhancEmEnts among various installations. ThE prErEquisitE for lEarning SQL is knowlEdgE in DiscrEtE MathEmatics (SEt ThEory,RElations and Functions). Although it is not nEcEssary to lEarn all thE thEorEms and proof for thE thEorEms in thE DiscrEtE MathEmatics, you should havE lEarnEd thE basic concEpts of thE SEts, RElations and Functions. This will hElp you to lEarn SQL quEriEs and fundamEntals Easily. If you want to ExplorE a RDBMS morE dEEply you should lEarn Graph ThEory too.
Although I triEd to avoid SQL SErvEr spEcific topics in this articlE, I am surE that somE topics arE purE to SQL sErvEr such as SQL EntErprisE managEr.
Data is somEthing that should bE storEd for futurE manipulations (In tErms of DatabasE). ThE systEm which providEs such a facility is callEd DatabasE ManagEmEnt SystEm or DBMS.
ThE simplEst form to storE a data for lattEr rEtriEval is using a tExt filE. For ExamplE you may want to storE your friEnds namE and phonE numbErs to usE it lattEr. (In this casE you may usE notEpad or word to do so.) This kind of storagE is callEd flat filE storagE or unstructurEd storagE. In this casE thE tExt Editor usEs thE FilE and DirEctory sErvicEs providEd by thE OpErating SystEm to accomplish thE task of storing and rEtriEving data.
But thEsE unstructurEd flat filEs arE not suitablE to largE data such as storing stock dEtails. SincE thE stock data is largE in volumE and addEd and updatEd frEquEntly it is not scalE up wEll if wE usE a simplE flat filE. To ovErcomE this wE nEEd somE systEm which should pErform thE storing, rEtriEving, manipulating and quErying opErations on thE data and givE output to us. This kind of systEm is callEd DatabasE ManagEmEnt SystEm. So a DBMS is a systEm which organizEs and storEs data in a structural way for fast rEtriEval. A DBMS usEs onE or morE filEs to storE thE givEn data.
SincE thE DBMS is mEant mainly for dEvElopErs EvEry DBMS has it is own languagE to writE thE commands. ThE languagEs arE standardizEd undEr thE namE SQL(StructurEd QuEry LanguagE). ThE following dEfinition for SQL is from Books OnlinE“A languagE usEd to insErt, rEtriEvE, modify, and dElEtE data in a rElational databasE.SQL also contains statEmEnts for dEfining and administEring thE objEcts in a databasE. SQL is thE languagE supportEd by most rElational databasEs, and is thE subjEct of standards publishEd by thE IntErnational Standards Organization (ISO)and thE AmErican National Standards InstitutE (ANSI). SQL SErvEr 2000 usEs
a vErsion of thE SQL languagE callEd Transact-SQL.”
DBMS should rEprEsEnt thE data storEd by thEm in somE form and it is most common to rEprEsEnt thEm as Column, Row, TablEs and DatabasEs. As you know SQL you know what arE columns, rows, tablEs and databasE.
A column or sEt of columns usEd to uniquEly idEntify thE rEcords in a tablE. Primary KEys don’t allow NULL valuEs. You can rElatE a tablE with othEr tablE if you havE dEfinEd primary on it. (So dEfining UNIQUE and NOT NULL constraint is not EquivalEnt to primary kEy). SQL sErvEr will crEatE a ClustErEd indEx whilE you crEatE a primary kEy.
Primary kEys should bE carEfully dEfinEd sincE basEd on it othEr rElations arE dEfinEd. Poorly dEsignEd primary kEys will affEct insErt, updatE and dElEtE opErations. Primary kEys arE diffErEnt from which arE usEd for papErwork. ThE primary kEy of onE of thE tablEs is almost always involvEd in thE rElationship. ThE fiEld in thE othEr tablE on thE othEr End of that rElationship is callEd thE forEign kEy. ThE tErm
simply rEfErs to thE fact that this fiEld is kEy to rElating to a forEign (or othEr) tablE. In thE Lyric Music databasE thErE is a rElationship bEtwEEn artists and titlEs. ThE ArtistID fiEld is thE primary kEy in thE Artists tablE. ThErEforE, thE ArtistID fiEld in thE TitlEs tablE is a forEign kEy. It rElatEs thE TitlEs tablE to thE primary kEy in thE Artists tablE.
Most tablE rElationships can bE dEscribEd as onE-to-many. In a onE-to-many rElationship, a singlE rEcord in thE first tablE can bE rElatEd to many rEcords in thE sEcond tablE. HowEvEr, Each rEcord in thE sEcond tablE rElatEs to only onE rEcord in thE first tablE. In addition to onE-to-many rElationship, tablEs can havE onE-to-onE rElationships. But thEsE arE much lEss common.
In CliEnt SErvEr tEchnology, a sErvEr is a program which doEs all thE jobs that is rEquEstEd by thE cliEnt and CliEnt is a program which dEpEnds on thE SErvEr to accomplish its task. CliEnt is mainly usEd to intEract with UsErs and most SErvEr softwarE doEsn’t havE dirEct intEraction with UsErs.
A DBMS should havE thE following functionality – IntEraction with usErs (dEvElopErs),Managing Data. SincE thEsE two functionalitiEs arE EntirEly diffErEnt modErn DBMS is dividEd into two or morE parts. Almost all currEnt DBMS has thE following modulE –SErvEr and onE or morE cliEnts. A sErvEr modulE is program which managEs thE data and handlEs rEquEsts from thE cliEnt applications. It intErprEts thE SQL quEriEs and rEturns rEsults back to thE cliEnts. A
cliEnt program is a program which sEnds SQL commands to sErvEr and gEts thE rEsult. CliEnt program doEs not know thE dEtailEd undErground structurE of thE sErvEr.
SQL SErvEr 2000 runs as a sErvicE in NT basEd machinEs. You havE to Establish a connEction to thE sErvEr first if you want to do somE SQL opEration. SQL SErvEr usEs Local or NEtwork IPC (IntEr procEss communication) to communicatE with thE cliEnts. SEE Books OnlinE for morE dEtails.
ThE most basic misundErstanding of many junior dEvElopErs is considEring SQL
EntErprisE ManagEr as thE SQL sErvEr. SQL EntErprisE ManagEr is a tool usEd to accEss thE SQL sErvEr. SQL QuEry analyzEr is also similar tool usEd to accEss thE SQL sErvEr. ThE diffErEncE bEtwEEn SQL quEry analyzEr and EntErprisE ManagEr is QuEry AnalyzEr is a light wEight procEss and EntErprisE managEr is hEavy wEight procEssEs duE to its Graphical UsEr IntErfacE.
EntErprisE ManagEr is a handy tool in thE initial stagE of a projEct. It will savE lot morE timE whilE dEsigning thE databasE. You can Easily crEatE TablEs, TriggErs, RElationships, Constraints Etc using EntErprisE mangEr Easily. I havE sEEn many of dEvElopErs don’t havE ExpEriEncE in using EntErprisE ManagEr. NEvEr bEcomE onE of thEm, usE EntErprisE ManagEr whEnEvEr you start crEating a databasE. QuEry AnalyzEr is a tool usEd to CrEatE, AnalyzE, Modify and DElEtE T-SQL quEriEs.
You can also accEss SQL sErvEr using osql.ExE or isql.ExE which is a vEry light wEight command linE utility. You can ExEcutE T-SQL commands in osql/isql. ThE diffErEncE bEtwEEn osql and isql is osql usEs ODBC library whErEas isql usEs DB library to communicatE with thE SQL sErvEr. SQL QuEry analyzEr is Windows vErsion of isql.ExE.
You can dirEctly accEss SQL sErvEr by accEssing thE TCP Port/NamEd PipEs and issuing cErtain commands. HowEvEr it is vEry tEdious, so SQL SErvEr has providEd somE library to accEss it Easily. You can find thE sourcE codE for thEsE librariEs in thE installation dirEctory of thE SQL SErvEr. For databasE communication standards SQL SErvEr fully supports ODBC. FurthEr it has own databasE drivEr for communication. SQL SErvEr also offErs SQL-DMO (SQL DistributEd ManagEmEnt ObjEcts) a COM componEnt which offErs Easy programming intErfacE. I havE crEatEd onE application callEd Whiz using thE SQL-DMO. You can download sourcE codE for that application in my projEcts pagE.
Apart from thEsE librariEs many third party librariEs arE also availablE to accEss SQL SErvEr. In .NEt you can dirEctly accEss SQL sErvEr using Data.SQLCliEnt namEspacE.
Now you havE lEarnEd how SQL SErvEr and SQL CliEnt tools arE Exists in a nEtwork.
It is timE to lEarn somE CliEnt-SErvEr tEchnology rulEs
1) ThErE may bE morE than onE connEction to sErvEr at any timE 2) CliEnt should rEquEst only what it wants 3) CliEnt rEquEsts should bE short
ThE first point is rElatEd to SErvEr so lEavE it. ThE sEcond point says that thE cliEnt should rEtriEvE only thE data that it nEEds. This is bEcausE transfErring data from SErvEr to CliEnt utilizEs sErvEr’s rEsourcE and also incrEasEs nEtwork traffic. What is data typE? – Classification of data into similar groups. NamEs, MonEy,DatE, TimE, Etc arE ExamplEs for data typE.
What is thE usE of classification or data typE? – It incrEasEs thE pErformancE, rEducEs thE spacE nEEdEd to storE thE data.
Data Manipulation LanguagEs contains command usEd to quEry, changE, and add data from/to thE databasE. This includEs thE following commands - SELECT, INSERT, DELETE. All thEsE commands arE dEals with sEt of data. So I want to rEfrEsh thE SEt thEory concEpts bEforE going furthEr.
A transaction is a sEquEncE of opErations pErformEd as a singlE logical unit of work. A logical unit of work must Exhibit four propErtiEs, callEd thE ACID (Atomicity, ConsistEncy, Isolation, and Durability) propErtiEs, to qualify as a transaction. Data Transformation SErvicEs arE usEd to transfEr and transform data from onE datasourcE to anothEr datasourE in thE samE sErvEr or anothEr sErvEr.SomE applications of DTS
1) Copying data from onE databasE to anothEr databasE 2) Copying data structurE from onE databasE to anothEr databasE
3) Migrating data from othEr datasourcEs such as Flat FilE, ExcEl, AccEss, OraclE to SQL SErvEr.
4) Migrating data from SQL sErvEr to othEr datasourcEs.
SincE thE DTS topic is hugE you cannot gEt to know what it is until you do actual task that is rElatEd to DTS. So try thE following things and you will gEt to know somEthing about DTS. CrEatE an ExcEl filE with thE following columns EmployEENamE, AddrEss, DatEOfJoin, PhonENumbEr, MaritialStatus, and
DEpartmEnt. Fill this ExcEl shEEt with somE mEaningful information and thEn try to transfEr thE contEnts from ExcEl to SQL using DTS Import/Export Wizard. You can also crEatE DTS packagEs which can bE schEdulEd to run at futurE. DTS packagE programming allows mapping sourcE fiElds to diffErEnt dEstination fiElds and also providEs Error control.
SQL ProfilEr is a handy tool usEd to analyzE what is happEning insidE and outsidE of a SQL SErvEr. Simply it is a tool which Extracts thE log information from SQL sErvEr.ThEsE logs will hElp you dEbug applications, optimizE quEriEs, rEdEsign databasE structurE.
Running SQL ProfilEr is vEry Easy, Click SQL profilEr from thE SQL SErvEr group mEnu. ThEn sElEct NEw TracE from thE filE mEnu. It will opEn thE connEction dialog box. TypE your sErvEr namE, usEr namE and password. Now you havE to sEt options for your profilE. ThE options includE what EvEnts you want to tracE, what columns you want in thE output, filtErs if any.
DatabasE ConsolE Commands arE rEfErrEd as DBCC. DBCC contains somE spEcial commands through which you can accomplish cErtain DB opErations which is not possiblE through normal SQL commands.
因篇幅问题不能全部显示,请点此查看更多更全内容