语句SQl数据库快速入门必须掌握的四大基本语句

sql数据库入门  时间:2021-02-27  阅读:()

SQl数据库快速入门必须掌握的四大基本语句

做一个系统的后台基本上都少不了增删改查作为一个新手入门我们必须要掌握SQL四条最基本的数据操作语句 Insert  Select  Update和Delet e下面对这四个语句进行详细

的剖析

熟练掌握SQ L是数据库用户的宝贵财富。在本文中我们将引导你掌握四条最基本的数据操作语句—SQL的核心功能—来依次介绍比较操作符、选择断言以及三值逻辑。当你完成这些学习后显然你已经开始算是真正SQL入门了。

在我们开始之前先使用CREATE TABLE语句来创建一个表。 DDL语句对数据库对象如表、列和视进行定义。它们并不对表中的行进行处理这是因为DD L语句并不处理数据库中实际的数据。这些工作由另一类SQL语句—数据操作语言 DML语句进行处理。

SQL中有四种基本的DM L操作 INSERT SELECT UPDATE和DELET E。 由于这是大多数SQL用户经常用到的我们有必要在此对它们进行一一说明。在图1中我们给出了一个名为EMPLO YEES的表。其中的每一行对应一个特定的雇员记录。请熟悉这张表我们在后面的例子中将要用到它。

INSERT语句

用户可以用I NSERT语句将一行记录插入到指定的一个表中。例如要将雇员Jo hnSmith的记录插入到本例的表中可以使用如下语句

INSERT INTO EMPLOY EESVALUES

('Smith', 'John', '1980-06-10',

'LosAngles ',16,45000);

通过这样的I NSERT语句系统将试着将这些值填入到相应的列中。这些列按照我们创建表时定义的顺序排列。在本例中第一个值“Smith”将填到第一个列LAST_NAME中第二个值“Joh n”将填到第二列FIRST_NAM E中„„以此类推。

我们说过系统会“试着”将值填入除了执行规则之外它还要进行类型检查。如果类型不符如将一个字符串填入到类型为数字的列中 系统将拒绝这一次操作并返回一个错误信息。

如果SQL拒绝了你所填入的一列值语句中其他各列的值也不会填入。这是因为SQ L提供对事务的支持。一次事务将数据库从一种一致性转移到另一种一致性。如果事务的某一部分失败则整个事务都会失败系统将会被恢复或称之为回退到此事务之前的状态。

回到原来的I NSERT的例子请注意所有的整形十进制数都不需要用单引号引起来而字符串和日期类型的值都要用单引号来区别。为了增加可读性而在数字间插入逗号将会 引起错误。记住在SQL中逗号是元素的分隔符。

同样要注意输入文字值时要使用单引号。双引号用来封装限界标识符。

对于日期类型我们必须使用SQL标准日期格式yyyy-m m-d d 但是在系统中可以进行定义 以接受其他的格式。当然 2000年临近请你最好还是使用四位来表示年份。

既然你已经理解了INSE RT语句是怎样工作的了让我们转到E MPLOYE ES表中的其他部分

INSERT INTO EMPLOY EESVALUES

('Bunyan ','Paul ', '1970-07-04',

'Boston ',12,70000);

INSERT INTO EMPLOY EESVALUES

('John', 'Adams', '1992-01-21',

'Boston ',20,100000);

INSERT INTO EMPLOY EESVALUES

('Smith', 'Pocaho ntas', '1976-04-06',

'LosAngles ',12,100000);

INSERT INTO EMPLOY EESVALUES

('Smith', 'Bessie ','1940-05-02',

'Boston ',5,200000);

INSERT INTO EMPLOY EESVALUES

('Jones', 'Davy', '1970-10-10',

'Boston ',8,45000);

INSERT INTO EMPLOY EESVALUES

('Jones', ' Indian a', '1992-02-01',

'Chicag o',NULL,NULL);

在最后一项中我们不知道J ones先生的工薪级别和年薪所以我们输入NULL 不要引号。NULL是SQL中的一种特殊情况我们以后将进行详细的讨论。现在我们只需认为NULL表示一种未知的值。

