当前位置: 首页 > 编程日记 > 正文

Mysql—(1)—

sql语句

sql是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。

在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库操作的基础,并且现在几乎所有的数据库均支持sql。

sql规范

/*
<1> 在数据库系统中,SQL语句不区分大小写(建议用大写) 。但字符串常量区分大小写。建议命令大写,表名库名小写;<2> SQL语句可单行或多行书写,以“;”结尾。关键词不能跨多行或简写。<3> 用空格和缩进来提高语句的可读性。子句通常位于独立行,便于编辑,提高可读性。
*/SELECT * FROM tb_tableWHERE NAME="YUAN";/*
<4> 注释:单行注释:--多行注释:/*......*/
/*
<5>sql语句可以折行操作<6> DDL,DML和DCL
*/
View Code

关于数据库操作的sql语句

-- 1.创建数据库(在磁盘上创建一个对应的文件夹)create database [if not exists] db_name [character set xxx] -- 2.查看数据库
    show databases;查看所有数据库show create database db_name; 查看数据库的创建方式-- 3.修改数据库alter database db_name [character set xxx] -- 4.删除数据库drop database [if exists] db_name;-- 5.使用数据库切换数据库 use db_name; -- 注意:进入到某个数据库后没办法再退回之前状态,但可以通过use进行切换查看当前使用的数据库 select database();
View Code

表字段的增删改查

创建一张表

-- 语法
create table tab_name(field1 type[完整性约束条件],field2 type,...fieldn type)[character set xxx];
-- 创建一个员工表employeecreate table employee(id int primary key auto_increment ,name varchar(20),gender bit default 1,   -- gender char(1)  default 1   -----    或者 TINYINT(1) 
            birthday date,       job varchar(20),salary double(4,2) unsigned,resume text    -- 注意,这里作为最后一个字段不加逗号
          );/* 约束:primary key (非空且唯一)  :能够唯一区分出当前记录的字段称为主键!unique         not nullauto_increment :用于主键字段,主键字段必须是数字类型*/
实例

查看表信息

    desc tab_name 查看表结构show columns from tab_name  查看表结构show tables 查看当前数据库中的所有的表show create table tab_name    查看当前数据库表建表语句 

修改表结构(修改已有的字段,相当于重写一个,需要写全各个元素)

-- (1)增加列(字段):  
alter table tab_name add [column] 列名 类型[完整性约束条件][first|after 字段名];
-- (2)修改一列类型:  
alter table tab_name modify 列名 类型 [完整性约束条件][first|after 字段名];
-- (3)修改列名:  
alter table tab_name change [column] 列名 新列名 类型 [完整性约束条件][first|after 字段名];
-- (4)删除一列:  
alter table tab_name drop [column] 列名;
-- (5)修改表名:  
rename table 表名 to 新表名;
-- (6)修该表所用的字符集: 
alter table student character set utf8;
-- (1)增加列(字段)alter table tab_name add [column] 列名 类型[完整性约束条件][first|after 字段名];alter table user add addr varchar(20) not null unique first/after username;#添加多个字段alter table users2 add addr varchar(20),add age  int first,add birth varchar(20) after name;-- (2)修改一列类型alter table tab_name modify 列名 类型 [完整性约束条件][first|after 字段名];alter table users2 modify age tinyint default 20;alter table users2 modify age int  after id;-- (3)修改列名alter table tab_name change [column] 列名 新列名 类型 [完整性约束条件][first|after 字段名];alter table users2 change age Age int default 28 first;-- (4)删除一列alter table tab_name drop [column] 列名;-- 思考:删除多列呢?删一个填一个呢?alter table users2 add salary float(6,2) unsigned not null after name,drop addr;    -- (5)修改表名rename table 表名 to 新表名;-- (6)修该表所用的字符集    alter table student character set utf8;
实例

删除表

drop table tab_name;

表记录的增删改查

