SQL基础教程
一、SQL简介
1:什么是SQL?
A:SQL指结构化查询语句 B:SQL使我们有能力访问数据库 C:SQL是一种ANSI(美国国家标准化组织)的标准计算机语言
2:SQL能做什么?
*面向数据库执行查询 *从数据库中取出数据 *向数据库插入新的记录
*更新数据库中数据 *从数据库删除记录 *创建数据库 *创建表
*创建存储过程 *创建视图 *设置表、存储过程和视图的权限
3:RDBMS
RDBMS是指关系型数据库管理系统
RDBMS是SQL的基础,同样也是所有现代数据库系统的基础,如MS SQL Server、IBM DB2、Oracle、MySQL以及Microsoft Access
RDBMS中的数据存储在被称为表的数据库对象中
表是相关的数据项的集合,他由列和行组成。
二、SQL语法
注意:SQL对大小写不敏感!!!
1:SQL语句后面的分号
某些数据库系统要求在每条SQL命令的末端使用分号。
分号是在数据库系统中分隔每条SQL语句的标准方法,这样就可以在服务器的相同请求中执行一条以上的语句。
如果使用的是MS Access和SQL Server 2000,则不必在每条SQL语句之后使用分号,不过某些数据库要求必须使用分号。
2:SQL DML和DDL
可以把SQL分为两个部分:数据操作语言(DML)和数据库定义语言(DDL)
SQL(结构化查询语句)适用于执行查询的语法。但是SQL语言也包含用于更新、插入和删除记录的语法。查询和更新构成了SQL的DML部分:select、update、delete、insert into 。 数据库定义语言(DDL)部分使我们有能力创建或删除表格,我们也可以定义索引(键),规定表之间的连接,以及事假表间的约束:
Create database、alert database、create table、alert table、drop table、create index、drop index
三、Select
User表里面的数据如下
data:image/s3,"s3://crabby-images/2700d/2700df576bc2a322c93171765d11811f8638e617" alt=""
查询user表里面的user_name字段和user_age字段的所有数据
Select user_name,user_age from user
data:image/s3,"s3://crabby-images/768bc/768bc718aa7fecd7629b0a99d5e74ebbd3e4800b" alt=""
查询user表中所有的字段数据,用 * 表示列的名称
Select * from user
data:image/s3,"s3://crabby-images/dba15/dba153c4c0304edcc285ea5227dada28d99ddd67" alt=""
四、Distinct
Distinct选取所有的值的时候不会出现重复的数据
用普通的查询,查询所有
Select * from user
data:image/s3,"s3://crabby-images/8588c/8588c78c0c3b4a1ecb33adfb43876dac7ba8c5d6" alt=""
Select distinct user_name,user_age from user
注意:不能有user_id,因为两个Mary的user_id不一样,加上就不算相同数据
data:image/s3,"s3://crabby-images/50c58/50c589ffdcaa23af5fb65fdd57c59118622264b4" alt=""
五、Where
1:查询user_id等于1 的数据
Select * from user where user_id = 1
data:image/s3,"s3://crabby-images/ed239/ed23913ea5ea875af5b4c1bb2921eabf2528c740" alt=""
2:查询user_age大于等于12的数据
Select * from user where user_age >=12
data:image/s3,"s3://crabby-images/a9a77/a9a773b0227d9efc2f8be5a0ad71d41929be1030" alt=""
3:查询user_age不等于12的数据
Select * from user where user_age <> 12
data:image/s3,"s3://crabby-images/ec6f5/ec6f5d8efb2d34506595b98cddf8098a2e55fa31" alt=""
六、AND 和 OR
And和or在where子语句中把两个或多个条件结合起来。如果需要两个条件都成立就是用and如果只需要其中一个条件成立就使用or
Select * from user where user_name = 'mary' and user_age = 12
需要注意的是SQL使用单引号来环绕文本值,如果是数值则不需要引号
data:image/s3,"s3://crabby-images/afea2/afea2cdc248f5b6a7636e93f6a8052f3c0ecce3a" alt=""
Select * from user where user_name='mary' or user_age =13
data:image/s3,"s3://crabby-images/cdfe6/cdfe6f1498a363023efbcc4e8a971bfbaf425fc1" alt=""
结合and和or使用圆括号来组成复杂的表达式
Select * from user where (user_name = 'mary' and user_age = 12) or(user_age =13)
data:image/s3,"s3://crabby-images/ddf54/ddf540982c31294986b7f3c8c5dce05257b71fec" alt=""
七、Order by
1:对指定列进行升序排列
Select * from user order by user_name
data:image/s3,"s3://crabby-images/ea581/ea581bf697dae9a19be8da8c87dab18fa1fa1e3f" alt=""
2:按照user_id逆序排列
Select * from user order by user_id DESC
data:image/s3,"s3://crabby-images/b3efe/b3efe32741f0a81e9c123c03e5f63a2bcbf41c21" alt=""
2:按照升序排列user_id逆序排列user_age
SELECT * FROM user order by user_id ASC,user_age DESC
data:image/s3,"s3://crabby-images/0180e/0180ee5656b7b0f265d186850e04f9f00b6e8c93" alt=""
3:按照升序排列user_id逆序排列user_age
SELECT * FROM user order by user_age DESC,user_id ASC
data:image/s3,"s3://crabby-images/52953/529535c4c408e83667b6922acf340fafec308fef" alt=""
注意:前面的条件优先级更高!!
八、Insert
User表
data:image/s3,"s3://crabby-images/72af8/72af860c66516c6abe2de0798881665bc60f5b68" alt=""
插入一行数据 user_id为2 user_name为tom,user_age为12
注意:如果每一项都有插入的话就不需要在前面列出列名!!
Insert into user values(2,'tom',12)
data:image/s3,"s3://crabby-images/f174e/f174efa9fbe62945d4cd27c694ce7ed856d64503" alt=""
新插入一行数据,只要求user_name为eva
Insert into user(user_name) values('eva')
注意:因为ID设置为自增,所以user_id不为null
data:image/s3,"s3://crabby-images/4d036/4d03652b644d8d39975fe61b5c24cc7b8b36e4e0" alt=""
九、Update
修改user_id为6的数据user_age为14
Update user set user_age=14 where user_id=6
data:image/s3,"s3://crabby-images/bc604/bc604af355777919030ab76bfbb8711c7790608e" alt=""
修改user_id为1的数据user_name为ann,user_age为11
Update user set user_name='ann',user_age=11 where user_id=1
data:image/s3,"s3://crabby-images/2e768/2e768ec8a0e31f946204028febe09dc65cf92ab4" alt=""
十、Delete
User表中的所有数据信息如下
data:image/s3,"s3://crabby-images/55b79/55b7951efb73c252131af78739670ec55fd9ebc3" alt=""
删除user_age为12的数据
Delete from user where user_age=12
data:image/s3,"s3://crabby-images/1139e/1139e17facb179415d58b15fdfbd857bf84bb3e1" alt=""
删除表中的所有数据
Delete from user
data:image/s3,"s3://crabby-images/56c07/56c0772d35188f90a4741f3a9203e401e9df3fae" alt=""
第二章 SQL高级教程
一、Top
Top子句用于返回要返回的记录的数目,但并不是所有的数据库都支持top子句
1:SQL Server
Select top 5 * from user
2:MySQL
Select * from user limit 5
3:Oracle
Select * from user where ROWNUM <= 5
二、Like
User表的初始数据如下
data:image/s3,"s3://crabby-images/20fe7/20fe742292e581e0b7e63756928f0703b3cf8e5c" alt=""
1:找出以li开头的数据
Select * from user where user_name like 'li%'
data:image/s3,"s3://crabby-images/4eab3/4eab3e2f738f617e7c6674bfe9e6babb995e538e" alt=""
2:找出以ry结尾的数据
Select * from user where user_name like '%ry'
data:image/s3,"s3://crabby-images/bf225/bf22566338d8aeb76081dc1892b7d5f42d0e9b7e" alt=""
3:找出含有a的数据
Select * from user where user_name like '%a%'
data:image/s3,"s3://crabby-images/ca043/ca043d48909d74482d8f908cafcd6eb21673171b" alt=""
4:找出第二个字母是a第四个字母是y的数据
Select * from user where user_name like '_a_y'
data:image/s3,"s3://crabby-images/b2525/b2525add8fd2808ff0c30c1d7937d1ff01c2a023" alt=""
三、通配符
在搜索数据库中的数据的时候SQL通配符可以替代一个或多个字符。SQL通配符必须与like运算符一起使用
1: _ 替代一个字符
找出第二个字母是a第四个字母是y的数据
Select * from user where user_name like '_a_y'
data:image/s3,"s3://crabby-images/0fab1/0fab156d843db5aa27ddd6bff14a62e41788f857" alt=""
2: % 替代一个或多个字符
找出以ry结尾的数据
Select * from user where user_name like '%ry'
data:image/s3,"s3://crabby-images/3dd70/3dd70c47497fa2bd8681caf2c51657ac6cf10b2f" alt=""
3: [] 字符列中的任意一个单字符
找出以a或者l开头的数据
Select * from user where user_name like '[al]%'
找出不是a或者l开头的数据
Select * from user where user_name like '[!al]%'
四、In
只要数据满足in里面的一个条件就可以了
找到user_age是12或者13的数据
Select * from user where user_age in (12,13)
data:image/s3,"s3://crabby-images/00d18/00d1816148dd6ce1c2f59ef014c92e412bb574fb" alt=""
找到user_name是Harry和Mary的数据
Select * from user where user_name IN ('mary','harry')
data:image/s3,"s3://crabby-images/560e1/560e12494d8382f637ba4a6722b0d4cd9bdb9f42" alt=""
五、Between
选取两个值之间的数据
查询年龄在12和14之间的数据
Select * from user where user_age between 12 and 14
data:image/s3,"s3://crabby-images/08b94/08b94bbf2b57b2b232f41e16b909f21d10bf89ae" alt=""
查询字母在Alice和John之间的数据
Select * from user where user_name between 'alice' AND'john'
data:image/s3,"s3://crabby-images/9a1b6/9a1b65f337c88ed43107563fcd2f55b55e023639" alt=""
六、Aliases
指定别名
假设我们有两个表分别是user和Room 。我们分别指定他们为u和r。
1:不使用别名
Select room.room_name,user.user_name,user.user_age from user ,room Where user.user_age=12 and room.room_id = 1
data:image/s3,"s3://crabby-images/1814d/1814dec70ce952926b18a16c9d8dd54dd23e8a8b" alt=""
2:使用别名
使用别名的时候直接将别名跟在后面,不使用as也可以
Select r.room_name,u.user_name,u.user_age from user as u,room as r Where u.user_age=12 and r.room_id = 1
data:image/s3,"s3://crabby-images/e7ab2/e7ab2fb4001224ec1d6799c1f6f7d3c8a413c36a" alt=""
七、Join
数据库中的表可以通过键将彼此联系起来,主键是一个列,在这个列中的每一行的值都是唯一的,在表中,每个主键的值都是唯一的,这样就可以在不重复每个表中的所有数据的情况下,把表间的数据交叉捆绑在一起。
以下为表user和表Room的数据
data:image/s3,"s3://crabby-images/f74e6/f74e6ce86d7d8bb530b2dbd361f2f01e3bbab550" alt=""
1:引用两个表
找出在Room of boy相关联的用户信息
Select u.user_name,u.user_age,r.room_name from user as u,room as r
Where u.room_id = r.room_id and r.room_name='room of boy'
data:image/s3,"s3://crabby-images/5b931/5b931bd1edcffd9a67c38814f69f91f02bb3742c" alt=""
2:使用关键字join来连接两张表
Select u.user_name,u.user_age,r.room_name
from user as u
join room as r
on u.room_id = r.room_id and r.room_name='room of boy'
data:image/s3,"s3://crabby-images/78696/786966d1493023d981597c613eb09539fd6c1d85" alt=""
八、Inner join
Inner join 与 join 用法一致
Select u.user_name,u.user_age,r.room_name
from user as u
inner join room as r
on u.room_id = r.room_id and r.room_name='room of boy'
data:image/s3,"s3://crabby-images/7d10c/7d10c0c1a1ee75079f55978fd60e64eef18d7acd" alt=""
九、Left join
注意:左连接以左边的表为主体,也就是说会列出左边的表中的所有的数据,无论它是否满足条件。
1:user在左边
Select u.user_name,u.user_age,r.room_name
from user as u
Left join room as r
on u.room_id = r.room_id and r.room_name='room of boy'
data:image/s3,"s3://crabby-images/6e169/6e169c2496bcd8878e333eb4778d58c9a3f10bba" alt=""
2:Room在左边
Select u.user_name,u.user_age,r.room_name
From room as r
Left join user as u
on u.room_id = r.room_id and r.room_name='room of boy'
data:image/s3,"s3://crabby-images/42d87/42d8711c73e86c9fcd4cabdc3f9d45adccbf2e30" alt=""
十、Right join
注意:左连接以右边的表为主体,也就是说会列出左边的表中的所有的数据,无论它是否满足条件。
1:Room在右边
Select u.user_name,u.user_age,r.room_name
from user as u
Right join room as r
on u.room_id = r.room_id and r.room_name='room of boy'
data:image/s3,"s3://crabby-images/beee0/beee0a27a1bd389a15221eaaafe68a5ad0365a7c" alt=""
2:user在右边
Select u.user_name,u.user_age,r.room_name
from room as r
Right join user as u
on u.room_id = r.room_id and r.room_name='room of boy'
data:image/s3,"s3://crabby-images/ebcd3/ebcd3e4a6c8b62e0ffe20f590fdd3067e495bd02" alt=""
十一、Full join
1:user在左边
Select * from user Full join room
data:image/s3,"s3://crabby-images/88883/888837627527d505c6a6ad2bec4a1b54d911a701" alt=""
2:Room在左边
Select * From room full join user
data:image/s3,"s3://crabby-images/0e86c/0e86c28f57c09b994f1430246ddfab7bf34f6514" alt=""
注意:SQL错误码1054表示没有找到对应的字段名;错误码1064表示用户输入的SQL语句有语法错误
十二、Union
Union操作符用于合并两个或者多个SELECT语句的结果集
请注意,UNION内部的select语句必须拥有相同数量的列。列也必须拥有相同的数据类型。同时,每条select语句中的列的顺序必须相同。
下面是Room表和color表的数据
data:image/s3,"s3://crabby-images/1c479/1c47994b3acd63493db8d0b349c7b85a40229cd8" alt=""
Select room_name from room
Union
Select color_name from color
data:image/s3,"s3://crabby-images/69f23/69f23ff39db133498da1801544a05bef3aac9fa2" alt=""
默认的union选取不同的值,如果想要有相同的值出现就使用union all
Select room_name from room
Union all
Select color_name from color
data:image/s3,"s3://crabby-images/eceb2/eceb22a60e009bf8611b26a014c2b0a9960a306a" alt=""
十三、Create DB
创建数据库mysqltest
Create database mysqltest
data:image/s3,"s3://crabby-images/2d354/2d35477371de1f1b6539c9645162563bc097b399" alt=""
十四、Create table
Create table sqltest(
Id int,
Name varchar(45),
Age int,
Salary float,
Time Date,
)
data:image/s3,"s3://crabby-images/5dddc/5dddc89b3918b589dfee9384ac703e8c314e4441" alt=""
十五、Constraints
SQL约束,用于限制加入表的数据的类型
常见约束:not noll、unique、primary key、foreign key、check、default
十六、Not null
Not null 约束强制列不接受NULL值。Not null 约束强制字段始终包含值,这意味着,如果不向字段添加值,就无法插入新的字段或者更新记录
用法,在字段后面加上 not null
data:image/s3,"s3://crabby-images/9aab7/9aab74af3e1aa23d53abccf2ba31478ec0589088" alt=""
十七、Unique
Unique约束唯一标识数据库中的每一条记录。Primary key约束拥有自动的unique约束。需要注意的是,每个表里面可以拥有多个unique约束,但只能有一个primary key约束
1:MySQL用法,unique(字段名)
data:image/s3,"s3://crabby-images/9f0e3/9f0e3ca4b9bcc2e919fba88719d4f4d54abd67d7" alt=""
2:SQL Server 、 Oracle 、 MS Access在字段后面加
data:image/s3,"s3://crabby-images/3ab62/3ab6256d2d59ae07402ecb58613d9438405f993f" alt=""
3:命名约束使用constraint
data:image/s3,"s3://crabby-images/5e10c/5e10c0c2f095430f626f32160001b0bb5bd0c7f4" alt=""
4:已经创建了表之后需要添加约束
ALTER TABLE sqltest ADD UNIQUE(Age)
data:image/s3,"s3://crabby-images/9f372/9f37206af0521dfd8e48514e9c756171c8667d80" alt=""
5:给已经创建了的表添加约束并命名
ALTER TABLE sqltest ADD constraint unique_name UNIQUE(Age,salary)
data:image/s3,"s3://crabby-images/9a884/9a88402286afe756ff69ef1c35f99b87aef2d478" alt=""
6:撤销约束
MySQL
在没有给约束命名的情况下(上面的age约束)直接使用字段名就可以了
ALTER TABLE sqltest DROP INDEX age
删除后 data:image/s3,"s3://crabby-images/d7220/d722054637cc62523e28fd8947cc8e53185fd2fb" alt=""
在约束有名字的情况下,直接使用名字就可以了
ALTER table sqltest drop index unique_name
删除后 data:image/s3,"s3://crabby-images/e121e/e121e98138260d84588888ffc946786dbff47903" alt=""
SQL Server 、 Oracle 、 MS Access
ALTER table 表名 drop constraint 约束名
十八、Primary key
Primary key约束唯一标识数据库表中的每一条记录,组件必须包含唯一的值。组件列不能包含NULL值。每个表都应该有一个主键,并且每一个表都只能有一个主键
1:在MySQL中的用法
data:image/s3,"s3://crabby-images/d170f/d170f5db356632ee19ead50db517581996ff6547" alt=""
2:在SQL Server 、 Oracle 和MS Access中的用法
data:image/s3,"s3://crabby-images/47182/4718211dcfcea3d38019e2ddf1e50202530087bf" alt=""
3:为已经创建成功的表创建primary key约束
Alter table sqltest add primary key(id)
data:image/s3,"s3://crabby-images/676b4/676b46dd38388049fe0c2307c1cf73395f0daf5c" alt=""
4:为已经创建成功的表添加主键约束,以及为多个列定义主键约束
Alter table sqltest add constraint pk_name primary key (id,name)
data:image/s3,"s3://crabby-images/21e49/21e4917c89b7570abc5b94fe1243c97fcc53cdef" alt=""
5:在MySQL中撤销主键
ALTER TABLE sqltest DROP PRIMARY KEY
删除后 data:image/s3,"s3://crabby-images/75687/75687bedc1c43b82db4348f2aea645ea9f563c73" alt=""
6:在SQL Server、Oracle、MS Access中撤销主键
Alter table 表名 drop constraint 主键名
十九、Foreign key
所谓的外键,即一个表的外键指向另一个表的主键
User表data:image/s3,"s3://crabby-images/c26ce/c26ce0c30434222e1e923bbcb4d6d5264c401de0" alt=""
Room表data:image/s3,"s3://crabby-images/bdaef/bdaef9397f4b6f8ca9caf9ede1856a9522d0ac1f" alt=""
在user表里面room_id列指向Room表里面的id列。Room表里面的id列是主键,user表里面的room_id列是外键。外键约束用于预防破坏表之间的连接动作,外键约束也能防止非法数据插入外键列,因为他必须是他指向的那个表的值之一。
data:image/s3,"s3://crabby-images/cb528/cb528f2126f6b95ea37319cd57eaa9747ef51b86" alt=""
二十、Check
Check约束用于限制列中的值的范围。如果对单一的列定义check约束,那么改了只允许特定的值。如果对一个表定义check约束,那么此约束会在特定的列中对值进行限制。
data:image/s3,"s3://crabby-images/64914/649144096ec40bac4d7e6994d49d73d66699ece1" alt=""
为已经创建成功的表添加check约束
ALTER TABLE USER ADD CHECK (age>10)
二十一、Default
Default约束用于向列宗插入默认值。如果没有规定其他值,那么就会将默认值添加到所有的新纪录。
用法:
data:image/s3,"s3://crabby-images/85361/85361b2bcad82f2502e1c0104c92f221165d7c28" alt=""
当表已经存在的时候,添加默认值
ALTER TABLE sqltest ALTER NAME SET DEFAULT 'tom'
data:image/s3,"s3://crabby-images/a0b51/a0b51cad4ad46482a31676b3d236bda896b1325d" alt=""
data:image/s3,"s3://crabby-images/17ca1/17ca181e8ac14eecabca09bdda77817e93120a2f" alt=""
撤销默认值
data:image/s3,"s3://crabby-images/24faa/24faa71fdfe6c224715aea9ff9b0d27b370a648a" alt=""
data:image/s3,"s3://crabby-images/8d411/8d411dd41dc9df9d7b4c49a6b6231228e062c392" alt=""
二十二、Create index
索引,你可以在表里面创建索引,一边更加快速高效地查询数据。用户无法看见索引,他们只能被用来加速搜索、查询。
注意:更新一个包含索引的表需要比更新一个没有索引的表更多的时间,这是索引本身也需要更新,因此,理想的做法是仅仅在常常被搜索的列上面创建索引。
1:创建一个索引
CREATE INDEX index_name ON color (color_id )
data:image/s3,"s3://crabby-images/4c0bb/4c0bb551ae9cb8cccee187d3c8a74000ef052090" alt=""
2:创建一个独一无二的索引,即两行不能拥有相同的索引值。
CREATE UNIQUE INDEX book_index ON book (book_id)
data:image/s3,"s3://crabby-images/be6ea/be6ea69923bda3f67445bc07b5202a37fc23f9dd" alt=""
3:如果索引不止一个列,你可以在括号中列出这些列的名称,用逗号隔开
CREATE INDEX index_bank ON bank (bank_id,bank_name)
data:image/s3,"s3://crabby-images/3b127/3b127a82df02eabb878341ba3e75bab93a9038cf" alt=""
二十三、Drop
通过使用DROP语句,可以删掉索引、表和数据库
1:删除索引
Drop index index_name on color
data:image/s3,"s3://crabby-images/58748/58748e6a30bdc925b25d1bed5a2e82508d2aeb8e" alt=""
删除之后
data:image/s3,"s3://crabby-images/4db53/4db53176be3165baa78a31418904ad70ffba9203" alt=""
data:image/s3,"s3://crabby-images/0a993/0a993225bb2d6d9e54693cd71259f45365bcaacf" alt=""
data:image/s3,"s3://crabby-images/63810/63810250f4d32f8e649cdbd46a3b260e4c7521b2" alt=""
2:删除表
DROP TABLE colorcopy
删除之后 data:image/s3,"s3://crabby-images/47d80/47d802026285d2bfab413d3ec9540669897c1b23" alt=""
3:清空表
TRUNCATE TABLE color
删除之后 data:image/s3,"s3://crabby-images/1e8db/1e8dbcecf5f3b1ed1d7ae2d99dba6cbe3deea44f" alt=""
4:删除数据库
DROP DATABASE mysqltest
删除之后 data:image/s3,"s3://crabby-images/3bd55/3bd5525e5922c216ed0e348d2cc345c62f8f4291" alt=""
二十四、Alert
data:image/s3,"s3://crabby-images/5525d/5525d98af29145d86fab3df74ba0d2413370f662" alt=""
1:添加列
Alter table user add salary float
data:image/s3,"s3://crabby-images/acc31/acc31b4f3c092bbfc8acdad4197ae038e7b9ff12" alt=""
2:删除列
Alter table user drop column room_id
data:image/s3,"s3://crabby-images/49aa2/49aa2f7add555e393126dcbfde362079ae88e22e" alt=""
二十五、Increment
定义主键自增
data:image/s3,"s3://crabby-images/b487b/b487bc005dd8b93ad20ed42c53d7484e3d6df826" alt=""
二十六、View
视图,一种基于SQL语句的结果集可视化表。视图包含行和列,就像一个真实的表。视图中的字段来自一个或多个数据库中的真实的表中的字段,我们可以向视图添加SQL函数、where以及join语句,我们提交数据,然后这些来自某个单一的表。需要注意的是,数据库中的结构和设计不会受到视图的函数、where或join语句的影响
1:创建一个视图,字段来自user表和Room表
CREATE VIEW view_test AS
SELECT user.user_name,user.user_age,room.room_name
FROM USER,room
WHERE user.user_age>10
2:查询视图
Select * from view_test
data:image/s3,"s3://crabby-images/24ff7/24ff75e599fdcdf03a06dd13fd91eb750eceb3a6" alt=""
3:撤销视图
DROP VIEW view_test
二十七、Date
data:image/s3,"s3://crabby-images/3c516/3c516d293afa95c96463ea5f81d4d48dce5d90ed" alt=""
二十八、Nulls
默认的,表的列可以存放NULL值。如果表里面的某个列是可选的,那么我们可以在不想改列添加值的情况下插入记录或者更新记录,这意味着该字段以NULL值保存。注意,NULL和0是不等价的,不能进行比较。
data:image/s3,"s3://crabby-images/7f4d0/7f4d03041c33696f61745b131c12e0d79a31518a" alt=""
1:查询NULL值
select * from user where salary is null
data:image/s3,"s3://crabby-images/4a63e/4a63e3ef1b0f1eaaa21804314d588ecea41149c7" alt=""
2:查询非NULL值
select * from user where salary is not null
data:image/s3,"s3://crabby-images/c2ac2/c2ac20370da5ce70709c69bc22a65f74cee32c5e" alt=""
二十九、数据类型
MySQL主要有三种类型:文本、数字、日期
data:image/s3,"s3://crabby-images/75ecc/75ecce822ad1fc8f129faabb44973dd7163d448d" alt=""
data:image/s3,"s3://crabby-images/c9759/c9759bdf5de8db9701d5d3ed7ba0a9f94f302100" alt=""
data:image/s3,"s3://crabby-images/15075/15075d492294db8f34ba371a8a370f88f9e33649" alt=""
data:image/s3,"s3://crabby-images/b34c1/b34c10613df7aa8e1bfa329117bc947887a25739" alt=""
data:image/s3,"s3://crabby-images/0f28d/0f28d1cce100c2db403bba2e518f65ae30d86686" alt=""
data:image/s3,"s3://crabby-images/d5d81/d5d819e06ddc03e2d193d4d601189479d29d32f8" alt=""
data:image/s3,"s3://crabby-images/21325/21325c8ad7a1de9cde39ec09b9bc6467cb17d7d9" alt=""
data:image/s3,"s3://crabby-images/27c2c/27c2c840ba05cf6d2cf261915505b34051610296" alt=""
三十、服务器
data:image/s3,"s3://crabby-images/fa201/fa201aebf02ff38d38bc05ce4e34443c6fa5f251" alt=""
第三章 SQL函数
一、SQL functions
在SQL当中,基本的函数类型和种类有若干种,函数的基本类型是:
合计函数(Aggregate function)和 Scalar函数
Aggregate 函数,函数操作面向一系列的值,并返回一个单一的值。
Scalar 函数,操作面向某个单一的值,并返回基于输入值的一个单一的值。
二、Avg()
求平均年龄
Select avg(user_age) from user
data:image/s3,"s3://crabby-images/1298c/1298c42b178d74e7b9d635336c5725b1e937b9e8" alt=""
求大于平均年龄的用户
Select * from user where user_age>(Select avg(user_age) from user)
data:image/s3,"s3://crabby-images/38875/3887571e3f3367f582ce088d42a0790a10915dd3" alt=""
三、Count()
返回列的值的数目(不包含NULL)
注意,可以使用as来给count()取一个别名
data:image/s3,"s3://crabby-images/1c9b9/1c9b96c04d885d2687a2332c3cf0e96674e20c8b" alt=""
Select count(user_id) from user
data:image/s3,"s3://crabby-images/3ccc5/3ccc550c1366ce41ab24ee56c8ae3c14da7328e9" alt=""
Select count(salary) from user
data:image/s3,"s3://crabby-images/6577b/6577b093df7375ab3a7f9e8e156e5add828b439c" alt=""
返回值不同的有多少
Select count(distinct user_name) from user
data:image/s3,"s3://crabby-images/424f2/424f2dbceb0032cc00b12682f024271017e45ffc" alt=""
查询所有列
Select count(*) from user
data:image/s3,"s3://crabby-images/25782/25782caa0a6b3e7521c873225d9705307a288e96" alt=""
四、Max()
返回最大值,NULL不包括在计算中
data:image/s3,"s3://crabby-images/8d16a/8d16a97d79e3d9c2713f7e6e8ff72df23c852579" alt=""
Select max(price) as max_price from commodity
data:image/s3,"s3://crabby-images/b0472/b0472d7a2bbf9a212123b15f70d556a132e1aa45" alt=""
五、Min()
返回最小值,NULL不包括在计算中
data:image/s3,"s3://crabby-images/0ea18/0ea183c367e70c25804e1072dec674bdaa411eb3" alt=""
Select min(salary) poor_man from user
data:image/s3,"s3://crabby-images/e45f0/e45f0e7a5cdf2d81d1e9aa4d29860097e0bdef80" alt=""
六、Sum()
返回该列值的总额
data:image/s3,"s3://crabby-images/f0bad/f0badafe27bdb1e81f7fd68ac71d3c7c346f992a" alt=""
Select sum(salary) from user
data:image/s3,"s3://crabby-images/0fbf1/0fbf15a554e21b018b20d5a38876a64d23429084" alt=""
七、Group By
用于结合合计函数,根据一个或多个列对结果集进行分组
data:image/s3,"s3://crabby-images/cf209/cf20950b55a70ead3db2f0f01be1461a806ed304" alt=""
SELECT cname,SUM(price) FROM commodity GROUP BY cname
data:image/s3,"s3://crabby-images/c6755/c675535ca67e264f6869f7ab3851fc474d97251c" alt=""
八、Having
在SQL中增加having子句的原因是where不能与合计函数一起使用。用法和where 一样
SELECT cname,SUM(price) FROM commodity
GROUP BY cname
HAVING SUM(price)>20
data:image/s3,"s3://crabby-images/3f507/3f5073c9ce2b128ec033f32047ec991f80927d9d" alt=""
九、Ucase()
把函数字段的值转化为大写
data:image/s3,"s3://crabby-images/f11b4/f11b42015aa855187fa0319fc955a761c7198451" alt=""
SELECT UCASE(user_name) FROM user
data:image/s3,"s3://crabby-images/2ce8b/2ce8bc557ab9e4e98709b2eb0abbd672030024db" alt=""
十、Lcase()
将函数字段转化为小写
data:image/s3,"s3://crabby-images/8423a/8423a59668960d9ae8f68fd57cf7fe9c61b55730" alt=""
Select lcase(user_name) from user
data:image/s3,"s3://crabby-images/27a91/27a91879537a7940312afc684f56b2f61b66ee6b" alt=""
十一、Mid()
从文本字段中提取字符
data:image/s3,"s3://crabby-images/10705/107054fbf0c53d3094012ab8eb5ebe92358af35f" alt=""
Select mid(user_name,2,2) from user
data:image/s3,"s3://crabby-images/5ff03/5ff03c1a317c3ca03d53b4d2321ca99f260bff62" alt=""
十二、Round()
Round函数把数值字段舍入为指定的小数位数
data:image/s3,"s3://crabby-images/832a0/832a0a6d31496e64acafd0e5cbf1baa622141eb0" alt=""
Select round(salary,2) from user
data:image/s3,"s3://crabby-images/1cdbf/1cdbfd5711cf032548ff79887995aca5c6fdda50" alt=""
十三、Now()
返回当前时间
SELECT NOW() FROM user
data:image/s3,"s3://crabby-images/6772c/6772cb0562a7f981d1c0ff8bd73d47d9a11ae8eb" alt=""
示例:
--查找emp表
select * from emp;
--查找emp表的sal
select a.SAL from emp a;
--查找emp表的ename
select a.ename from emp a;
--emp表的sal*10
select a.SAL*10 from emp a;
--emp表的sal的平均值
select avg(a.sal) from emp a;
--emp表的sal的总和
select sum(a.sal) from emp a;
--emp表的sal的max
select max(a.sal) from emp a;
--emp表的sal的min
select min(a.sal) from emp a;
--emp表中sal<1000的信息
select * from emp where sal<1000;
--ename中含有A的信息
select ename from emp where ename like'%A%';
--emp中ename不含有A的信息
select * from emp where ename not like'%A%';
--查询系统时间
select sysdate from dual;
--计算薪资小于5000的员工的工资总和
select sum(sal) from emp where sal<5000 ;
--计算工资不高于平均工资的工资总和
select sum(sal) from emp where sal<(select avg(sal) from emp);
--计算工资小于4000的员工的平均工资
select avg((select sum(sal) from emp where sal<4000)) from emp;
--查询薪水低于100000的员工姓名和sal
select ename,sal from emp where sal<100000;
--计算20号部门的员工的最高工资和最低工资
select max(sal),min(sal) from emp where deptno=20;
--查询工资大于1000,并且是20号部门的员工的全部信息
select * from emp where sal>1000 and deptno=20;
--求最高工资的员工的员工姓名和部门名称
select ename,deptno,sal from emp where sal=(select max(sal) from emp);
--将员工薪水小于5000且部门平均薪水大于1000的部门标号列出,按部门平均薪水降序排序
select deptno from emp where sal<5000 group by deptno having avg(sal) >1000;
select sal from emp order by sal desc;
Order by *** desc
--查找表emp
select * from emp ;
--根据用户名“Smiths”查找他所在的部门
select deptno from emp where ename='SMITH';
--查询每个部门的最高工资的人员名称
select e.ename,e.deptno,e.sal from (select deptno as did ,max(sal) as m from emp group by deptno ) s,emp e,dept d where e.sal=s.m and s.did=e.deptno and d.deptno=e.deptno;
--查询“Jones”之后第一个进入公司的人
select * from emp where hiredate=(select min(hiredate) from emp where hiredate>(select hiredate from emp where ename='JONES')) ;
--5.查找工资最高的部门名称和工资最低的部门名称及工资
select d.dname,e.sal from emp e,dept d where e.deptno=d.deptno and sal=(select max(m) from (select deptno,max(sal) as m from emp e group by deptno) s)
union
select d.dname,e.sal from emp e,dept d where e.deptno=d.deptno and sal=(select min(m) from (select deptno,min(sal) as m from emp e group by deptno) s)
--创建表
create table student(
StudentId number (6),--学号
LoginPwd varchar(20),--密码
StudentName varchar(50),--姓名
Sex char(2),--性别
Gradeld Number(6),--所在年级
Phone number(15),--联系电话
Address varchar2(255),--现住址
BornDate Date,--出生日期
Emile varchar2(50)--电子邮件
);
--添加数据
insert into student values(1001,'123456','赵六','男',1507,120,'北京','23-5月-1995','@10422');
insert into student values(1002,'123456','王五','女',1507,110,'北京','23-5月-1995','@10422');
insert into student values(1003,'123456','张三','男',1507,120,'北京','23-5月-1995','@10422');
insert into student values(1004,'123456','李四','女',1507,110,'北京','23-5月-1995','@10422');
--提交
commit;
--查询此表
select * from student;
--根据条件修改
update student set studentname='孙七',loginpwd='666666' where studentid=1001;
select * from student;
--根据条件删除
delete from student where studentid=1002;
select * from student;
--增加字段
ALTER TABLE 表名称 ADD(列名称 数据类型 [DEFAULT 默认值],列名称 数据类型 [DEFAULT 默认值],…)
--删除此表
drop table student;
--B卷 创建表空间
create tablespace mytestspace datafile 'e:week3.dbf' size 2M;
--创建用户
create user zhangsan identified by zhangsan default tablespace mytestspace
temporary tablespace temp;
--创建角色并授权
create role fang;
grant create table to fang;
grant fang to zhangsan;
grant dba to zhangsan;
--创建表
create table teacher (
tid number primary key,
tname varchar2(50),
tdate date,
address varchar2(100)
);
select * from teacher;
--创建序列
create sequence teachers_sequence minvalue 1 maxvalue 100 (最小值,最大值)cycle (循环)increment by 1(步长值) start with 1(从1开始);
insert into teacher values(teachers_sequence.nextval,'小李','01-1月-1999','北京');
insert into teacher values(teachers_sequence.nextval,'小张',to_date('1982-1-1','yyyy-mm-dd'),'北京');