有时像我们刚才所讨论的情况我们可能希望对某一些而不是全部的列进行赋值。除了对要省略的列输入NU LL外还可以采用另外一种INS ERT语句如下

INSERT INTO EMPLOY EES(

FI RST_NAME, LAST_N AME,

HIRE_D ATE,BRANCH_OFFIC E)

VALUE(

'1992-02-01', ' Indian apol is');

这样我们先在表名之后列出一系列列名。未列出的列中将自动填入缺省值如果没有设置缺省值则填入 NULL。请注意我们改变了列的顺序而值的顺序要对应新的列的顺序。如果该语句中省略了FIR ST_NAM E和LAST_NAME项这两项规定不能为空 SQL操作将失败。

让我们来看一看上述INS ERT语句的语法图

INSERT INTOtable

[(column {,column })]

VALUES

(column value[{,column value}]);

和前一篇文章中一样我们用方括号来表示可选项大括号表示可以重复任意次数的项不能在实际的SQL语句中使用这些特殊字符。 VALUE子句和可选的列名列表中必须使用圆括号。

SELECT语句

SELECT语句可以从一个或多个表中选取特定的行和列。因为查询和检索数据是数据库管理中最重要的功能所以SELECT语句在SQL中是工作量最大的部分。实际上仅仅是访问数据库来分析数据并生成报表的人可以对其他SQL语句一窍不通。

S E L E CT语句的结果通常是生成另外一个表。在执行过程中系统根据用户的标准从数据库中选出匹配的行和列并将结果放到临时的表中。在直接SQL direct SQL中它将结果显示在终端的显示屏上或者将结果送到打印机或文件中。也可以结合其他SQL语句来将

结果放到一个已知名称的表中。

S E L E CT语句功能强大。虽然表面上看来它只用来完成本文第一部分中提到的关系代数运算“选择” 或称“限制”  但实际上它也可以完成其他两种关系运算—“投影”和“连接” S E L E CT语句还可以完成聚合计算并对数据进行排序。

S E L E CT语句最简单的语法如下

SELECT column sFROMtables ;

当我们以这种形式执行一条SE LE CT语句时系统返回由所选择的列以及用户选择的表中所有指定的行组成的一个结果表。这就是实现关系投影运算的一个形式。

让我们看一下使用图1中E MPLOYE ES表的一些例子这个表是我们以后所有SE LECT语句实例都要使用的。而我们在图2和图3中给出了查询的实际结果。我们将在其他的例子中使用这些结果。

假设你想查看雇员工作部门的列表。那下面就是你所需要编写的SQL查询

SELECT BRANCH_OFFIC EFROM EMPLOY EES;

以上SELECT语句的执行将产生如图2中表2所示的结果。

由于我们在S ELE CT语句中只指定了一个列所以我们的结果表中也只有一个列。注意结果表中具有重复的行这是因为有多个雇员在同一部门工作记住SQL从所选的所有行中将值返回 。要消除结果中的重复行只要在SEL ECT语句中加上DISTINCT子句

SELECT DISTIN CTBRANCH_OFFICE

FROM EMPLOY EES;

这次查询的结果如表3所示。

现在已经消除了重复的行但结果并不是按照顺序排列的。如果你希望以字母表顺序将结果列出又该怎么做呢只要使用OR DER BY子句就可以按照升序或降序来排列结果

SELECT DISTIN CTBRANCH_OFFICE

FROM EMPLOY EES

ORDERBY BRANCH_OFFICEASC;

这一查询的结果如表4所示。请注意在OR DER BY之后是如何放置列名B RANCH_OFFICE 的这就是我们想要对其进行排序的列。为什么即使是结果表中只有一个列时我们也必须指出列名呢这是因为我们还能够按照表中其他列进行排序 即使它们并不显示出来。列名BRAN CH_OFFICE之后的关键字ASC表示按照升序排列。如果你希望以降序排列那么可以用关键字DESC。

同样我们应该指出ORDE RBY子句只将临时表中的结果进行排序并不影响原来的表。