--增加表记录--  <1>插入一条记录:insertinto] tab_name (field1,filed2,.......) values (value1,value2,.......);
--  <2>插入多条记录:insertinto] tab_name (field1,filed2,.......) values (value1,value2,.......), (value1,value2,.......) ...                           ;
--  <3>set插入:insertinto] tab_name set 字段名=--修改表记录update tab_name set field1=value1,field2=value2,......[where 语句]--删除表记录delete from tab_name [where ....]
增加表记录/* 
<1>插入一条记录:insert [into] tab_name (field1,filed2,.......) values (value1,value2,.......);示例:insert into employee_new (id,name,birthday,salary) values(1,'yuan','1990-09-09',9000);insert into employee_new values(2,'alex','1989-08-08',3000);insert into employee_new (name,salary) values('xialv',1000);<2>插入多条记录:insert [into] tab_name (field1,filed2,.......) values (value1,value2,.......),values (value1,value2,.......) ...                           ;示例:insert into employee_new values(4,'alvin1','1993-04-20',3000),(5,'alvin2','1995-05-12',5000);<3>set插入:insert [into] tab_name set 字段名=值 示例:insert into employee_new set id=12,name="alvin3";*/修改表记录update tab_name set field1=value1,field2=value2,......[where 语句]/*      UPDATE语法可以用新值更新原有表行中的各列。SET子句指示要修改哪些列和要给予哪些值。WHERE子句指定应更新哪些行。如没有WHERE子句,则更新所有的行。*/update employee_new set birthday="1989-10-24" WHERE id=1;--- 将yuan的薪水在原有基础上增加1000元。update employee_new set salary=salary+4000 where name='yuan';删除表记录delete from tab_name [where ....]/*    如果不跟where语句则删除整张表中的数据delete只能用来删除一行记录delete语句只能删除表中的内容,不能删除表本身,想要删除表,用dropTRUNCATE TABLE也可以删除表中的所有数据,词语句首先摧毁表,再新建表。此种方式删除的数据不能在事务中恢复。*/-- 删除表中名称为’alex’的记录。delete from employee_new where name='alex';-- 删除表中所有记录。delete from employee_new;-- 注意auto_increment没有被重置:alter table employee auto_increment=1;-- 使用truncate删除表中记录。truncate table emp_new;
实例技巧

思考: 表中数据三条,id分别为1,2,3,突然插入一个id=7,那么下次作为主键的字增长的id会从几开始增长呢?(从7开始)

查询表记录(重点)

-- 查询语法:SELECT *|field1,filed2 ...   FROM tab_nameWHERE 条件GROUP BY fieldHAVING 筛选ORDER BY fieldLIMIT 限制条数

简单查询

---准备表CREATE TABLE ExamResult(id INT PRIMARY KEY  auto_increment,name VARCHAR (20),JS DOUBLE ,Django DOUBLE ,OpenStack DOUBLE
);---插入数据
INSERT INTO ExamResult VALUES  (1,"yuan",98,98,98),(2,"xialv",35,98,67),(3,"alex",59,59,62),(4,"wusir",88,89,82),(5,"alvin",88,98,67),(6,"yuan",86,100,55);
ExamResult表
-- (1)select [distinct] *|field1,field2,......   from tab_name-- 其中from指定从哪张表筛选,*表示查找所有列,也可以指定一个列-- 表明确指定要查找的列,distinct用来剔除重复行。select * from ExamResult;                      -- 查询表中所有学生的信息。(* 在数据量大的时候会很慢,所以查找所有信息,最好是写完整所有字段,这样更快。)
select name,JS from ExamResult;                -- 查询表中所有学生的姓名和对应的js成绩。
select distinct JS ,name from ExamResult;      -- 过滤表中重复数据。-- (2)select 也可以使用表达式,并且可以使用: 字段 as 别名或者:字段 别名select name,JS+10,Django+10,OpenStack+10 from ExamResult;       -- 在所有学生分数上加10分特长分显示。select name,JS+Django+OpenStack from ExamResult;                -- 统计每个学生的总分。select name as 姓名,JS+Django+OpenStack as 总成绩 from ExamResult;   -- 使用别名表示学生总分。
select name,JS+Django+OpenStack 总成绩 from ExamResult;       
    --as 是可以省略的,所以在选择要显示的列的时候必须用逗号隔开,不然会认为后一列的名字是前一列的别名,结果只显示一列。

使用where子句,进行过滤查询

-- where字句中可以使用:-- 比较运算符:> < >= <= <> !=between 80 and 100 值在10到20之间in(80,90,100) 值是10或20或30like 'yuan%'/*pattern可以是%或者_,如果是%则表示任意多字符,此例如唐僧,唐国强如果是_则表示一个字符唐_,只有唐僧符合。两个_则表示两个字符:__*/-- 逻辑运算符在多个条件直接可以使用逻辑运算符 and or not
 -- 查询姓名为XXX的学生成绩select * from ExamResult where name='yuan';-- 查询英语成绩大于90分的同学select id,name,JS from ExamResult where JS>90;-- 查询总分大于200分的所有同学select name,JS+Django+OpenStack as 总成绩 fromExamResult where JS+Django+OpenStack>200 ;
View Code

order by排序

指定排序的列,排序的列即可是表中的列名,也可以是select 语句后指定的别名。-- select *|field1,field2... from tab_name order by field [Asc|Desc]-- Asc 升序、Desc 降序,其中asc为默认值 ORDER BY 子句应位于SELECT语句的结尾。
-- 练习:-- 对JS成绩排序后输出。select * from ExamResult order by JS;-- 对总分排序按从高到低的顺序输出select name ,(ifnull(JS,0)+ifnull(Django,0)+ifnull(OpenStack,0)) 总成绩 from ExamResult order by 总成绩 desc;-- 对姓李的学生成绩排序输出select name ,(ifnull(JS,0)+ifnull(Django,0)+ifnull(OpenStack,0))总成绩 from ExamResult where name like 'a%'order by 总成绩 desc;    --可以写成多行
练习

