赞
踩
SQL(Structured Query Language:结构化查询语言)是用于管理关系数据库系统。SQL的范围包括数据插入、查询、更新和删除,数据库模式创建和修改,以及数据访问控制。
- SQL面向数据库执行查询、存取数据
- SQL可以在数据库中插入、更新、删除记录
- SQL可以创建新的数据库并在数据库中建立新表和存储过程
- SQL可以在数据库中创建视图,设置表、存储过程中和视图的权限
在您的网站中使用SQL,要创建一个显示数据库中数据的网站,您需要:
RDBMS
RDBMS 指关系型数据库管理系统,全称 Relational Database Management System。
RDBMS 是 SQL 的基础,同样也是所有现代数据库系统的基础,比如 MS SQL Server、IBM DB2、Oracle、MySQL 以及 Microsoft Access。
RDBMS 中的数据存储在被称为表的数据库对象中。
表是相关的数据项的集合,它由列和行组成。
一个数据库通常包含一个或多个表,每个表有一个名字标识(例如“Websites”),表包含带有数据的记录(行)。
SELECT *FROM Websites;
SQL语句后面的分号?
某些数据库系统要求每条SQL语句的末端使用分号。
分号是在数据库系统中分隔每条SQL语句的标准方法,这样就可以在对服务器的相同请求中执行一条以上的SQL语句。
一些比较重要的SQL命令
SELECT语句用于从数据库中选取数据,将结果存储在一个结果表中,称为结果集。
SQL SELECT语法
- SELECT colum1,colum2,....
- FROM table_name;
或者
SELECT *FROM table_name;
参数说明:
示例演示:
以下为某小学部分学生信息表,表名为Student
学号(id) | 姓名(name) | 年级(grade) | 班级(class) | 学科(course) |
1204 | 小红 | 二年级 | 三班 | 数学 |
1205 | 小兰 | 三年级 | 一班 | 语文 |
1206 | 小艾 | 二年级 | 二班 | 数学 |
1207 | 小粉 | 一年级 | 一班 | 语文 |
下面的SQL语句从"Student"表中选取"name"和"class"列
SELECT name,class FROM Student;
输出结果为:
姓名(name) 班级(class) 小红 三班 小兰 一班 小艾 二班 小粉 一班
在上述表格中选取所有的列:
SELECT *FROM Student;
输出结果为:
学号(id) 姓名(name) 年级(grade) 班级(class) 学科(course) 1204 小红 二年级 三班 数学 1205 小兰 三年级 一班 语文 1206 小艾 二年级 二班 数学 1207
小粉 一年级 一班 语文
SELECT DISTINCT语句用于返回唯一不同的值(通俗来讲就是去掉选取的对象中重复的值)。
SELECT DISTINCT语法:
SELECT DISTINCT column1, column2, ... FROM table_name;参数说明:
- column1,column2,.....要选择的字段名称,可以为多个字段。如果不指定字段名称,则回选择所有字段。
- table_name:要查询的表名称。
示例:在Student表中,筛选出班级(class)中唯一不同的值,也就是去掉“class”中的重复值
SELECT DISTINCT class FROM Student;
输出结果:
班级(class) |
三班 |
一班 |
二班 |
WHERE子句用于过滤记录。,提取出满足条件的记录。
WHERE语法:
SELECT column1,column2,... FROM table_name WHERE condition;参数说明:
- column1, column2, ...:要选择的字段名称,可以为多个字段。如果不指定字段名称,则会选择所有字段。
- table_name:要查询的表名称。
演示说明,此处我们继续使用Student表的数据
从Student表中筛选出班级为一班的学生姓名:
SELECT name FROM Student WHERE class="一班";
执行输出结果:
姓名(name) | 班级(class) |
小蓝 | 一班 |
小粉 | 一班 |
文本字段VS.数值字段
SQL使用单引号来环绕文本值(大部分数据库系统也接受双引号),在上个实例中"一班"文本字段使用了双引号,但是如果是数值字段,请不要使用引号。
示例:
SELECT *FROM Student WHERE id=1204
执行输出结果
学号(id) | 姓名(name) | 年级(grade) | 班级(class) | 学科(course) |
1204 | 小红 | 二年级 | 三班 | 数学 |
下面的运算符可以在WHERE子句中使用:
运算符 | 描述 |
= | 等于 |
<> | 不等于。注释:在SQL一些版本中,该操作符可被写成!= |
> | 大于 |
< | 小于 |
>= | 大于等于 |
<= | 小于等于 |
BETWEEN | 在某个范围内 |
LIKE | 搜某种模式 |
IN | 指定针对某个列的多个可能值 |
AND & OR运算符用于基于一个以上的条件对记录进行过滤。
如果第一个条件和第二个条件都成立,则AND运算符显示一条记录。
如果第一个条件和第二个条件中只要有一个成立,则OR运算符显示一条记录。
演示示例
我们在Student表中再添加一列学生的成绩,新表如下所示:
学号(id) | 姓名(name) | 年级(grade) | 班级(class) | 学科(course) | 成绩(score) |
1204 | 小红 | 二年级 | 三班 | 数学 | 98 |
1205 | 小兰 | 三年级 | 一班 | 语文 | 88 |
1206 | 小艾 | 二年级 | 二班 | 数学 | 92 |
1207 | 小粉 | 一年级 | 一班 | 语文 | 90 |
下面的SQL语句是从Student表中选取班级为二年级且成绩大于95的学生。
SELECT *FROM Student WHERE grade='二年级' AND score >95;
执行输出结果:
学号(id) 姓名(name) 年级(grade) 班级(class) 学科(course) 成绩(score) 1204 小红 二年级 三班 数学 98
下面的SQL语句从Student表中选取年级为“二年级”或者“三年级”的所有学生
SELECT * FROM Student WHERE grade='二年级' OR grade='三年级';输出执行结果:
学号(id) 姓名(name) 年级(grade) 班级(class) 学科(course) 成绩(score) 1204 小红 二年级 三班 数学 98 1205 小兰 三年级 一班 语文 88 1206 小艾 二年级 二班 数学 92
也可以把AND和OR结合起来(使用圆括号来组成复杂的表达式)。
下面的SQL语句从Student表中选取成绩大于90且班级为一班或者二班的学生信息。
SELECE *FROM Student WHERE score>90 AND(class='一班' OR '二班');执行输出结果:
学号(id) 姓名(name) 年级(grade) 班级(class) 学科(course) 成绩(score) 1206 小艾 二年级 二班 数学 92 1207 小粉 一年级 一班 语文 90
ORDER BY 关键字用于对结果集进行排序。
ORDER BY 关键字用于对结果集按照一个列或多个列进行排序。
ORDER BY 关键字默认按照升序对记录进行排序。如果需要按照降序对记录进行排序,可以使用DESC关键字。
SQL ORDER BY 语法
- SELECT column1, column2, ...
- FROM table_name
- ORDER BY column1, column2, ... ASC|DESC;
演示数据库
此处我们继续使用Student表中数据。
下面的SQL语句从Student表中选取所有学生信息,并按照成绩升序排序:
SELECT *FROM Student ORDER BY score;执行输出结果:
学号(id) 姓名(name) 年级(grade) 班级(class) 学科(course) 成绩(score) 1204 小红 二年级 三班 数学 98 1206 小艾 二年级 二班 数学 92 1207 小粉 一年级 一班 语文 90 1205 小兰 三年级 一班 语文 88
下面的SQL语句从Student表中选取所有学生信息,并按照学号降序排序:
SELECT * FROM Student ORDER BY id DESC;执行输出结果:
学号(id) 姓名(name) 年级(grade) 班级(class) 学科(course) 成绩(score) 1207 小粉 一年级 一班 语文 90 1206 小艾 二年级 二班 数学 92 1205 小兰 三年级 一班 语文 88 1204 小红 二年级 三班 数学 98
下面的SQL语句从Student表中选取所有学生信息,并按照年级和班级排序:
SELECT * FROM Student ORDER BY grade,class;执行输出结果:
学号(id) 姓名(name) 年级(grade) 班级(class) 学科(course) 成绩(score) 1207 小粉 一年级 一班 语文 90 1206 小艾 二年级 二班 数学 92 1204 小红 二年级 三班 数学 98 1205 小兰 三年级 一班 语文 88
INSERT INTO 语句用于向表中插入新记录。
INSERT INTO语句可以有两种编写形式,第一种形式无需指定要插入数据的列名,只需提供被插入的值即可。
- INSERT INTO table_name
- VALUES(value1,value2,value3,...);
第二种形式需要指定列名及被插入的值:
- INSERT INTO table_name (column1,column2,column3,...)
- VALUES (value1,value2,value3,...);
参数说明:
演示数据库
假设我们要在Student表中插入一个新行,可以使用下面的语句
INSERT INTO Student (name, grade, class,course,score) VALUES ('小紫','二年级','一班','语文','95');执行以上SQL,再次读取"Student"表,数据如下所示:
学号(id) 姓名(name) 年级(grade) 班级(class) 学科(course) 成绩(score) 1204 小红 二年级 三班 数学 98 1205 小兰 三年级 一班 语文 88 1206 小艾 二年级 二班 数学 92 1207 小粉 一年级 一班 语文 90 1208 小紫 二年级 一班 语文 95
注意:id列是自动更新的,表中的每条记录都有一个唯一的数字。
UODATE语句用于更新表中已存在的记录。
SQL UPDATE语法
- UPDATE table_name
- SET column1 = value1, column2 = value2, ...
- WHERE condition;
参数说明:
请注意 SQL UPDATE 语句中的 WHERE 子句!
WHERE 子句规定哪条记录或者哪些记录需要更新。如果您省略了 WHERE 子句,所有的记录都将被更新
演示数据库
我们将继续使用Student表进行数据演示。
假设我们要将小兰的成绩改为95,学科改为数学。
UPDATE Student SET SCORE='95',COUESR='数学' WHERE name='小兰';执行以上SQL,再读取表格,数据如下所示:
学号(id) 姓名(name) 年级(grade) 班级(class) 学科(course) 成绩(score) 1204 小红 二年级 三班 数学 98 1205 小兰 三年级 一班 数学 95 1206 小艾 二年级 二班 数学 92 1207 小粉 一年级 一班 语文 90 1208 小紫 二年级 一班 语文 95
警告!
在更新记录表时,我们如果省略了WHERE语句,如下所示:
- UPDATE Student
- SET score='95',course='数学'
执行以上代码会将Student表中所有的数据的score改为95,course改为数学。
DELETE语句用于删除标总的行记录。
SQL DELETE语法
- DELETE FROM table_name
- WHERE condition;
参数说明:
假设我们要从Student表中删除名为”小粉"且成绩在90分以上的信息。
DELETE FROM Student where name='小粉'AND score>'90';执行以上结果,重新读取Student表,数据如下所示:
学号(id) 姓名(name) 年级(grade) 班级(class) 学科(course) 成绩(score) 1205 小兰 三年级 一班 语文 88
注释:在删除记录时要格外小心!因为您不能重来!在写删除代码时,WHERE 子句规定哪条记录或者哪些记录需要删除。如果您省略了 WHERE 子句,所有的记录都将被删除!
SQL入门教程到这里就结束啦,更多精彩内容敬请期待吧!!!!!码字不易,希望可以一键三连哦!!!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。