假设我们希望得到按部门排序并从工资最高的雇员到工资最低的雇员排列的列表。除了工资括号中的内容我们还希望看到按照聘用时间从最近聘用的雇员开始列出的列表。以下是你将要用到的语句

SELECT BRANCH_OFFIC E,FIRST_NAME,

LAST_N AME,SALARY,HIRE_D ATE

FROM EMPLOY EES

ORDERBYSALARY DESC,

HIRE_DATE DESC;

这里我们进行了多列的选择和排序。排序的优先级由语句中的列名顺序所决定。SQL将先对列出的第一个列进行排序。如果在第一个列中出现了重复的行时这些行将被按照第二列进行排序如果在第二列中又出现了重复的行时这些行又将被按照第三列进行排序„„如此类推。这次查询的结果如表5所示。

将一个很长的表中的所有列名写出来是一件相当麻烦的事所以SQL允许在选择表中所

有的列时使用*号

SELECT *FROM EMPLOY EES;

这次查询返回整个EMPL OYEES表如表1所示。

下面我们对开始时给出的S ELECT语句的语法进行一下更新竖直线表示一个可选项允许在其中选择一项。 

SELECT [DISTIN CT]

(column [{, column s}]) | *

FROMtable[ {, table}]

[ORDER BYcolumn [ASC] |DESC

[ {, column [ASC] |DESC}] ];

定义选择标准

在我们目前所介绍的SEL ECT语句中我们对结果表中的列作出了选择但返回的是表中所有的行。让我们看一下如何对SEL ECT语句进行限制使得它只返回希望得到的行

SELECT column sFROM tables [WHERE predic ates];

WHERE子句对条件进行了设置只有满足条件的行才被包括到结果表中。这些条件由断言predic ate进行指定断言指出了关于某件事情的一种可能的事实 。如果该断言对于某个给定的行成立该行将被包括到结果表中否则该行被忽略。在SQL语句中断言通常通过比较来表示。例如假如你需要查询所有姓为J ones的职员则可以使用以下SELECT语句

SELECT *FROM EMPLOY EES

WHERE LAST_N AME='Jones';

LAST_N AME = 'Jones'部分就是断言。在执行该语句时 SQL将每一行的LAST_NAME列与“Jones”进行比较。如果某一职员的姓为“Jones”  即断言成立该职员的信息将被包括到结果表中见表6。

使用最多的六种比较

我们上例中的断言包括一种基于“等值”的比较LAST_N AME='Jones'但是SQL断言还可以包含其他几种类型的比较。其中最常用的为

等于=

不等于<>

小于<

大于>

小于或等于<=

大于或等于>=

下面给出了不是基于等值比较的一个例子

SELECT *FROM EMPLOY EES

WHERE SALARY >50000;

这一查询将返回年薪高于$50,000.00的职员参见表7。

逻辑连接符

有时我们需要定义一条不止一种断言的S ELECT语句。举例来说如果你仅仅想查看Davy Jones的信息的话表6中的结果将是不正确的。为了进一步定义一个WHE RE子句用户可以使用逻辑连接符A ND OR和NOT。为了只得到职员Davy Jones的记录用户可以输入如下语句

SELECT *FROM EMPLOY EES

WHERE LAST_N AME='Jones'AND FIRST_NAME='Davy';

在本例中我们通过逻辑连接符AND将两个断言连接起来。只有两个断言都满足时整个表达式才会满足。如果用户需要定义一个SE LECT语句来使得当其中任何一项成立就满足条件时可以使用OR连接符

SELECT *FROM EMPLOY EES

WHERE LAST_N AME='Jones'OR LAST_N AME='Smith';

有时定义一个断言的最好方法是通过相反的描述来说明。如果你想要查看除了Bos ton办事处的职员以外的其他所有职员的信息时你可以进行如下的查询

SELECT *FROM EMPLOY EES

WHERE NOT(BRANCH_OFFIC E='Boston');

关键字NOT后面跟着用圆括号括起来的比较表达式。其结果是对结果取否定。如果某一职员所在部门的办事处在Bos ton括号内的表达式返回tru e但是NOT操作符将该值取反所以该行将不被选中。