group by分组查询

CREATE TABLE order_menu(id INT PRIMARY KEY auto_increment,product_name VARCHAR (20),price FLOAT(6,2),born_date DATE,class VARCHAR (20));INSERT INTO order_menu (product_name,price,born_date,class) VALUES("苹果",20,20170612,"水果"),("香蕉",80,20170602,"水果"),("水壶",120,20170612,"电器"),("被罩",70,20170612,"床上用品"),("音响",420,20170612,"电器"),("床单",55,20170612,"床上用品"),("草莓",34,20170612,"水果");
View Code
-- 注意,按分组条件分组后每一组只会显示第一条记录-- group by字句,其后可以接多个列名,也可以跟having子句,对group by 的结果进行筛选。也只能用having,不能用where--聚合函数就是针对分组之后的操作,聚合函数、分组、having 一起使用。-- 按位置字段筛选select * from order_menu group by 5;-- 练习:对购物表按类名分组后显示每一组商品的价格总和select class,SUM(price)from order_menu group by class;-- 练习:对购物表按类名分组后显示每一组商品价格总和超过150的商品select class,SUM(price)from order_menu group by classHAVING SUM(price)>150;/*having 和 where两者都可以对查询结果进行进一步的过滤,差别有:<1>where语句只能用在分组之前的筛选,having可以用在分组之后的筛选;<2>使用where语句的地方都可以用having进行替换<3>having中可以用聚合函数,where中就不行。*/-- GROUP_CONCAT() 函数SELECT id,GROUP_CONCAT(name),GROUP_CONCAT(JS) from ExamResult GROUP BY id;    

聚合函数

--<1> 统计表中所有记录-- COUNT(列名):统计行的个数
-- 统计一个班级共有多少学生?先查出所有的学生,再用count包上
select count(*) from ExamResult;
-- 统计JS成绩大于70的学生有多少个?
select count(JS) from ExamResult where JS>70;
-- 统计总分大于280的人数有多少?
select count(name) from ExamResultwhere (ifnull(JS,0)+ifnull(Django,0)+ifnull(OpenStack,0))>280;
-- 注意:count(*)统计所有行;     count(字段)不统计null值.
View Code
     -- SUM(列名):统计满足条件的行的内容和
-- 统计一个班级JS总成绩?先查出所有的JS成绩,再用sum包上
select JS as JS总成绩 from ExamResult;
select sum(JS) as JS总成绩 from ExamResult;
-- 统计一个班级各科分别的总成绩
select sum(JS) as JS总成绩,
sum(Django) as Django总成绩,
sum(OpenStack) as OpenStack from ExamResult;-- 统计一个班级各科的成绩总和
select sum(ifnull(JS,0)+ifnull(Django,0)+ifnull(Database,0))as 总成绩 from ExamResult;
-- 统计一个班级JS成绩平均分
select sum(JS)/count(*) from ExamResult ;
-- 注意:sum仅对数值起作用,否则会报错。
View Code
     -- AVG(列名):
-- 求一个班级JS平均分?先查出所有的JS分,然后用avg包上。
select avg(ifnull(JS,0)) from ExamResult;
-- 求一个班级总分平均分
select avg((ifnull(JS,0)+ifnull(Django,0)+ifnull(Database,0)))from ExamResult ;
View Code
     -- Max、Min
-- 求班级最高分和最低分(数值范围在统计中特别有用)
select Max((ifnull(JS,0)+ifnull(Django,0)+ifnull(OpenStack,0)))
最高分 from ExamResult;
select Min((ifnull(JS,0)+ifnull(Django,0)+ifnull(OpenStack,0)))
最低分 from ExamResult;
-- 求购物表中单价最高的商品名称及价格
---SELECT id, MAX(price) FROM order_menu;--id和最高价商品是一个商品吗?SELECT MAX(price) FROM order_menu; 
-- 注意:null 和所有的数计算都是null,所以需要用ifnull将null转换为0!
--      -----ifnull(JS,0)
View Code

limit记录条数限制

 SELECT * from ExamResult limit 1;SELECT * from ExamResult limit 2,5;        --  跳过前两条显示接下来的五条纪录SELECT * from ExamResult limit 2,2;

正则表达式

SELECT * FROM employee WHERE emp_name REGEXP '^yu';
SELECT * FROM employee WHERE emp_name REGEXP 'yun$';
SELECT * FROM employee WHERE emp_name REGEXP 'm{2}';

外键约束

创建外键

