我先学了些VC++编程,因工作需要,现在打算学习数据库方面的知识,听说Access数据库是最基本的数据库,又听说SQL Server和Oracal是现在最流行的数据库。可是我是一个对数据库毫无基础的菜鸟,连最基本的DBMS之类的术语也是一懂半懂。请问我应该如何学习数据库,先学什么?然后学什么?最好能提供几本好书,如果有下载的话就最好了。谢谢!!!!

解决方案 »

  1.   

    我也曾经和你一样迷茫,现在好象找到了一点感觉。
    我一开始也是不知道该从那个DBMS入手,也不知道学哪个更合算(我想你也是这种心情),后来我下了决心学SQL SERVER,原因是,他的定位比较适中,ACCESS弱了一些,ORACAL高了一些,有点屠龙之技的感觉,况且我也是搞VC开发的,VC和SQL SERVER都是微软的东东,结合起来可能比较好用,也好上手。SQL SERVER搞熟了,ORACAL我想也比较好上手。
    现在,我自我感觉上了路子,这些天了解了些ODBC,DAO,ADO技术,比较爽,哈哈!
    上面是我的一点心得,希望对你有些帮助!
    好运!
      

  2.   

    access:前提:已经安装好access进入access,点击文件-->新建--〉按照向导提示一步步做下去。建好数据库,察看窗口数据的添加、查询、删除。然后察看每个数据表的数据,最后察看每个数据表的内容即数据表的设计视图。如果能明白数据和表和数据库之间的意义,你就出徒了,如果能把数据表之间的关联和数据的查询搞明白,你就是高手了。sql数据库:前提:已经会使用access数据库学会添加数据表,以及修改数据内容。sql语言:对于数据库,这是一门非常重要的语言,一定要熟练掌握。找个比较全面的教材,记熟几个常用命令,如insert into, update , select,order by ,delete。其他的什么时候用到,什么时候看就可以了,在使用中逐渐熟悉。
      

  3.   

    SQL是英文Structured Query Language的缩写,意思为结构化查询语言。SQL语言的主要功能就是同各种数据库建立联系,进行沟通。按照ANSI(美国国家标准协会)的规定,SQL被作为关系型数据库管理系统的标准语言。SQL语句可以用来执行各种各样的操作,例如更新数据库中的数据,从数据库中提取数据等。目前,绝大多数流行的关系型数据库管理系统,如Oracle, Sybase, Microsoft SQL Server, Access等都采用了SQL语言标准。虽然很多数据库都对SQL语句进行了再开发和扩展,但是包括Select, Insert, Update, Delete, Create, 以及Drop在内的标准的SQL命令仍然可以被用来完成几乎所有的数据库操作。下面,我们就来详细介绍一下SQL语言的基本知识。数据库表格  一个典型的关系型数据库通常由一个或多个被称作表格的对象组成。数据库中的所有数据或信息都被保存在这些数据库表格中。数据库中的每一个表格都具有自己唯一的表格名称,都是由行和列组成,其中每一列包括了该列名称,数据类型,以及列的其它属性等信息,而行则具体包含某一列的记录或数据。以下,是一个名为天气的数据库表格的实例。城市 最高气温 最低气温 
    北京 10 5 
    上海 15 8 
    天津 8 2 
    重庆 20 13   该表格中“城市”, “最高气温”和“最低气温”就是三个不同的列,而表格中的每一行则包含了具体的表格数据。
    数据查询  在众多的SQL命令中,select语句应该算是使用最频繁的。select语句主要被用来对数据库进行查询并返回符合用户查询标准的结果数据。Select语句的语法格式如下:select column1 [, column2,etc] from tablename[where condition]; ([] 表示可选项)  select语句中位于select关键词之后的列名用来决定那些列将作为查询结果返回。用户可以按照自己的需要选择任意列,还可以使用通配符“*”来设定返回表格中的所有列。select语句中位于from关键词之后的表格名称用来决定将要进行查询操作的目标表格。Select语句中的where可选从句用来规定哪些数据值或哪些行将被作为查询结果返回或显示。在where条件从句中可以使用以下一些运算符来设定查询标准:= 等于> 大于< 小于>= 大于等于<= 小于等于<> 不等于  除了上面所提到的运算符外,LIKE运算符在where条件从句中也非常重要。LIKE运算符的功能非常强大,通过使用LIKE运算符可以设定只选择与用户规定格式相同的记录。此外,我们还可以使用通配符“%”用来代替任何字符串。举例如下:select firstname, lastname, cityfrom employeewhere firstname LIKE ‘E%’;(注意,字符串必须被包含在单括号内)上述SQL语句将会查询所有名称以E开头的姓名。或者,通过如下语句:select * from employeewhere firstname = ‘May’;查询所有名称为May的行。 创建表格  SQL语言中的create table语句被用来建立新的数据库表格。create table语句的使用格式如下:create table tablename(column1 data type,column2 data type, column3 data type);  如果用户希望在建立新表格时规定列的限制条件,可以使用可选的条件选项:create table tablename(column1 data type [constraint],column2 data type [constraint],column3 data type [constraint]);   举例如下:create table employee(firstname varchar(15),lastname varchar(20),age number(3),address varchar(30),city varchar(20));  简单来说,创建新表格时,在关键词create table后面加入所要建立的表格的名称,然后在括号内顺次设定各列的名称,数据类型,以及可选的限制条件等。注意,所有的SQL语句在结尾处都要使用“;”符号。  使用SQL语句创建的数据库表格和表格中列的名称必须以字母开头,后面可以使用字母,数字或下划线,名称的长度不能超过30个字符。注意,用户在选择表格名称时不要使用SQL语言中的保留关键词,如select, create, insert等,作为表格或列的名称。  数据类型用来设定某一个具体列中数据的类型。例如,在姓名列中只能采用varchar或char的数据类型,而不能使用number的数据类型。  SQL语言中较为常用的数据类型为:char(size):固定长度字符串,其中括号中的size用来设定字符串的最大长度。Char类型的最大长度为255字节。varchar(size):可变长度字符串,最大长度由size设定。number(size):数字类型,其中数字的最大位数由size设定。Date:日期类型。number(size,d):数字类型,size决定该数字总的最大位数,而d则用于设定该数字在小数点后的位数。  最后,在创建新表格时需要注意的一点就是表格中列的限制条件。所谓限制条件就是当向特定列输入数据时所必须遵守的规则。例如,unique这一限制条件要求某一列中不能存在两个值相同的记录,所有记录的值都必须是唯一的。除unique之外,较为常用的列的限制条件还包括not null和primary key等。not null用来规定表格中某一列的值不能为空。primary key则为表格中的所有记录规定了唯一的标识符。  向表格中插入数据  SQL语言使用insert语句向数据库表格中插入或添加新的数据行。Insert语句的使用格式如下:insert into tablename(first_column,...last_column)values (first_value,...last_value); 例如:insert into employee(firstname, lastname, age, address, city)values (‘Li’, ‘Ming’, 45, ‘No.77 Changan Road’, ‘Beijing”);  简单来说,当向数据库表格中添加新记录时,在关键词insert into后面输入所要添加的表格名称,然后在括号中列出将要添加新值的列的名称。最后,在关键词values的后面按照前面输入的列的顺序对应的输入所有要添加的记录值。
      更新记录  SQL语言使用update语句更新或修改满足规定条件的现有记录。update语句的格式为:update tablenameset columnname = newvalue [, nextcolumn = newvalue2...]where columnname OPERATOR value [and|or column OPERATOR value];例如:update employeeset age = age+1where first_name= ‘Mary’and last_name= ‘Williams’;使用update语句时,关键一点就是要设定好用于进行判断的where条件从句。
       删除记录  SQL语言使用delete语句删除数据库表格中的行或记录。Delete语句的格式为:delete from tablenamewhere columnname OPERATOR value [and|or column OPERATOR value];   例如:
    delete from employeewhere lastname = May;  简单来说,当需要删除某一行或某个记录时,在delete from关键词之后输入表格名称,然后在where从句中设定删除记录的判断条件。注意,如果用户在使用delete语句时不设定where从句,则表格中的所有记录将全部被删除。  删除数据库表格  在SQL语言中使用drop table命令删除某个表格以及该表格中的所有记录。drop table命令的使用格式为:drop table tablename;例如:drop table employee;  如果用户希望将某个数据库表格完全删除,只需要在drop table命令后输入希望删除的表格名称即可。drop table命令的作用与删除表格中的所有记录不同。删除表格中的全部记录之后,该表格仍然存在,而且表格中列的信息不会改变。而使用drop table命令则会将整个数据库表格的所有信息全部删除。  以上,我们对SQL语言主要的命令和语句进行了较为详细的介绍。应该说SQL语句的语法结构和风格还是相当简单和直观的,只要用户结合实践多加练习,一定会在短期内迅速掌握。 
      

  4.   

    其实一开始不必拘泥与具体的产品,什么access了,sqlserver了,全不管,要学一点基础理论,找一些这方面的书看一下,你就会对数据库有一个感性的认识了,然后对那些产品也会又一个模糊的把握了,之后具体于产品,狂学,适当的时候做点小项目锻炼一下,这样会提高很快的,我觉得,我去年刚刚学过数据库,为了做项目没有复习,考试中因为照顾别人而又题目没有做,还考了70多分,哈哈!
      

  5.   

    忘了说了,基础理论的书,比较好的如silberchartz的<database system concep>等,高教引进的一批外文书质量都很高,关于数据库方面的都值得看的
      

  6.   

    我是本贴的贴主,首先谢谢各位朋友的真诚相助。从你们的介绍中我得到两点:1.一开始不拘泥于具体的某一个产品,而是恶补一下基础理论,比如什么是数据库?什么是关系数据库?数据库的基本操作,比如添加、查找、删除等,这一点最后用access来学习。2.在access中把数据库的基本术语,基本操作学懂以后,大概就要选一门具体的数据库工具了,这点最好是选sql server数据库了,好处自不必说。这是我得到的几点心得,可是问题又来了:各个阶段看什么样的书呢?关于数据库的书很多,关于sql server的书也有一大萝筐。可是我要什么呢?对于一个什么都不懂的人又怎么才能分别它们谁是悟空?谁又是白骨精呢?