断言可以与其他的断言嵌套使用。为了保证它们以正确的顺序进行求值可以用括号将它们括起来

SELECT *FROM EMPLOY EES

WHERE (LAST_N AME='Jones'

AND FIRST_NAME=' Indian a')

OR(LAST_N AME='Smith'

AND FIRST_NAME='Bessie ');

SQL沿用数学上标准的表达式求值的约定—圆括号内的表达式将最先进行求值其他表达式将从左到右进行求值。

以上对逻辑连接符进行了说明在对下面的内容进行说明之前我们再一次对 SELE CT语句的语法进行更新

SELECT [DISTIN CT]

(column [{, column }] ) | *

FROMtable[ {, table} ]

[ORDER BY column [ASC] | [DESC

[{, column [ASC] | [DESC} ] ]

WHERE predic ate[ { logica l-connec tor predic ate}];

NULL和三值逻辑

在SQL中N ULL是一个复杂的话题关于NULL的详细描述更适合于在SQ L的高级教程而不是现在的入门教程中进行介绍。但由于NUL L需要进行特殊处理并且你也很可能会遇到它所以我们还是简略地进行一下说明。

首先在断言中进行NULL判断时需要特殊的语法。例如如果用户需要显示所有年薪未知的职员的全部信息用户可以使用如下SELE CT语句

SELECT *FROM EMPLOY EES

WHERESALARY ISNULL;

相反如果用户需要所有已知年薪数据的职员的信息你可以使用以下语句

SELECT *FROM EMPLOY EES

WHERESALARY ISNOTNULL;

请注意我们在列名之后使用了关键字IS NULL或I SNOTNULL而不是标准的比较形式COLUMN =NULL、 COLUMN <>NULL或是逻辑操作符N OT NULL。

这种形式相当简单。但当你不明确地测试NUL L而它们确实存在时事情会变得很混乱。

例如 回过头来看我们图1中的E M-PLOYEES表可以看到In dianaJones的工薪等级或年薪值都是未知的。这两个列都包含NU L L。可以想象运行如下的查询

SELECT *FROM EMPLOY EES

WHERE GRADE<=SALARY;

此时 Indian aJones应该出现在结果表中。因为NULL都是相等的所以可以想象它们是能够通过GRAD E小于等于SA LARY的检查的。这其实是一个毫无疑义的查询但是并没有关系。 SQL允许进行这样的比较只要两个列都是数字类型的。然而 Indian aJones并没有出现在查询的结果中为什么

正如我们早先提到过的 NULL表示未知的值而不是象某些人所想象的那样表示一个为NULL的值。对于SQL来说意味着这个值是未知的而只要这个值为未知就不能将其与其他值比较即使其他值也是NULL。所以SQL允许除了在tr ue和false之外还有第三种类型的真值称之为“非确定” unknow n值。

如果比较的两边都是NUL L整个断言就被认为是非确定的。将一个非确定断言取反或使用AND或O R与其他断言进行合并之后其结果仍是非确定的。 由于结果表中只包括断言值为“真”的行所以NULL不可能满足该检查。从而需要使用特殊的操作符IS NULL和ISNOTNULL。

UPDATE语句

UPDATE语句允许用户在已知的表中对现有的行进行修改。

例如我们刚刚发现Indian aJones的等级为16工资为$40,000.00我们可以通过下面的SQL语句对数据库进行更新并清除那些烦人的NULL 。

UPDATE EMPLOY EES

SET GRADE=16,SALARY =40000

WHERE FIRST_NAME=' Indian a'

AND LAST_N AME='Jones';

上面的例子说明了一个单行更新但是UPDATE语句可以对多行进行操作。满足WHERE条件的所有行都将被更新。如果你想让Bos ton办事处中的所有职员搬到New York你可以使用如下语句

UPDATE EMPLOY EES

SETBRANCH_OFFICE='NewYork'

WHERE BRANCH_OFFIC E='Boston';

如果忽略WH ERE子句,表中所有行中的部门值都将被更新为'NewYork'。

UPDATE语句的语法流图如下面所示

UPDATE table

SET column =value[{, column =value}]

[WHERE predic ate[ { logica l-connec tor predic ate}]];

DELETE语句

DELETE语句用来删除已知表中的行。如同UPDATE语句中一样所有满足WH ERE子句中条件的行都将被删除。由于SQL中没有UNDO语句或是“你确认删除吗 ”之类的警告在执行这条语句时千万要小心。如果决定取消Los Angele s办事处并解雇办事处的所有职员这一卑鄙的工作可以由以下这条语句来实现

DELETE FROM EMPLOY EES

WHERE BRANCH_OFFICE='LosAngele s';

如同UPDATE语句中一样省略WHER E子句将使得操作施加到表中所有的行。

DELETE语句的语法流图如下面所示

DELETE FROMtable

[WHERE predic ate[ { logica l-connec tor predic ate} ] ];

现在我们完成了数据操作语言DML的主要语句的介绍。我们并没有对SQL能完成的所有功能进行说明。 SQL还提供了许多的功能如求平均值、求和以及其他对表中数据的计算此外SQL还能完成从多个表中进行查询多表查询或称之为连接的工作。这种语言还允许你使用G R ANT和R E VOKE命令控制使用者的数据访问权限

数脉科技:六月优惠促销,免备案香港物理服务器,E3-1230v2处理器16G内存,350元/月

数脉科技六月优惠促销发布了!数脉科技对香港自营机房的香港服务器进行超低价促销,可选择30M、50M、100Mbps的优质bgp网络。更大带宽可在选购时选择同样享受优惠,目前仅提供HKBGP、阿里云产品,香港CN2、产品优惠码续费有效,仅限新购,每个客户可使用于一个订单。新客户可以立减400元,或者选择对应的机器用相应的优惠码,有需要的朋友可以尝试一下。点击进入:数脉科技官方网站地址数脉科技是一家成...

RepriseHosting:$27.97/月-L5640,16G内存,1TB硬盘,10TB月流量,西雅图机房

RepriseHosting是成立于2012年的国外主机商,提供独立服务器租用和VPS主机等产品,数据中心在美国西雅图和拉斯维加斯机房。商家提供的独立服务器以较低的价格为主,目前针对西雅图机房部分独立服务器提供的优惠仍然有效,除了价格折扣外,还免费升级内存和带宽,商家支持使用支付宝或者PayPal、信用卡等付款方式。配置一 $27.97/月CPU:Intel Xeon L5640内存:16GB(原...

EtherNetservers年付仅10美元,美国洛杉矶VPS/1核512M内存10GB硬盘1Gpbs端口月流量500GB/2个IP

EtherNetservers是一家成立于2013年的英国主机商,提供基于OpenVZ和KVM架构的VPS,数据中心包括美国洛杉矶、新泽西和杰克逊维尔,商家支持使用PayPal、支付宝等付款方式,提供 60 天退款保证,这在IDC行业来说很少见,也可见商家对自家产品很有信心。有需要便宜VPS、多IP VPS的朋友可以关注一下。优惠码SUMMER-VPS-15 (终身 15% 的折扣)SUMMER-...

sql数据库入门为你推荐
bbsxpbbsxp 2008 无法创建数据库支付宝查询余额支付宝钱包怎么查余额?天天酷跑刷积分教程最近一直有人说天天酷跑刷积分,怎么刷的。bluestacks安卓模拟器BlueStacks如何安装使用?xp系统停止服务Windowsxp系统为什么停止服务创维云电视功能创维健康云电视有什么功能?安装迅雷看看播放器迅雷看看播放器安装二层交换机二层交换机是什么意思,三层呢云挂机快手极速版后台云挂机辅?助各位用了吗?在哪找的?小米手柄小米手柄能连几个手机
上海vps 北京vps 如何申请免费域名 便宜建站 mobaxterm 监控宝 777te 秒杀预告 ntfs格式分区 国外代理服务器地址 架设邮件服务器 阿里云手机官网 forwarder 服务器是什么 卡巴斯基免费版下载 ddos攻击器 长沙服务器托管 网络时间服务器 web服务器配置 个人web服务器 更多