--切记:作为外键一定要和关联主键的数据类型保持一致[ADD CONSTRAINT charger_fk_stu]FOREIGN KEY (charger_id) REFERENCES ClassCharger(id)
---  每一个班主任会对应多个学生 , 而每个学生只能对应一个班主任----主表CREATE TABLE ClassCharger(id TINYINT PRIMARY KEY auto_increment,name VARCHAR (20),age INT ,is_marriged boolean  -- show create table ClassCharger: tinyint(1)

);INSERT INTO ClassCharger (name,age,is_marriged) VALUES ("冰冰",12,0),("丹丹",14,0),("歪歪",22,0),("姗姗",20,0),("小雨",21,0);----子表CREATE TABLE Student(id INT PRIMARY KEY auto_increment,name VARCHAR (20),charger_id TINYINT,     --切记:作为外键一定要和关联主键的数据类型保持一致-- [ADD CONSTRAINT charger_fk_stu]FOREIGN KEY (charger_id) REFERENCES ClassCharger(id)

) ENGINE=INNODB;INSERT INTO Student(name,charger_id) VALUES ("alvin1",2),("alvin2",4),("alvin3",1),("alvin4",3),("alvin5",1),("alvin6",3),("alvin7",2);DELETE FROM ClassCharger WHERE name="冰冰";
INSERT student (name,charger_id) VALUES ("yuan",1);
-- 删除居然成功,可是 alvin3显示还是有班主任id=1的冰冰的;-----------增加外键和删除外键---------ALTER TABLE student  ADD CONSTRAINT abcFOREIGN KEY(charger_id)REFERENCES  classcharger(id);ALTER TABLE student DROP FOREIGN KEY abc;
示例

INNODB支持的ON语句

--外键约束对子表的含义:   如果在父表中找不到候选键,则不允许在子表上进行insert/update--外键约束对父表的含义:    在父表上进行update/delete以更新或删除在子表中有一条或多条对
-- 应匹配行的候选键时,父表的行为取决于:在定义子表的外键时指定的
-- on update/on delete子句-----------------innodb支持的四种方式--------------------------------------------cascade方式 在父表上update/delete记录时,同步update/delete掉子表的匹配记录
-----外键的级联删除:如果父表中的记录被删除,则子表中对应的记录自动被删除--------FOREIGN KEY (charger_id) REFERENCES ClassCharger(id)ON DELETE CASCADE------set null方式 在父表上update/delete记录时,将子表上匹配记录的列设为null-- 要注意子表的外键列不能为not nullFOREIGN KEY (charger_id) REFERENCES ClassCharger(id)ON DELETE SET NULL------Restrict方式 :拒绝对父表进行删除更新操作(了解)------No action方式 在mysql中同Restrict,如果子表中有匹配的记录,则不允许对父表对应候选键-- 进行update/delete操作(了解)
View Code

多表查询(*****)

-- 准备两张表
-- company.employee
-- company.departmentcreate table employee(emp_id int auto_increment primary key not null,emp_name varchar(50),age int,dept_id int);insert into employee(emp_name,age,dept_id) values('A',19,200),('B',26,201),('C',30,201),('D',24,202),('E',20,200),('F',38,204);create table department(dept_id int,dept_name varchar(100));insert into department values(200,'人事部'),(201,'技术部'),(202,'销售部'),(203,'财政部');mysql> select * from employee;
+--------+----------+------+---------+
| emp_id | emp_name | age  | dept_id |
+--------+----------+------+---------+
|      1 | A        |   19 |     200 |
|      2 | B        |   26 |     201 |
|      3 | C        |   30 |     201 |
|      4 | D        |   24 |     202 |
|      5 | E        |   20 |     200 |
|      6 | F        |   38 |     204 |
+--------+----------+------+---------+
6 rows in set (0.00 sec)mysql> select * from department;
+---------+-----------+
| dept_id | dept_name |
+---------+-----------+
|     200 | 人事部    |
|     201 | 技术部    |
|     202 | 销售部    |
|     203 | 财政部    |
+---------+-----------+
4 rows in set (0.01 sec)
employee,department 表

多表查询之连接查询

1.笛卡尔积查询

SELECT * FROM employee,department;
mysql> SELECT * FROM employee,department;--        select employee.emp_id,employee.emp_name,employee.age,
--        department.dept_name from employee,department;+--------+----------+------+---------+---------+-----------+
| emp_id | emp_name | age  | dept_id | dept_id | dept_name |
+--------+----------+------+---------+---------+-----------+
|      1 | A        |   19 |     200 |     200 | 人事部    |
|      1 | A        |   19 |     200 |     201 | 技术部    |
|      1 | A        |   19 |     200 |     202 | 销售部    |
|      1 | A        |   19 |     200 |     203 | 财政部    |
|      2 | B        |   26 |     201 |     200 | 人事部    |
|      2 | B        |   26 |     201 |     201 | 技术部    |
|      2 | B        |   26 |     201 |     202 | 销售部    |
|      2 | B        |   26 |     201 |     203 | 财政部    |
|      3 | C        |   30 |     201 |     200 | 人事部    |
|      3 | C        |   30 |     201 |     201 | 技术部    |
|      3 | C        |   30 |     201 |     202 | 销售部    |
|      3 | C        |   30 |     201 |     203 | 财政部    |
|      4 | D        |   24 |     202 |     200 | 人事部    |
|      4 | D        |   24 |     202 |     201 | 技术部    |
|      4 | D        |   24 |     202 |     202 | 销售部    |
|      4 | D        |   24 |     202 |     203 | 财政部    |
|      5 | E        |   20 |     200 |     200 | 人事部    |
|      5 | E        |   20 |     200 |     201 | 技术部    |
|      5 | E        |   20 |     200 |     202 | 销售部    |
|      5 | E        |   20 |     200 |     203 | 财政部    |
|      6 | F        |   38 |     204 |     200 | 人事部    |
|      6 | F        |   38 |     204 |     201 | 技术部    |
|      6 | F        |   38 |     204 |     202 | 销售部    |
|      6 | F        |   38 |     204 |     203 | 财政部    |
+--------+----------+------+---------+---------+-----------+
View Code

