当前位置:文档之家› SQL语句学习实例版.

SQL语句学习实例版.

SQL语句学习实例版.
SQL语句学习实例版.

SQL语句学习手册实例版(仅供学习

表操作

例1 对于表的教学管理数据库中的表STUDENTS,可以定义如下: CREATE TABLE STUDENTS

(SNO NUMERIC (6, 0 NOT NULL

SNAME CHAR (8 NOT NULL

AGE NUMERIC(3,0

SEX CHAR(2

BPLACE CHAR(20

PRIMARY KEY(SNO

例2 对于表的教学管理数据库中的表ENROLLS,可以定义如下: CREATE TABLE ENROLLS

(SNO NUMERIC(6,0 NOT NULL

CNO CHAR(4 NOT NULL

GRADE INT

PRIMARY KEY(SNO,CNO

FOREIGN KEY(SNO REFERENCES STUDENTS(SNO

FOREIGN KEY(CNO REFERENCES COURSES(CNO

CHECK ((GRADE IS NULL OR (GRADE BETWEEN 0 AND 100

例 3 根据表的 STUDENTS 表,建立一个只包含学号、姓名、年龄的女学生表。

CREATE TABLE GIRL

AS SELECT SNO, SNAME, AGE

FROM STUDENTS

WHERE SEX='女';

例4 删除教师表TEACHER。

DROP TABLE TEACHER

例5 在教师表中增加住址列。

ALTER TABLE TEACHERS

ADD (ADDR CHAR(50

例6 把STUDENTS表中的BPLACE列删除,并且把引用BPLACE列的所有视图和约束也一起删除。

ALTER TABLE STUDENTS

DROP BPLACE CASCADE

例7 补充定义ENROLLS表的主关键字。

ALTER TABLE ENROLLS

ADD PRIMARY KEY (SNO,CNO;

视图操作(虚表

例9 建立一个只包括教师号、姓名和年龄的视图FACULTY。(在视图定义中不能包含ORDER BY子句

CREATE VIEW FACULTY

AS SELECT TNO, TNAME, AGE

FROM TEACHERS

例10 从学生表、课程表和选课表中产生一个视图GRADE_TABLE,它包括学生姓名、课程名和成绩。

CREATE VIEW GRADE_TABLE

AS SELECT SNAME,CNAME,GRADE

FROM STUDENTS,COURSES,ENROLLS

WHERE STUDENTS.SNO=ENROLLS.SNO AND

https://www.doczj.com/doc/c116757593.html,O=https://www.doczj.com/doc/c116757593.html,O

例11 删除视图GRADE_TABLE

DROP VIEW GRADE_TABLE REST RICT

索引操作

例12 在学生表中按学号建立索引。

CREATE UNIQUE INDEX ST

ON STUDENTS (SNO,ASC

例13 删除按学号所建立的索引。

DROP INDEX ST

数据库模式操作

例14 创建一个简易教学数据库的数据库模式 TEACHING_DB,属主为ZHANG。

CREATE SCHEMA TEACHING_DB AUTHRIZATION ZHANG

例15 删除简易教学数据库模式TEACHING_DB。((1选用CASCADE,即当删除数据库模式时,则本数据库模式和其下属的基本表、视图、索引等全部被删除。(2选用RESTRICT,即本数据库模式下属的基本表、视图、索引等事先已清除,才能删除本数据库模式,否则拒绝删除。 DROP SCHEMA TEACHING_DB CASCADE

单表操作

例16 找出3个学分的课程号和课程名。

SELECT CNO, CNAME

FROM COURSES

WHERE CREDIT=3

例17 查询年龄大于22岁的学生情况。

SELECT *

FROM STUDENTS

WHERE AGE>22

例18 找出籍贯为河北的男生的姓名和年龄。

SELECT SNAME, AGE

FROM STUDENTS

WHERE BPLACE='河北' AND SEX='男'

例19 找出年龄在20~23岁之间的学生的学号、姓名和年龄,并按年龄升序排序。(ASC(升序或DESC(降序声明排序的方式,缺省为升序。 SELECT SNO, SNAME, AGE

FROM STUDENTS

WHERE AGE BETWEEN 20 AND 23

ORDER BY AGE

例20 找出年龄小于23岁、籍贯是湖南或湖北的学生的姓名和性别。(条件比较运算符=、<和逻辑运算符AND(与,此外还可以使用的运算符有: >(大于、>=(大于等于、<=(小于等于、<>(不等于、NOT (非、OR(或等。

谓词LIKE 只能与字符串联用,常常是“<列名> LIKE pattern”的格式。特殊字符“_”和“%”作为通配符。

谓词IN表示指定的属性应与后面的集合(括号中的值集或某个查询子句的结果中的某个值相匹配,实际上是一系列的OR(或的缩写。谓词NOT IN 表示指定的属性不与后面的集合中的某个值相匹配。

谓词BETWEEN是“包含于…之中”的意思。

SELECT SNAME, SEX

FROM STUDENTS

WHERE AGE<23 AND BPLACE LIKE'湖%'

SELECT SNAME, SEX

FROM STUDENTS

WHERE AGE<23 AND BPLACE IN ('湖南','湖北'

例22 找出学生表中籍贯是空值的学生的姓名和性别。(在SQL中不能使用条件:<列名>=NULL。在SQL中只有一个特殊的查询条件允许查询NULL值:

SELECT SNAME, SEX

FROM STUDENTS

WHERE BPLACE IS NULL

多表操作

例23 找出成绩为95分的学生的姓名。(子查询

SELECT SNAME

FROM STUDENTS

WHERE SNO=

(SELECT SNO

FROM ENROLLS

WHERE GRADE=95

例24 找出成绩在90分以上的学生的姓名。

SELECT SNAME

FROM STUDENTS

WHERE SNO IN

(SELECT SNO

FROM ENROLLS

WHERE GRADE>90

SELECT SNAME

FROM STUDENTS

WHERE SNO=ANY

(SELECT SNO

FROM ENROLLS

WHERE GRADE>90

例25 查询全部学生的学生名和所学课程号及成绩。(连接查询 SELECT SNAME, CNO, GRADE

FROM STUDENTS, ENROLLS

WHERE STUDENTS.SNO=ENROLLS.SNO

例26 找出籍贯为山西或河北,成绩为90分以上的学生的姓名、籍贯和成绩。(当构造多表连接查询命令时,必须遵循两条规则。第一,连接条件数正好比表数少1(若有三个表,就有两个连接条件;第二,若一个表中的主关键字是由多个列组成,则对此主关键字中的每一个列都要有一个连接条件(也有少数例外情况

SELECT SNAME, BPLACE, GRADE

FROM STUDENTS, ENROLLS

WHERE BPLACE IN (…山西?,…河北? AND GRADE >=90 AND STUDENTS.SNO=ENROLLS.SNO

例28 查出课程成绩在80分以上的女学生的姓名、课程名和成绩。(FROM 子句中的子查询

SELECT SNAME,CNAME, GRADE

FROM (SELECT SNAME, CNAME , GRADE

FROM STUDENTS, ENROLLS,COURSES

WHERE SEX='女'

AS TEMP (SNAME, CNAME,GRADE

WHERE GRADE>80

表达式与函数的使用

例29 查询各课程的学时数。(算术表达式由算术运算符+、-、*、/与列名或数值常量所组成。

SELECT CNAME,COURSE_TIME=CREDIT*16

FROM COURSES

例30 找出教师的最小年龄。(内部函数:SQL标准中只使用COUNT、SUM、AVG、MAX、MIN函数,称之为聚集函数(Set Function。COUNT函数的结果是该列统计值的总数目,SUM函数求该列统计值之和, AVG函数求该列统计值之平均

值,MAX函数求该列最大值,MIN函数求该列最小值。

SELECT MIN(AGE

FROM TEACHERS

例31 统计年龄小于等于22岁的学生人数。(统计

SELECT COUNT(*

FROM STUDENTS

WHERE AGE <=22

例32 找出学生的平均成绩和所学课程门数。

SELECT SNO, AVG(GRADE, COURSES=COUNT(*

FROM ENROLLS

GROUP BY SNO

例34 找出年龄超过平均年龄的学生姓名。

SELECT SNAME

FROM STUDENTS

WHERE AGE >

(SELECT AVG(AGE

FROM STUDENTS

例35 找出各课程的平均成绩,按课程号分组,且只选择学生超过3人的课程的成绩。(GROUP BY 与HAVING

GROUP BY 子句把一个表按某一指定列(或一些列上的值相等的原则分组,然后再对每组数据进行规定的操作。

GROUP BY子句总是跟在WHERE子句后面,当WHERE子句缺省时,它跟在FROM子句后面。

HAVING子句常用于在计算出聚集之后对行的查询进行控制。

SELECT CNO, AVG(GRADE, STUDENTS=COUNT(*

FROM ENROLLS

GROUP BY CNO

HAVING COUNT(* >= 3

相关子查询

例37 查询没有选任何课程的学生的学号和姓名。(当一个子查询涉及到一个来自外部查询的列时,称为相关子查询(Correlated Subquery。相关子查询要用到存在测试谓词EXISTS和NOT EXISTS,以及ALL、ANY(SOME等。

SELECT SNO, SNAME

FROM STUDENTS

WHERE NOT EXISTS

(SELECT *

FROM ENROLLS

WHERE ENROLLS.SNO=STUDENTS.SNO

例38 查询哪些课程只有男生选读。

SELECT DISTINCT CNAME

FROM COURSES C

WHERE '男' =ALL

(SELECT SEX

FROM ENROLLS,STUDENTS

WHERE ENROLLS.SNO=STUDENTS.SNO AND

https://www.doczj.com/doc/c116757593.html,O=https://www.doczj.com/doc/c116757593.html,O

例39 要求给出一张学生、籍贯列表,该表中的学生的籍贯省份,也是其他一些学生的籍贯省份。

SELECT SNAME, BPLACE

FROM STUDENTS A

WHERE EXISTS

(SELECT *

FROM STUDENTS B

WHERE A.BPLACE=B.BPLACE AND

A.SNO < >

B.SNO

例40 找出选修了全部课程的学生的姓名。

本查询可以改为:查询这样一些学生,没有一门课程是他不选修的。

SELECT SNAME

FROM STUDENTS

WHERE NOT EXISTS

(SELECT *

FROM COURSES

WHERE NOT EXISTS

(SELECT *

FROM ENROLLS

WHERE ENROLLS.SNO=STUDENTS.SNO

AND https://www.doczj.com/doc/c116757593.html,O=https://www.doczj.com/doc/c116757593.html,O

关系代数运算

例41 设有某商场工作人员的两张表:营业员表SP_SUBORD和营销经理表SP_MGR,其关系数据模式如下:

SP_SUBORD (SALPERS_ID, SALPERS_NAME, MANAGER_ID, OFFICE

SP_MGR (SALPERS_ID, SALPERS_NAME, MANAGER_ID, OFFICE

其中,属性SALPERS_ID为工作人员的编号, SALPERS_NAME 为工作人员的姓名, MANAGER_ID为所在部门经理的编号, OFFICE为

工作地点。

若查询全部商场工作人员,可以用下面的SQL语句:

(SELECT * FROM SP_SUBORD

UNION

(SELECT * FROM SP_MGR

或等价地用下面的SQL语句:

SELECT *

FROM (TABLE SP_SUBORD UNION TABLE SP_MGR

(2INTERSECT

(SELECT * FROM SP_SUBORD

INTERSECT

(SELECT * FROM SP_MGR

或等价地用下面的SQL语句:

SELECT *

FROM (TABLE SP_SUBORD INTERSECT TABLE SP_MGR

或用带ALL的SQL语句:

(SELECT * FROM SP_SUBORD

INTERSECT ALL

(SELECT * FROM SP_MGR

SELECT *

FROM (TABLE SP_SUBORD INTERSECT ALL TABLE SP_MGR (3EXCEPT

(SELECT * FROM SP_MGR

EXCEPT

(SELECT * FROM SP_SUBORD

或等价地用下面的SQL语句:

SELECT *

FROM (TABLE SP_MGR EXCEPT TABLE SP_ SUBORD

或用带ALL的SQL语句:

(SELECT * FROM SP_MGR

EXCEPT ALL

(SELECT * FROM SP_SUBORD

例42 查询籍贯为四川、课程成绩在80分以上的学生信息及其成绩。(自然连接

(SELECT * FROM STUDENTS

WHERE BPLACE=…四川?

NATURAL JOIN

(SELECT * FROM ENROLLS

WHERE GRADE >=80

例3.43列出全部教师的姓名及其任课的课程号、班级。

(外连接与外部并外连接允许在结果表中保留非匹配元组,空缺部分填以NULL。外连接的作用是在做连接操作时避免丢失信息。

外连接有3类:

(1左外连接(Left Outer Join。连接运算谓词为LEFT [OUTER] JOIN,其结果表中保留左关系的所有元组。

(2右外连接(Right Outer Join。连接运算谓词为RIGHT [OUTER] JOIN,其结果表中保留右关系的所有元组。

(3全外连接(Full Outer Join。连接运算谓词为FULL [OUTER] JOIN,其结果表中保留左右两关系的所有元组。

SELECT TNAME, CNO, CLASS

FROM TEACHERS LEFT OUTER JOIN TEACHING USING (T NO

SQL的数据操纵

例44 把教师李映雪的记录加入到教师表TEACHERS中。(插入 INSERT INTO TEACHERS

VALUES(1476,'李映雪',44,'副教授'

例45 成绩优秀的学生将留下当教师。

INSERT INTO TEACHERS (TNO,TNAME

SELECT DISTINCT SNO,SNAME

FROM STUDENTS,ENROLLS

WHERE STUDENTS.SNO=ENROLLS.SNO AND GRADE>=90

例47 把所有学生的年龄增加一岁。(修改

UPDATE STUDENTS

SET AGE=AGE+1

例48 学生张春明在数据库课考试中作弊,该课成绩应作零分计。

UPDATE ENROLLS

SET GRADE=0

WHERE CNO='C1' AND

'张春明'=

(SELECT SNAME

FROM STUDENTS

WHERE STUDENTS.SNO=ENROLLS.SNO

例49 从教师表中删除年龄已到60岁的退休教师的数据。(删除 DELETE FROM TEACHERS

WHERE AGE >=60

SQL的数据控制

例50 授予LILI有对表STUDENTS的查询权。(表/视图特权的授予一个SQL 特权允许一个被授权者在给定的数据库对象上进行特定的操作。授权操作的数据库对象包括:表/视图、列、域等。授权的操作包括: INSERT、UPDATE、DELETE、SELECT、REFERENCES、TRIGGER、UNDER、USAGE、EXECUTE等。其中INSERT、

UPDATE、DELETE、SELECT、REFERENCES、TRIGGER有对表做相应操作的权限,故称为表特权。

GRANT SELECT ON STUDENTS

TO LILI

WITH GRANT OPTION

例51 取消LILI的存取STUDENTS表的特权。

REVOKE ALL

ON STUDENTS

FROM LILI CASCADE

不断补充中:

1. 模糊查找:

它判断列值是否与指定的字符串格式相匹配。可用于char、varchar、text、ntext、datetim e 和smalldatetime等类型查询。

可使用以下通配字符:

百分号%:可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。

下划线_:匹配单个任意字符,它常用来限制表达式的字符长度。

方括号[]:指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。[^]:其取值也[] 相同,但它要求所匹配对象为指定字符以外的任一个字符。

例如:

限制以Publishing结尾,使用LIKE '%Publishing'

限制以A开头:LIKE '[A]%'

限制以A开头外:LIKE '[^A]%'

2.更改表格

ALTER TABLE table_nam e

ADD COLUMN column_name DATATYPE

说明:增加一个栏位(没有删除某个栏位的语法。

ALTER TABLE table_name

ADD PRIMARY KEY (column_name

说明:更改表得的定义把某个栏位设为主键。

ALTER TABLE table_name

DROP PRIMARY KEY (column_name

说明:把主键的定义删除。

3.group by

在select 语句中可以使用group by 子句将行划分成较小的组,然后,使用聚组函数返回每一个组的汇总信息,另外,可以使用having子句限制返回的结果集。group by 子句可以将查询结果分组,并返回行的汇总信息Oracle 按照group by 子句中指定的表达式的值分组查询结果。

在带有group by 子句的查询语句中,在select 列表中指定的列要么是group by 子句中指定的列,要么包含聚组函数

select m ax(sal,job emp group by job;

(注意max(sal,job的job并非一定要出现,但有意义

查询语句的select 和group by ,having 子句是聚组函数唯一出现的地方,在where 子句中不能使用聚组函数。

select deptno,sum(sal from emp where sal>1200 group by deptno having

sum(sal>8500 order by deptno;

当在gropu by 子句中使用having 子句时,查询结果中只返回满足having条件的组。在一个sql语句中可以有where子句和having子句。having 与where 子句类似,均用于设置限定条件

where 子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使用where条件显示特定的行。

having 子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having 条件显示特定的组,也可以使用多个分组标准进行分组。

查询每个部门的每种职位的雇员数

select deptno,job,count(* from emp group by deptno,job;

4.外连接与内连接

有时候,即使在连接的表中没有相应的行,用户可能想从一张表中看数据,Oracle 提供了外连接实现该功能。

内连接是指连接查询只显示完全满足连接条件的记录,即等值连接,外连接的查询结果是内连接查询结果的扩展。外连接不仅返回满足连接条件的所有记录而且也返回了一个表中那些在另一个表中没有匹配行的记录。外连接的操作符是“+”。“+”

号放在连接条件中信息不完全的那一边(即没有相应行的那一边。运算符“+”影响NULL行的建立。建一行或多行NULL来匹配连接的表中信息完全的行。

外连接运算符“+”只能出现在where子句中表达式的一边。

假如在多张表之间有多个连接条件,外连接运算符不能使用or,in逻辑运算符与其它条件组合。

假如emp表中deptno=10的ename为空值,dept表中deptno=20的loc为空值:

1.

select

enam e,dept.deptno,loc

from

em p,dept

where

em p.depno(+=dept.deptno;

如果在dept.deptno中有的数值在emp.deptno中没有值,则在做外连接时,

结果中ename会产生一个空值。(emp.deptno=10

2.

select

enam e,dept.deptno,loc

from

常用SQL语句大全

常用SQL语句大全 一、基础 1、说明:创建数据库 CREATE DATABASE database-name 2、说明:删除数据库 DROP database dbname 3、说明:备份sql server --- 创建备份数据的device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' --- 开始备份 BACKUP DATABASE pubs TO testBack 4、说明:创建新表 create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..) 根据已有的表创建新表: A:create table tab_new like tab_old (使用旧表创建新表) B:create table tab_new as select col1,col2…from tab_old definition only 5、说明:删除新表 DROP table tabname 6、说明:增加一个列 Alter table tabname add column col type 注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。 7、说明:添加主键:Alter table tabname add primary key(col) 说明:删除主键:Alter table tabname DROP primary key(col) 8、说明:创建索引:create [unique] index idxname on tabname(col….) 删除索引:DROP index idxname 注:索引是不可更改的,想更改必须删除重新建。 9、说明:创建视图:create view viewname as select statement 删除视图:DROP view viewname 10、说明:几个简单的基本的sql语句 选择:select * from table1 where 范围 插入:insert into table1(field1,field2) values(value1,value2) 删除:delete from table1 where 范围 更新:update table1 set field1=value1 where 范围 查找:select * from table1 where field1 like ’%value1%’---like的语法很精妙,查资料! 排序:select * from table1 order by field1,field2 [desc] 总数:select count as totalcount from table1 求和:select sum(field1) as sumvalue from table1 平均:select avg(field1) as avgvalue from table1 最大:select max(field1) as maxvalue from table1 最小:select min(field1) as minvalue from table1 11、说明:几个高级查询运算词

数据库增删改查基本语句

数据库增删改查基本语句 adoquery1.Fielddefs[1].Name; 字段名 dbgrid1.columns[0].width:=10; dbgrid的字段宽度 adoquery1.Fields[i].DataType=ftString 字段类型 update jb_spzl set kp_item_name=upper(kp_item_name) 修改数据库表中某一列为大写select * from master.dbo.sysobjects ,jm_https://www.doczj.com/doc/c116757593.html,ers 多库查询 adotable1.sort:='字段名称ASC' adotable排序 SQL常用语句一览 sp_password null,'新密码','sa' 修改数据库密码 (1)数据记录筛选: sql="select * from 数据表where 字段名=字段值orderby 字段名[desc] " sql="select * from 数据表where 字段名like '%字段值%' orderby 字段名[desc]" sql="select top10 * from 数据表where 字段名orderby 字段名[desc]" sql="select * from 数据表where 字段名in('值1','值2','值3')" sql="select * from 数据表where 字段名between 值1 and 值2" (2)更新数据记录: sql="update 数据表set 字段名=字段值where 条件表达式" sql="update 数据表set 字段1=值1,字段2=值2……字段n=值n where 条件表达式" (3)删除数据记录: sql="delete from 数据表where 条件表达式" sql="delete from 数据表"(将数据表所有记录删除) (4)添加数据记录: sql="insert into 数据表(字段1,字段2,字段3…) values(值1,值2,值3…)" sql="insert into 目标数据表select * from 源数据表"(把源数据表的记录添加到目标数据表)

SQL语句基础教程汇总

无论您是一位SQL 的新手,或是一位只是需要对SQL 复习一下的资料仓储业界老将,您就来对地方了。这个SQL 教材网站列出常用的SQL 指令,包含以下几个部分: ? SQL 指令: SQL 如何被用来储存、读取、以及处理数据库之中的资料。 ?表格处理: SQL 如何被用来处理数据库中的表格。 ?进阶SQL: 介绍SQL 进阶概念,以及如何用SQL 来执行一些较复杂的运算。 ? SQL 语法: 这一页列出所有在这个教材中被提到的SQL 语法。 对于每一个指令,我们将会先列出及解释这个指令的语法,然后用一个例子来让读者了解这个指令是如何被运用的。当您读完了这个网站的所有教材后,您将对SQL 的语法会有一个大致上的了解。另外,您将能够正确地运用SQL 来由数据库中获取信息。笔者本身的经验是,虽然要对SQL 有很透彻的了解并不是一朝一夕可以完成的,可是要对SQL 有个基本的了解并不难。希望在看完这个网站后,您也会有同样的想法。 SQL指令 SELECT 是用来做什么的呢?一个最常用的方式是将资料从数据库中的表格内选出。从这一句回答中,我们马上可以看到两个关键字:从(FROM) 数据库中的表格内选出(SELECT)。(表格是一个数据库内的结构,它的目的是储存资料。在表格处理这一部分中,我们会提到如何使用SQL 来设定表格。) 我们由这里可以看到最基本的SQL 架构: SELECT "栏位名" FROM "表格名" 我们用以下的例子来看看实际上是怎么用的。假设我们有以下这个表格: store_name Sales Date Los Angeles $1500 Jan-05-1999 San Diego $250 Jan-07-1999 Los Angeles $300 Jan-08-1999 Boston $700 Jan-08-1999

SQL常用语法及例子精简——快速入手

sql语言 库表的增删改查常用语及语法 (1)数据记录筛选: sql="select*from 数据表where 字段名=字段值orderby字段名[desc]" sql="select*from 数据表where 字段名like'%字段值%'orderby字段名[desc]" sql="selecttop10*from 数据表where 字段名orderby字段名[desc]" sql="select*from 数据表where 字段名in('值1','值2','值3')" sql="select*from 数据表where 字段名between 值1and 值2" (2)更新数据记录: sql="update 数据表set 字段名=字段值where 条件表达式" sql="update 数据表set 字段1=值1,字段2=值2……字段n=值nwhere条件表达式" (3)删除数据记录: sql="de letefrom数据表where 条件表达式" sql="de letefrom数据表"(将数据表所有记录删除) (4)添加数据记录: sql="insertinto数据表(字段1,字段2,字段3…)values(值1,值2,值3…)" sql="insertinto目标数据表select*from 源数据表"(把源数据表的记录添加到目标数据表) (5)数据记录统计函数: AVG(字段名)得出一个表格栏平均值 COUNT(*|字段名)对数据行数的统计或对某一栏有值的数据行数统计 MAX(字段名)取得一个表格栏最大的值 MIN(字段名)取得一个表格栏最小的值 SUM(字段名)把数据栏的值相加 引用以上函数的方法: sql="selectsum(字段名)as 别名from 数据表where 条件表达式" setrs=conn.excute(sql) 用rs("别名")获取统的计值,其它函数运用同上。 (6)数据表的建立和删除: CREATETABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度)……) 例:CREATETABLEtab01 (namevarchar (50), datetimedefaultnow ()) DROPTABLE 数据表名称(永久性删除一个数据表) 4.记录集对象的方法: rs.movenext将记录指针从当前的位置向下移一行 rs.moveprevious将记录指针从当前的位置向上移一行 rs.movefirst将记录指针移到数据表第一行 rs.movelast将记录指针移到数据表最后一行 rs.absoluteposition=N 将记录指针移到数据表第N 行 rs.absolutepage=N 将记录指针移到第N 页的第一行 rs.pagesize=N 设置每页为N 条记录 rs.pagecount根据pagesize的设置返回总页数 rs.recordcount返回记录总数 rs.bof返回记录指针是否超出数据表首端,true 表示是,false 为否

数据库基本SQL语句大全

数据库基本SQL 语句大全 学会数据库是很实用D ??记录一些常用的sql 语句…有入门有提高 有见都没见过的…好全…收藏下… 其实一般用的就是查询,插入,删除等语句而已....但学学存储过程是好 事…以后数据方面的东西就不用在程序里搞喽?.而且程序与数据库只要 一个来回通讯就可以搞定所有数据的操作 一、基础 1、说明:创建数据库 Create DATABASE database-name 2、说明:删除数据库 drop database dbn ame 3、说明:备份sql server ---创建 备份数据的device USE master EXEC sp_addumpdevice ‘ disk ‘ c: MyNwind_1.dat ---开始备份 BACKU P DATABASE pubs TO testBack 4、说明:创建新表 create table tab name(col1 type1 [not n ull] [p rimary key],col2 type2 [not null],..) 根据已有的表创建新表: A : create table tab_new like tab_old 使用旧表创建新表) B : create table tab_new as select col1,col2 5、说明:删除新表 drop table tab name ‘ testBack ??- from tab_old defi niti on only

6、说明:增加一个列 Alter table tab name add colu mn col type 注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一 能改变的是增加varchar类型的长度。 7、说明:添加主键:Alter table tab name add p rimary key(col) 说明:删除主键:Alter table tab name drop p rimary key(col) 8、说明:仓J建索弓丨:c reate [uniq ue] in dex idx name on tab name(col ….) 删除索引:drop in dex idx name 注:索引是不可更改的,想更改必须删除重新 建。 9、说明:创建视图:create view view name as select stateme nt 删除视图:drop view view name 10、说明:几个简单的基本的sql语句 选择: select * from tablel where 范围 插入: in sert into table1(field1,field2) values(value1,value2) 删除: delete from table1 where 范围 更新: up date table1 set field1=value1 where 范围 查找: select * from tablel where fieldi like '%vkee的语法很精 妙,查资料! 排序: select * from tablei order by field1,field2 [desc] 总数: select count as totalco unt from tablei 求和: select sum(fieldi) as sumvalue from tablei 平均: select avg(fieldi) as avgvalue from tablei 最大: select max(fieldi) as maxvalue from tablei

SQL语句实例

表操作 例1 对于表的教学管理数据库中的表STUDENTS,可以定义如下:CREATE TABLE STUDENTS, ( SNO NUMERIC (6, 0) NOT NULL, SNAME CHAR (8) NOT NULL, AGE NUMERIC(3,0), SEX CHAR(2), BPLACE CHAR(20), PRIMARY KEY(SNO) ) 例2 对于表的教学管理数据库中的表ENROLLS,可以定义如下:CREATE TABLE ENROLLS ( SNO NUMERIC(6,0) NOT NULL, CNO CHAR(4) NOT NULL, GRADE INT, PRIMARY KEY(SNO,CNO), FOREIGN KEY(SNO) REFERENCES STUDENTS(SNO), FOREIGN KEY(CNO) REFERENCES COURSES(CNO), CHECK ((GRADE IS NULL) OR (GRADE BETWEEN 0 AND 100)) ) 例3 根据表的STUDENTS 表,建立一个只包含学号、姓名、年龄的女学生表。CREATE TABLE GIRL AS SELECT SNO, SNAME, AGE FROM STUDENTS WHERE SEX='女'; 例4 删除教师表TEACHER。 DROP TABLE TEACHER 例5 在教师表中增加住址列。 ALTER TABLE TEACHERS ADD (ADDR CHAR(50))

例6 把STUDENTS表中的BPLACE列删除,并且把引用BPLACE列的所有视图和约束也一起删除。 ALTER TABLE STUDENTS DROP BPLACE CASCADE 例7 补充定义ENROLLS表的主关键字。 ALTER TABLE ENROLLS ADD PRIMARY KEY (SNO,CNO); 视图操作(虚表) 例9 建立一个只包括教师号、姓名和年龄的视图FACULTY。(在视图定义中不能包含ORDER BY子句) CREATE VIEW FACULTY AS SELECT TNO, TNAME, AGE FROM TEACHERS 例10 从学生表、课程表和选课表中产生一个视图GRADE_TABLE,它包括学生姓名、课程名和成绩。 CREATE VIEW GRADE_TABLE AS SELECT SNAME,CNAME,GRADE FROM STUDENTS,COURSES,ENROLLS WHERE STUDENTS.SNO=ENROLLS.SNO AND https://www.doczj.com/doc/c116757593.html,O=https://www.doczj.com/doc/c116757593.html,O 例11 删除视图GRADE_TABLE DROP VIEW GRADE_TABLE RESTRICT 索引操作 例12 在学生表中按学号建立索引。 CREATE UNIQUE INDEX ST ON STUDENTS (SNO,ASC) 例13 删除按学号所建立的索引。 DROP INDEX ST 数据库模式操作 例14 创建一个简易教学数据库的数据库模式TEACHING_DB,属主为ZHANG。 CREATE SCHEMA TEACHING_DB AUTHRIZATION ZHANG 例15 删除简易教学数据库模式TEACHING_DB。((1)选用CASCADE,即当删除数据库模式时,则本数据库模式和其下属的基本表、视图、索引等全

数据库基础知识和sql语句

第一章数据库基础知识 本章以概念为主,主要是了解数据库的基本概念,数据库技术的发展,数据模型,重点是关系型数据。 第一节:信息,数据与数据处理 一、信息与数据: 1、信息:是现实世界事物的存在方式或运动状态的反映。或认为,信息是一种已经被加工为特定形式的数据。 信息的主要特征是:信息的传递需要物质载体,信息的获取和传递要消费能量;信息可以感知;信息可以存储、压缩、加工、传递、共享、扩散、再生和增值 2、数据:数据是信息的载体和具体表现形式,信息不随着数据形式的变化而变化。数据有文字、数字、图形、声音等表现形式。 3、数据与信息的关系:一般情况下将数据与信息作为一个概念而不加区分。 二、数据处理与数据管理技术: 1、数据处理:数据处理是对各种形式的数据进行收集、存储、加工和传输等活动的总称。 2、数据管理:数据收集、分类、组织、编码、存储、检索、传输和维护等环节是数据处理的基本操作,称为数据管理。数据管理是数据处理的核心问题。 3、数据库技术所研究的问题不是如何科学的进行数据管理。 4、数据管理技术的三个阶段:人工管理,文件管理和数据库系统。 第二节:数据库技术的发展 一、数据库的发展:数据库的发展经历了三个阶段: 1、层次型和网状型: 代表产品是1969年IBM公司研制的层次模型数据库管理系统IMS。 2、关系型数据型库: 目前大部分数据库采用的是关系型数据库。1970年IBM公司的研究员E.F.Codd提出了关系模型。其代表产品为sysem R和Inges。 3、第三代数据库将为更加丰富的数据模型和更强大的数据管理功能为特征,以提供传统数据库系统难以支持的新应用。它必须支持面向对象,具有开放性,能够在多个平台上使用。 二、数据库技术的发展趋势: 1、面向对象的方法和技术对数据库发展的影响: 数据库研究人员借鉴和吸收了面向对旬的方法和技术,提出了面向对象数据模型。 2、数据库技术与多学科技术的有机组合: 3、面向专门应用领域的数据库技术 三、数据库系统的组成:

SQL语句大全实例

SQL语句实例 表操作 例 1 对于表的教学管理数据库中的表STUDENTS ,可以定义如下:CREATE TABLE STUDENTS (SNO NUMERIC (6, 0) NOT NULL SNAME CHAR (8) NOT NULL AGE NUMERIC(3,0) SEX CHAR(2) BPLACE CHAR(20) PRIMARY KEY(SNO)) 例 2 对于表的教学管理数据库中的表ENROLLS ,可以定义如下: CREATE TABLE ENROLLS (SNO NUMERIC(6,0) NOT NULL CNO CHAR(4) NOT NULL GRADE INT PRIMARY KEY(SNO,CNO) FOREIGN KEY(SNO) REFERENCES STUDENTS(SNO) FOREIGN KEY(CNO) REFERENCES COURSES(CNO) CHECK ((GRADE IS NULL) OR (GRADE BETWEEN 0 AND 100))) 例 3 根据表的STUDENTS 表,建立一个只包含学号、姓名、年龄的女学生表。 CREATE TABLE GIRL

AS SELECT SNO, SNAME, AGE FROM STUDENTS WHERE SEX=' 女'; 例 4 删除教师表TEACHER 。 DROP TABLE TEACHER 例 5 在教师表中增加住址列。 ALTER TABLE TEACHERS ADD (ADDR CHAR(50)) 例 6 把STUDENTS 表中的BPLACE 列删除,并且把引用BPLACE 列的所有视图和约束也一起删除。 ALTER TABLE STUDENTS DROP BPLACE CASCADE 例7 补充定义ENROLLS 表的主关键字。 ALTER TABLE ENROLLS ADD PRIMARY KEY (SNO,CNO) ; 视图操作(虚表) 例9 建立一个只包括教师号、姓名和年龄的视图FACULTY 。( 在视图定义中不能包含ORDER BY 子句) CREATE VIEW FACULTY AS SELECT TNO, TNAME, AGE FROM TEACHERS 例10 从学生表、课程表和选课表中产生一个视图GRADE_TABLE ,它包括学生姓名、课程名和成绩。 CREATE VIEW GRADE_TABLE AS SELECT SNAME,CNAME,GRADE FROM STUDENTS,COURSES,ENROLLS WHERE STUDENTS.SNO =ENROLLS.SNO AND https://www.doczj.com/doc/c116757593.html,O=https://www.doczj.com/doc/c116757593.html,O 例11 删除视图GRADE_TABLE DROP VIEW GRADE_TABLE RESTRICT 索引操作 例12 在学生表中按学号建立索引。 CREATE UNIQUE INDEX ST ON STUDENTS (SNO,ASC) 例13 删除按学号所建立的索引。 DROP INDEX ST 数据库模式操作

SQL常用语句+举例

SQL 常用语句+举例 相关表: 1. distinct: 剔除重复记录 例:select distinct stroe_name from Store_information 结果: 2. And / or: 并且/或 例:在表中选出所有sales 高于$1000或是sales 在$275及$500之间的记录 Select store_name ,sales from Store_information Where sales>1000 Or (sales>275 and sales <500) 3. 例:在表中查找store_name 包含 Los Angeles 或San Diego 的记录 Select * from Store_information where store_name in (‘Los Angeles ’,’San Diego ’) 结果: 4. Between : 可以运用一个范围抓出表中的值

与in 的区别:in 依照一个或数个不连续的值的限制抓出表中的值 例:查找表中介于Jan-06-1999 及Jan-10-1999 中的记录 Select * from Store_information where date between ‘Jan-06-1999’ and ‘Jan-10-1999’ 结果: 5. Like : 让我们依据一个套式来找出我们要的记录 套式通常包含: ’A_Z ’: 所有以A 开头,中间包含一个字符,以Z 结尾的字串 ’ABC%’: 所有以ABC 起头的字串 ’%XYZ ’: 所有以XYZ 结尾的字串 ’%AN%’: 所有包含AN 的字串 例:Select * from Store_information where store_name like ‘%An%’ 结果: 6. Order by: 排序,通常与ASC (从小到大,升序)、DESC (从大到小,降序)结合使用 当排序字段不止一个时,先依据字段1排序,当字段1有几个值相同时,再依据字段2排序 例:表中sales 由大到小列出Store_information 的所有记录 Select Store_name, sales,date from Store_information order by sales desc 结果: 7. 函数:AVG (平均值)、COUNT (计数)、MAX (最大值)、MIN (最小值)、SUM(求和) 语句:select 函数名(字段名) from 表名 例:求出sales 的总和 Select sum(sales) from Store_information 结果 8. COUNT (计数) 例:找出Store_information 表中 有几个store_name 值不是空的记录

数据库基本SQL语句大全

数据库基本SQL语句大全 数据库基本----SQL语句大全 一、基础 1、说明:创建数据库 Create DATABASE database-name 2、说明:删除数据库 drop database dbname 3、说明:备份sql server --- 创建备份数据的device USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1、d at' --- 开始备份 BACKUP DATABASE pubs TO testBack 4、说明:创建新表 create table tabname(col1 type1 [not null] [primary key],col2 typ e2 [not null],、、) 根据已有的表创建新表: A:create table tab_new like tab_old (使用旧表创建新表) B:create table tab_new as select col1,col2…from tab_old definit ion only 5、说明:删除新表 drop table tabname 6、说明:增加一个列 Alter table tabname add column col type 注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的就是增加varchar类型的长度。 7、说明:添加主键: Alter table tabname add primary key(col) 说明:删除主键: Alter table tabname drop primary key(col) 8、说明:创建索引:create [unique] index idxname on tabname(col…、) 删除索引:drop index idxname 注:索引就是不可更改的,想更改必须删除重新建。 9、说明:创建视图:create view viewname as select statement

50个常用sql语句实例(学生表 课程表 成绩表 教师表)

Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,Tname) 教师表 create table Student(S# varchar(20),Sname varchar(10),Sage int,Ssex varchar(2)) 前面加一列序号: if exists(select table_name from information_schema.tables where table_name='Temp_Table') drop table Temp_Table go select 排名=identity(int,1,1),* INTO Temp_Table from Student go select * from Temp_Table go drop database [ ] --删除空的没有名字的数据库 问题: 1、查询“”课程比“”课程成绩高的所有学生的学号; select a.S# from (select s#,score from SC where C#='001') a,(select s#,score from SC where C#='002') b where a.score>b.score and a.s#=b.s#; 2、查询平均成绩大于分的同学的学号和平均成绩; select S#,avg(score) from sc group by S# having avg(score) >60; 3、查询所有同学的学号、姓名、选课数、总成绩; select Student.S#,Student.Sname,count(SC.C#),sum(score) from Student left Outer join SC on Student.S#=SC.S# group by Student.S#,Sname 4、查询姓“李”的老师的个数; select count(distinct(Tname)) from Teacher where Tname like '李%'; 5、查询没学过“叶平”老师课的同学的学号、姓名; select Student.S#,Student.Sname from Student

SQL入门基础语法

SQL语句的概述 SQL语言的分类 数据定义语言(Data Definition Language)主要用于修改、创建和删除数据库对象,其中包括CREATE ALTER DROP语句。 数据查询语言(Data Query Language)主要用于查询数据库中的数据,其主要是SELECT 语句,SELECT语句包括五个子句,分别是FROM WHERE HAVING GROUP BY 和WITH语句。 数据操作语言(Data Manipulation Language)主要用于更新数据库里数据表中的数据,包括INSERT UODATE DELETE语句。 数据控制语言(Data Control Language)主要用于授予和回收访问数据库的某种权限。包括GRANT REVOKE等语句。 事物控制语言,主要用于数据库对事物的控制,保证数据库中数据的一致性,包括COMMIT ROLLBACK语句。 常用的数据类型 MYSQL: SQL语句的书写规范 SQL语句中不区分关键字的大小写 SQL语句中不区分列名和对象名的大小写 SQL语句对数据库中数据的大小写敏感 SQL语句中使用--注释,当使用--注释时,--后面至少有--个空格,多行注释用/* */ 数据库的创建与删除

数据库的创建 CREATE DATABASE database_name; 在MYSQL COMMAND LINE CLIENT中书写SQL语句时,在SQL语句后面都要加上分号数据库的删除 DROP DATABASE database_name; 数据表的创建与更新 数据库中的表 数据记录:在数据表中的每一行被称为数据记录 字段:数据表中的每一列被称为字段 主键(PRIMARY KEY):作为数据表中唯一的表示,保证了每一天数记录的唯一性。主键在关系数据库中约束实体完整性。所谓的实体完整性,是指对数据表中行的约束。 外键(FOREIGN KEY):外键用来定义表与表之间的关系。在数据表中,如果属性列F是关系B中的一个属性(并不是关系B的主键),并且属性列F是关系A的主键,则F就是B 的外键。外键在关系数据库中约束参照完整性。所谓的参照完整性是指表与表之间的约束。 索引:索引是指向数据表中的一个指针,指向索引字段在数据表中的物理位置。一般可以在如下几种情况下建立索引 在主键列中创建索引 多表连接时,在经常使用的连接列上创建索引 在经常使用WHERE子句查询的列上创建索引 在经常进行分组GROUP BY及排序ORDER BY的列上创建索引 约束:为了保证数据的完整需要使用约束 1.唯一约束(UNIQUE)使用唯一约束的某一列或者某一组中没有相同的值,即保证 了值的唯一性。但是唯一约束中可以插入NULL值 2.主键约束(PRIMARY KEY)保证使用主键约束的列中只能有唯一的值,并且不能包 含NULL值,数据表中每一列只能定义一个PRIMARY KEY 3.外键约束(FOREIGN KEY)保证表参照完整性,确保对一个数据表的数据操作不会 对与之关联的表造成不利的影响 4.检查约束(CHECK)限制列的取值范围或者取值条件,可以为一个列定义多个CHECK 约束 5.非空约束(NOT NULL)用于对列的约束 创建数据表 CREATE TABLE table_name( column_name1 datatype [constraint_condition1] [,column name2 datatype [constraint_condition2] …) 使用约束 1.唯一约束(UNIQUE)用来保证某一列或者某一组列中没有相同的值,一般为列创建 了一个唯一约束后,数据库会自动为该列建立一个唯一索引,其索引名与约束名相同 例如:CREATE TABLE T_dept(

SQL查询语句例子

数据表的查询(select) select 字段列表[as 别名], * from 数据表名 [where 条件语句] [group by 分组字段] [order by 排序字段列表desc] [LIMIT startrow,rownumber] 1、Select 字段列表From 数据表 例:①、select id,gsmc,add,tel from haf (* 表示数据表中所有字段) ②、select 单价,数量,单价*数量as 合计金额from haf (As 设置字段的别名) 2、Select …from …Where 筛选条件式 筛选条件式:①、字符串数据:select * from 成绩单Where 姓名='李明' ②、万用字符:select * from 成绩单Where 姓名like '李%' select * from 成绩单Where 姓名like '%李%' select * from 成绩单Where 姓名like '%李_' ③、特殊的条件式: ⑴= / > / < / <> / >= / <= ⑵AND(逻辑与) OR(逻辑或) NOT(逻辑非) ⑶Where 字段名称in(值一,值二) ⑷Where 字段名称Is Null / Where 字段名称Is Not Null 3、Select …from …group by 字段 SQL函数: SELECT sex,count(id) as women from `user` group by 'sex'; 函数名描述函数名描述 AVG平均值Count计数 MAX最大值MIN最小值 Sum求和

SQL语句基础考核

/* --1.学生表 Student(SID,Sname,Sage,Ssex) --SID 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别 --2.课程表 Course(CID,Cname,TID) --CID --课程编号,Cname 课程名称,TID 教师编号 --3.教师表 Teacher(TID,Tname) --TID 教师编号,Tname 教师姓名 --4.成绩表 SC(SID,CID,score) --SID 学生编号,CID 课程编号,score 分数 */ --创建测试数据 createtable Student(SID varchar(10),Sname nvarchar(10),Sage datetime,Ssex nvarchar(10)) insertinto Student values('01',N'赵雷','1990-01-01',N'男') insertinto Student values('02',N'钱电','1990-12-21',N'男') insertinto Student values('03',N'孙风','1990-05-20',N'男') insertinto Student values('04',N'李云','1990-08-06',N'男') insertinto Student values('05',N'周梅','1991-12-01',N'女') insertinto Student values('06',N'吴兰','1992-03-01',N'女') insertinto Student values('07',N'郑竹','1989-07-01',N'女') insertinto Student values('08',N'王菊','1990-01-20',N'女') createtable Course(CID varchar(10),Cname nvarchar(10),TID varchar(10)) insertinto Course values('01',N'语文','02') insertinto Course values('02',N'数学','01') insertinto Course values('03',N'英语','03') createtable Teacher(TID varchar(10),Tname nvarchar(10)) insertinto Teacher values('01',N'张三') insertinto Teacher values('02',N'李四') insertinto Teacher values('03',N'王五') createtable SC(SID varchar(10),CID varchar(10),score decimal(18,1)) insertinto SC values('01','01', 80) insertinto SC values('01','02', 90) insertinto SC values('01','03', 99) insertinto SC values('02','01', 70) insertinto SC values('02','02', 60) insertinto SC values('02','03', 80) insertinto SC values('03','01', 80) insertinto SC values('03','02', 80) insertinto SC values('03','03', 80) insertinto SC values('04','01', 50) insertinto SC values('04','02', 30) insertinto SC values('04','03', 20) insertinto SC values('05','01', 76) insertinto SC values('05','02', 87) insertinto SC values('06','01', 31) insertinto SC values('06','03', 34) insertinto SC values('07','02', 89) insertinto SC values('07','03', 98) go --1、查询"01"课程比"02"课程成绩高的学生的信息及课程分数 --1.1、查询同时存在"01"课程和"02"课程的情况 select a.*,b.score[课程'01'的分数],c.score[课程'02'的分数]from Studenta,SCb,SCc where a.SID=b.SID and a.SID=c.SID and b.CID='01'and c.CID='02'and b.score>c.score --1.2、查询同时存在"01"课程和"02"课程的情况和存在"01"课程但可能不存在"02"课程的情况(不存在时显示为null)(以下存在相同内容时不再解释) select a.*,b.score[课程"01"的分数],c.score[课程"02"的分数]from Studenta leftjoin SCb on a.SID=b.SID and b.CID='01'

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

SQl数据库快速入门必须掌握的四大基本语句 做一个系统的后台,基本上都少不了增删改查,作为一个新手入门,我们必须要掌握SQL 四条最基本的数据操作语句:Insert,Select,Update和Delete!下面对这四个语句进行详细的剖析: 熟练掌握SQL是数据库用户的宝贵财富。在本文中,我们将引导你掌握四条最基本的数据操作语句—SQL的核心功能—来依次介绍比较操作符、选择断言以及三值逻辑。当你完成这些学习后,显然你已经开始算是真正SQL入门了。 在我们开始之前,先使用CREATE TABLE语句来创建一个表。DDL语句对数据库对象如表、列和视进行定义。它们并不对表中的行进行处理,这是因为DDL语句并不处理数据库中实际的数据。这些工作由另一类SQL语句—数据操作语言(DML)语句进行处理。 SQL中有四种基本的DML操作:INSERT,SELECT,UPDATE和DELETE。由于这是大多数SQL用户经常用到的,我们有必要在此对它们进行一一说明。在图1中我们给出了一个名为EMPLOYEES的表。其中的每一行对应一个特定的雇员记录。请熟悉这张表,我们在后面的例子中将要用到它。 INSERT语句 用户可以用INSERT语句将一行记录插入到指定的一个表中。例如,要将雇员John Smith 的记录插入到本例的表中,可以使用如下语句: INSERT INTO EMPLOYEES VALUES ('Smith','John','1980-06-10', 'Los Angles',16,45000); 通过这样的INSERT语句,系统将试着将这些值填入到相应的列中。这些列按照我们创建表时定义的顺序排列。在本例中,第一个值“Smith”将填到第一个列LAST_NAME中;第二个值“John”将填到第二列FIRST_NAME中……以此类推。 我们说过系统会“试着”将值填入,除了执行规则之外它还要进行类型检查。如果类型不符(如将一个字符串填入到类型为数字的列中),系统将拒绝这一次操作并返回一个错误信息。 如果SQL拒绝了你所填入的一列值,语句中其他各列的值也不会填入。这是因为SQL 提供对事务的支持。一次事务将数据库从一种一致性转移到另一种一致性。如果事务的某一部分失败,则整个事务都会失败,系统将会被恢复(或称之为回退)到此事务之前的状态。 回到原来的INSERT的例子,请注意所有的整形十进制数都不需要用单引号引起来,而字符串和日期类型的值都要用单引号来区别。为了增加可读性而在数字间插入逗号将会引起错误。记住,在SQL中逗号是元素的分隔符。 同样要注意输入文字值时要使用单引号。双引号用来封装限界标识符。 对于日期类型,我们必须使用SQL标准日期格式(yyyy-mm-dd),但是在系统中可以进行定义,以接受其他的格式。当然,2000年临近,请你最好还是使用四位来表示年份。 既然你已经理解了INSERT语句是怎样工作的了,让我们转到EMPLOYEES表中的其他部分: INSERT INTO EMPLOYEES VALUES ('Bunyan','Paul','1970-07-04', 'Boston',12,70000); INSERT INTO EMPLOYEES VALUES

相关主题
文本预览
相关文档 最新文档