值得看的SQL书籍

来自:程序员书库(ID:CodingBook) 


近年来,和其他系统领域一样,数据库领域也实现了飞速发展,应用范围不断扩大,不但出现了具有新功能的数据库,而且操作的数据量也在大幅增长。如果问你哪个语言可以在关系数据库中自由穿梭,想必SQL绝对是大家首选答案


掌握SQL的重要性不言而喻。今天就为大家简单介绍5本无数读者喜爱的SQL书籍。



1、《SQL必知必会》


640?wx_fmt=jpeg&wxfrom=5&wx_lazy=1


福达著, 钟鸣、刘晓霞译


● 麻省理工学院、伊利诺伊大学等众多大学的参考教材

● SQL经典畅销书,内容丰富,简洁实用 

● 存储过程和触发器等核心知识点一应俱全。


这本书由浅入深地讲解了SQL的基本概念和语法,涉及数据的排序、过滤和分组,以及表、视图、联结、子查询、游标、存储过程和触发器等内容,实例丰富,便于查阅。新版增加了针对ApacheOpenOfficeBase、MariaDB、SQlite等DBMS的描述,并根据新版本的Oracle、SQLServer、MySQL和PostgreSQL更新了相关示例,非常适合初学者。


读者评价:


@未完待续:很薄的一本,能作为速查手册用,很适合轻度需求的人

@匿名:书是32开的,比我们一般的买的书要小。200多页,几天就可以看完,适合完全没有sql基础的人快速入门!内容通俗易懂!

@orcl_zhang :适合入门学习者,讲的还是很深入浅出的,结构也很好,循序渐进

@Ven:书中的内容的确是关系型数据库使用者“必须知道必须会”的,如果你连这些都不知道,那就太…… 这本书讲得实在有够浅,只适合彻底的新手和入门者。



2、《SQL基础教程》


640?wx_fmt=jpeg


MICK 著, 孙淼、罗勇 译


● 深数据库工程师写给初学者的实用指南

● 107张图表+209段代码+88个法则,菜鸟进阶必备


这本书豆瓣评分9.0,重印13次,第2版基于新版本RDBMS全面升级,并新增一章介绍从应用程序执行SQL语句的方法。本书从数据库、表的结构到查询、更新表的语法,常用的函数,表的联结等,内容逐步深入。对于初学者常见的疑难点,均通过专栏进行讲解。各章节后精心设计了练习题,帮助读者巩固理解。


读者评价:


@HopeR:这本书感觉上絮叨一点,实际上能满足各种层次的学习,细致而系统

@MoonJourney非常好的SQL基础教材,不掉书袋,脱离现实,慢慢看跟着做绝对没问题。本书用的是 PostgreSQL。

@Joshz:入门书,写得很浅显易懂,而且会不厌其烦地强调学过的内容。书中涉及到的SQL的知识点都很基础,应届生面试看看可能够了,但是如果要经常和数据库打交道那很显然不够。

@匿名:看起来很快,3天不到能看完,算是快速入门比较好的书吧。 优点就是,里面的知识实用于五个最常用的数据库,而且不同的地方有图标标示,以后自己学习某一个数据库应该会比较快



3、《SQL Cookbook》


640?wx_fmt=jpeg


Anthony Molinaro 著


● 畅销全球的数据库入门经典

● 作者有9年解决复杂SQL问题的实战经验


本书是一本指南,其中包含了一系列SQL 的常用问题以及它们的解决方案,希望能对读者的日常工作有所帮助。有150 多个小节,这还仅仅是SQL 所能做的事情的一鳞半爪,而这本书更主要的是让读者看到,SQL 能够做多少一般认为是SQL 问题范围之外的事情。


读者书评:


@Renco:基本还是在讲SQL的一些语言小技巧 没有专门的篇幅讲Dynamic SQL

@匿名:内容比较多,以例子的讲解为主,很多解决方法令人耳目一新,但是有些东西感觉重复太多,比如说字符的处理,讲来讲去其实就是一个东西,非要把几个雷同的例子翻来覆去地捣弄,读起来有点疲劳

@PSjay:本书的各个例子将使用SQL的各种情况都讲得很详细,并且思路清晰,一次性读完意义不大,还是比较适合在寻求解决方案的时候翻一翻。



4、《深入浅出SQL(中文版)》


640?wx_fmt=jpeg


贝里 著,O‘Reilly Taiwan 译


● 让SQL变得有趣,变得好玩

● 语言幽默,内容紧凑,SQL菜鸟晋级必备


这本对所有没SQL基础的人来说都是本好书,幽默的语言,紧凑的内容,而且还有生动的图画,这无非给了初学者一个很好的开始,不仅会信心大增,也会提高学习兴趣,同时对后续的提高也打下了基础。着重基本语法的理解和基本概念的阐述,穿插在各个章节的练习题恰好提供了巩固作用,如果你正苦于寻找一本SQL入门书籍,那么它一定是不二之选


读者评价:


@SZ:这本对所有没SQL基础的人来说都是本好书,生动的图画,幽默的语言,紧凑的内容,让你爱不释手,绝对是入门SQL的好!

@qiao:由于之前有点SQL基础,所以一个下午就把这本书翻完了。秉承了HeadFirst系列一贯的诙谐风格,适合完完全全的新手。



5、《SQL 反模式》


640?wx_fmt=jpeg


Bill Karwin 著,谭振林 / Push Chen 译


● 广受好评的SQL图书


《SQL反模式》是一本广受好评的SQL图书。它介绍了如何避免在SQL的使用和开发中陷入一些常见却经常被忽略的误区。它通过讲述各种具体的案例,以及开发人员和使用人员在面对这些案例时经常采用的错误解决方案,来介绍如何识别、利用这些陷阱,以及面对问题时正确的解决手段。另外,《SQL反模式》还涉及了SQL的各级范式和针对它们的正确理解。


读者书评:


@匿名:看完了发现自己也有过错误的设计. 这部书把不少错误设计和实践都总结出来了, 以后应该避免.

@秋夜:这本书讲的东西,只有维护过一堆烂代码和槽糕的数据库设计的人才能体会。 至少没有外键,也不设主键的系统我是见过的 本书讨论的主题是非常实用的,而且是开发中的一些重要问题

@匿名:书不错,特别是每一章的例子都很好


接下去,程序员书库还会推荐其他关系数据库参考图书,诸如Oracle、MySQL、PostgreSQL等。或者你想看到哪方面的书籍推荐也可留言区告诉我我们。

640?wx_fmt=png

  • 7
    点赞
  • 93
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL语言快速入门之二   创建表格 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 tablename set columnname = newvalue [, nextcolumn = newvalue2...] where columnname OPERATOR value [and|or column OPERATOR value]; 例如: update employee set age = age+1 where first_name= ‘Mary’and last_name= ‘Williams’; 使用update语句时,关键一点就是要设定好用于进行判断的where条件从句。 删除记录 SQL语言使用delete语句删除数据库表格中的行或记录。Delete语句的格式为: delete from tablename where columnname OPERATOR value [and|or column OPERATOR value]; 例如: delete from employee where 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语句的语法结构和风格还是相当简单和直观的,只要用户结合实践多加练习,一定会在短期内迅速掌握。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值