2.内连接

select * from employee,department where employee.dept_id = department.dept_id;select * from employee inner join department on employee.dept_id = department.dept_id;
--如果department表中没有的编号,是不会出现在这个结果中的。
-- 查询两张表中都有的关联数据,相当于利用条件从笛卡尔积结果中筛选出了正确的结果。select * from employee,department where employee.dept_id = department.dept_id;
--select * from employee inner join department on employee.dept_id = department.dept_id;+--------+----------+------+---------+---------+-----------+| emp_id | emp_name | age  | dept_id | dept_id | dept_name |+--------+----------+------+---------+---------+-----------+|      1 | A        |   19 |     200 |     200 | 人事部    ||      2 | B        |   26 |     201 |     201 | 技术部    ||      3 | C        |   30 |     201 |     201 | 技术部    ||      4 | D        |   24 |     202 |     202 | 销售部    ||      5 | E        |   20 |     200 |     200 | 人事部    |+--------+----------+------+---------+---------+-----------+
结果如下:

3.外连接

--(1)左外连接:在内连接的基础上增加左边有右边没有的结果select * from employee left join department on employee.dept_id = department.dept_id;--(2)右外连接:在内连接的基础上增加右边有左边没有的结果select * from employee RIGHT JOIN department on employee.dept_id = department.dept_id;--(3)全外连接:在内连接的基础上增加左边有右边没有的和右边有左边没有的结果-- mysql不支持全外连接 full JOIN-- mysql可以使用此种方式间接实现全外连接select * from employee RIGHT JOIN department on employee.dept_id = department.dept_idUNIONselect * from employee LEFT JOIN department on employee.dept_id = department.dept_id;
--(1)左外连接:在内连接的基础上增加左边有右边没有的结果select * from employee left join department on employee.dept_id = department.dept_id;+--------+----------+------+---------+---------+-----------+| emp_id | emp_name | age  | dept_id | dept_id | dept_name |+--------+----------+------+---------+---------+-----------+|      1 | A        |   19 |     200 |     200 | 人事部    ||      5 | E        |   20 |     200 |     200 | 人事部    ||      2 | B        |   26 |     201 |     201 | 技术部    ||      3 | C        |   30 |     201 |     201 | 技术部    ||      4 | D        |   24 |     202 |     202 | 销售部    ||      6 | F        |   38 |     204 |    NULL | NULL      |+--------+----------+------+---------+---------+-----------+--(2)右外连接:在内连接的基础上增加右边有左边没有的结果select * from employee RIGHT JOIN department on employee.dept_id = department.dept_id;+--------+----------+------+---------+---------+-----------+| emp_id | emp_name | age  | dept_id | dept_id | dept_name |+--------+----------+------+---------+---------+-----------+|      1 | A        |   19 |     200 |     200 | 人事部    ||      2 | B        |   26 |     201 |     201 | 技术部    ||      3 | C        |   30 |     201 |     201 | 技术部    ||      4 | D        |   24 |     202 |     202 | 销售部    ||      5 | E        |   20 |     200 |     200 | 人事部    ||   NULL | NULL     | NULL |    NULL |     203 | 财政部    |+--------+----------+------+---------+---------+-----------+--(3)全外连接:在内连接的基础上增加左边有右边没有的和右边有左边没有的结果-- mysql不支持全外连接 full JOIN-- mysql可以使用此种方式间接实现全外连接select * from employee RIGHT JOIN department on employee.dept_id = department.dept_idUNIONselect * from employee LEFT JOIN department on employee.dept_id = department.dept_id;+--------+----------+------+---------+---------+-----------+| emp_id | emp_name | age  | dept_id | dept_id | dept_name |+--------+----------+------+---------+---------+-----------+|      1 | A        |   19 |     200 |     200 | 人事部    ||      2 | B        |   26 |     201 |     201 | 技术部    ||      3 | C        |   30 |     201 |     201 | 技术部    ||      4 | D        |   24 |     202 |     202 | 销售部    ||      5 | E        |   20 |     200 |     200 | 人事部    ||   NULL | NULL     | NULL |    NULL |     203 | 财政部    ||      6 | F        |   38 |     204 |    NULL | NULL      |+--------+----------+------+---------+---------+-----------+-- 注意 union与union all的区别:union会去掉相同的纪录
View Code

多表查询之复合条件连接查询

-- 查询员工年龄大于等于25岁的部门SELECT DISTINCT department.dept_nameFROM employee,departmentWHERE employee.dept_id = department.dept_idAND age>25;--以内连接的方式查询employee和department表,并且以age字段的升序方式显示select employee.emp_id,employee.emp_name,employee.age,department.dept_namefrom employee,departmentwhere employee.dept_id = department.dept_idorder by age asc;

多表查询之子查询

-- 子查询是将一个查询语句嵌套在另一个查询语句中。
-- 内层查询语句的查询结果,可以为外层查询语句提供查询条件。
-- 子查询中可以包含:IN、NOT IN、ANY、ALL、EXISTS 和 NOT EXISTS等关键字
-- 还可以包含比较运算符:= 、 !=、> 、<等
-- 子查询是将一个查询语句嵌套在另一个查询语句中。
-- 内层查询语句的查询结果,可以为外层查询语句提供查询条件。
-- 子查询中可以包含:IN、NOT IN、ANY、ALL、EXISTS 和 NOT EXISTS等关键字
-- 还可以包含比较运算符:= 、 !=、> 、<等-- 1. 带IN关键字的子查询---查询employee表,但dept_id必须在department表中出现过select * from employeewhere dept_id IN(select dept_id from department);+--------+----------+------+---------+
| emp_id | emp_name | age  | dept_id |
+--------+----------+------+---------+
|      1 | A        |   19 |     200 |
|      2 | B        |   26 |     201 |
|      3 | C        |   30 |     201 |
|      4 | D        |   24 |     202 |
|      5 | E        |   20 |     200 |
+--------+----------+------+---------+
5 rows in set (0.01 sec)-- 2. 带比较运算符的子查询--      =、!=、>、>=、<、<=、<>-- 查询员工年龄大于等于25岁的部门select dept_id,dept_name from departmentwhere dept_id IN(select DISTINCT dept_id from employee where age>=25);-- 3. 带EXISTS关键字的子查询-- EXISTS关字键字表示存在。在使用EXISTS关键字时,内层查询语句不返回查询的记录。
-- 而是返回一个真假值。Ture或False
-- 当返回Ture时,外层查询语句将进行查询;当返回值为False时,外层查询语句不进行查询select * from employeeWHERE EXISTS(SELECT dept_name from department where dept_id=203);--department表中存在dept_id=203,Tureselect * from employeeWHERE EXISTS(SELECT dept_name from department where dept_id=205);-- Empty set (0.00 sec)
ps:  create table t1(select * from t2);
View Code

转载于:https://www.cnblogs.com/zihe/p/7229828.html

相关文章:

vs2005 打sp1补丁失败的解决办法

上次安装sp1补丁失败,由于没有时间也没去研究,最近是非要用sp1的不可了,所以再次打补丁,还是失败,提示我-未通过数字签名检查,开始以为是数据编录服务没启动 Cryptographic Services,看了下发现已经启动了,网上搜索到一个结果,这里小计下: 在windows 2003或windows XP下安装Vis…

【怎样写代码】工厂三兄弟之抽象工厂模式(六):扩展案例II

如果喜欢这里的内容&#xff0c;你能够给我最大的帮助就是转发&#xff0c;告诉你的朋友&#xff0c;鼓励他们一起来学习。 If you like the content here, you can give me the greatest help is forwarding, tell your friends, encourage them to learn together.

计算机应用基础第三章操作步骤,最新江西三校生计算机应用基础模拟操作题集锦(超实用!)...

第二章 Windows XP 操作系统? 【2011高考】 将计算机系统时间修改为2011年9月1日10&#xff1a;30。请写出操作步骤。 答&#xff1a;双击系统托盘中时间图标(或双击“控制面板”窗口中的“日期和时间”图标)&#xff0c;打开“日期和时间属性”对话框&#xff1b;在“日期”分…

同花顺的数据格式总览(转帖)

原文&#xff1a;http://enterprisebeing.spaces.live.com/Blog/cns!1D3811D0695B6887!172.entry 同花顺采用了简易的数据库组织方式。在同花顺的发布文件包中包括了SQLite 3的驱动&#xff0c;但不是很清楚同花顺是如何使用这个驱动的。基本上&#xff0c;对同花顺数据结构的解…

【怎样写代码】对象克隆 -- 原型模式(一):问题案例

如果喜欢这里的内容&#xff0c;你能够给我最大的帮助就是转发&#xff0c;告诉你的朋友&#xff0c;鼓励他们一起来学习。 If you like the content here, you can give me the greatest help is forwarding, tell your friends, encourage them to learn together.

狗是放弃了自由的狼

2019独角兽企业重金招聘Python工程师标准>>> 远古时期&#xff0c;狼群与人类争夺食物。它们有灵敏的嗅觉和听觉&#xff0c;往往先于人类找到食物。它们是人类强劲的竞争对手。 然而却有一部分狼&#xff0c;为了偷懒&#xff0c;不去捕猎而选择了依附人类。它们为…

计算机组原理ppt,计算机组原理第三章.ppt

计算机组原理第三章计算机组成原理 毛典辉 北京工商大学计算机与信息工程学院 Email: amaode 进一步结论&#xff1a; 当最高有效位产生进位而符号位无进位时,产生上溢&#xff1b; 当最高有效位无进位而符号位有进位时,产生下溢。 缺点 将多个数一次相加&#xff0c;机器难以实…

DotNet关键知识点——WCF篇(六)

关于WCF消息通信的安全性论题。 1. 传输层面的安全性 一般方法&#xff1a; binding单元中加security单元&#xff0c;security一般含mode属性&#xff0c;一般将其设置为"Transport"&#xff0c;随后在security单元中加入transport单元&#xff0c;并对其参数作设置…

AAC_LC用LATM封装header信息解析 Audio Specific Config格式分析

通常来说AAC的头信息在编解码过程中是可以获取到的&#xff0c;但今天需要根据音频参数生成相应的AAC头。项目中使用的是AAC_LC&#xff0c;今天先对它的结构进行分析。 项目中使用ffmpeg进行音频编码&#xff0c;音频编码库为FAAC&#xff0c;好吧&#xff0c;直接看代码吧。 …

【怎样写代码】对象克隆 -- 原型模式(二):解决方案

如果喜欢这里的内容&#xff0c;你能够给我最大的帮助就是转发&#xff0c;告诉你的朋友&#xff0c;鼓励他们一起来学习。 If you like the content here, you can give me the greatest help is forwarding, tell your friends, encourage them to learn together.

计算机二级周小丹,亲爱的设计丨周小丹:始终认真,才能保持“天真”

从事室内设计&#xff0c;女性好像天然占了一些优势&#xff0c;比如对色彩和美学的敏感性、更强的沟通能力以及相较大多数男性而言更细致的观察力等等。但在实操层面&#xff0c;室内设计这一行实则非常考验女性设计师的“体能”&#xff0c;比如下工地、熬夜赶图等等。从北京…

最近在招标中评审出一个政府信息化软件

发布时间&#xff1a; &#xff1a;2010-03-31 18:42 浏览次数&#xff1a; &#xff1a; 5 产品名称&#xff1a; 卓技协同政府审批系统 V3.0(http://http://www.exctek.com/)英文名&#xff1a; ExctekSoft.CGA(Collaborative Government Approval) 适用客户&#xff…

克里斯坦森的破坏性创新—《可以量化的管理学》

6.4.4作用点与克里斯坦森的破坏性创新 内容提要&#xff1a;消费者对商品的需求焦点会随着商品的发展而从功能性到可靠性&#xff0c;到便利性&#xff0c;最后转移到价格。克莱顿•克里斯坦森(Clayton M. Christensen)所创造的破坏性创新就是指消费者需求焦点的转移&#xff0…

【怎样写代码】对象克隆 -- 原型模式(三):原型模式

如果喜欢这里的内容&#xff0c;你能够给我最大的帮助就是转发&#xff0c;告诉你的朋友&#xff0c;鼓励他们一起来学习。 If you like the content here, you can give me the greatest help is forwarding, tell your friends, encourage them to learn together.

楼主考南师计算机学硕,南京师范大学考研详解:据说这所学校不太好考?嗯,是真的!...

学校&#xff1a;南京师范大学地区&#xff1a;江苏省属性&#xff1a;“211工程”院校、“双一流”世界一流学科建设高校关于南师大南京师范大学&#xff0c;地处江苏南京&#xff0c;拥有绝佳的地理位置。在全国第四轮学科评估中&#xff0c;2个学科获得A&#xff0c;4个学科…

asp页面和Asp.net页面传中文参数UrlEncode编码以及接收解码

在asp中加一个链接&#xff0c;指向asp.net网页&#xff0c;但asp.net的网址是经过HttpUtility.UrlEncode转换和HttpUtility.UrlDecode解码的&#xff0c;而asp的server.urlencode却和HttpUtility.UrlEncode的编码方式不一样&#xff0c; 举例&#xff1a;asp.net用Get方式传输…

MyBatis关联查询、多条件查询

MyBatis关联查询、多条件查询 1、一对一查询 任务需求; 根据班级的信息查询出教师的相关信息 1、数据库表的设计 班级表&#xff1a; 教师表&#xff1a; 2、实体类的设计 班级表&#xff1a; public class Classes { 9 //定义实体类的属性&#xff0c;与class表中的字段对…

【怎样写代码】对象克隆 -- 原型模式(四):浅克隆与深克隆

如果喜欢这里的内容&#xff0c;你能够给我最大的帮助就是转发&#xff0c;告诉你的朋友&#xff0c;鼓励他们一起来学习。 If you like the content here, you can give me the greatest help is forwarding, tell your friends, encourage them to learn together.

计算机与控制学院优秀学生,三好学生主要事迹:计算机与控制工程学院王天琪事迹.doc...

三好学生主要事迹&#xff1a;计算机与控制工程学院王天琪事迹“中国好同学”、“中国好男孩”、“中国好男友”——用这“三好”来形容王天琪再合适不过。这个四川男生笑容温暖&#xff0c;彬彬有礼&#xff0c;生长于南方却操着一口标准的普通话&#xff0c;交谈中时而有些羞…

[总结]博客聚合-cnblogs,wordpress,live writer,word2010

一、url地址&#xff1a; cnblogs&#xff1a; http://BusyAnt.cnblogs.com/services/metaweblog.aspx wordpress: http://blog.busyant.cn/xmlrpc.php CSDN&#xff1a;http://blog.csdn.net/busyant/services/metablogapi.aspx 二、配置&#xff1a; word2010&#xff1a;文件…

【怎样写代码】对象克隆 -- 原型模式(五):原型管理器的引入和实现

如果喜欢这里的内容&#xff0c;你能够给我最大的帮助就是转发&#xff0c;告诉你的朋友&#xff0c;鼓励他们一起来学习。 If you like the content here, you can give me the greatest help is forwarding, tell your friends, encourage them to learn together.

Android 基于 Speex 的高度封装语音库,0 耦合,没三方jar包

作者&#xff1a;林冠宏 / 指尖下的幽灵 掘金&#xff1a;https://juejin.im/user/587f0dfe128fe100570ce2d8 博客&#xff1a;http://www.cnblogs.com/linguanh/ GitHub &#xff1a; https://github.com/af913337456/ 为了您的直观体验&#xff0c;请务必看完下面 截图&#…

计算机累加器有加法器功能吗,累加器-累加器ACC的作用

ACC累加器B用于辅助累加器做某些运算的寄存器PSW程序状态字其中最高位是进/借位标志C&#xff1b;PSW.6是辅助进位标志AC&#xff0c;用于标识加减运算中低四位向高四位的进位&#xff1b;PSW.4和PSW.3是寄存器组选择位RS1和RS0&#xff0c;用于从--1FH的32个存储器单元(4组)中…

object expected错误解决方法

写一个页面&#xff0c;引用了另外的js&#xff0c;结果触发js事件时&#xff0c;浏览器显示"object expected "错误&#xff0c;说什么action有错&#xff0c;在action硬是纠结了半天&#xff0c;结果发现是由于action跳转之后&#xff0c;路径错了&#xff0c;所以…

Eclipse优化之设置不自动弹出控制台和Server

有时候Eclipse启动&#xff0c;控制台console不会自动跳出来&#xff0c;需要手工点击该选项卡才行&#xff0c; 按下面的设置&#xff0c;可以让它自动跳出来(或不跳出来)&#xff1a; windows -> preferences -> run/debug -> console 在右边面板勾选或…

【怎样写代码】复杂对象的组装与创建 -- 建造者模式(一):问题案例

如果喜欢这里的内容&#xff0c;你能够给我最大的帮助就是转发&#xff0c;告诉你的朋友&#xff0c;鼓励他们一起来学习。 If you like the content here, you can give me the greatest help is forwarding, tell your friends, encourage them to learn together.

css menu builder,AutoPlay Menu Builder使用教程【图文教程】

是一个功能强大的光盘自动运行菜单制作工具&#xff0c;使用它,你不需要具备任何专业知识,只需要经过鼠标拖放和几次鼠标点击就可以轻松制作出非常漂亮的自动运行(AutoRun)菜单程序,让你制作菜单象垒积木一样容易!二、软件使用1、如图一所示&#xff0c;软件启动时首先随程序主…

freemarker写select组件报错总结(六)

1、错误描写叙述 六月 26, 2014 10:53:26 下午 freemarker.log.JDK14LoggerFactory$JDK14Logger error 严重: Template processing error: "Expression data[text] is undefined on line 9, column 51 in inc/select.ftl."Expression data[text] is undefined on lin…

FPGA中LVDS差分高速传输的实现

低压差分传送技术是基于低压差分信号(Low Volt-agc Differential signaling)的传送技术&#xff0c;从一个电路板系统内的高速信号传送到不同电路系统之间的快速数据传送都可以应用低压差分传送技术来实现&#xff0c;其应用正变得越来越重要。低压差分信号相对于单端的传送具有…

【怎样写代码】复杂对象的组装与创建 -- 建造者模式(二):解决方案

如果喜欢这里的内容&#xff0c;你能够给我最大的帮助就是转发&#xff0c;告诉你的朋友&#xff0c;鼓励他们一起来学习。 If you like the content here, you can give me the greatest help is forwarding, tell your friends, encourage them to learn together.