sql中的连接表达式,视图,事务等。
给定两张表
表A
create table A(ID int,name varchar(20),description varchar(20));
insert into A values(1,'N1','AD1');
insert into A values(2,'N2','AD2');
mysql> SELECT * FROM a;
+----+------+-------------+
| ID | name | description |
+----+------+-------------+
| 1 | N1 | AD1 |
| 2 | N2 | AD2 |
+----+------+-------------+
表B
create table B(ID int,name varchar(20),age int);
insert into B values(1,'N1',20);
insert into B values(3,'N2',21);
mysql> select * from B;
+----+------+-----+
| ID | name | age |
+----+------+-----+
| 1 | N1 | 20 |
| 3 | N2 | 21 |
+----+------+-----+
一:连接
1:自然连接
在共同的属性上(ID,name)取相同的值的元组(行)构成的模式(关系,表)。
mysql> select * from A natural join B;
+----+------+-------------+-----+
| ID | name | description | age |
+----+------+-------------+-----+
| 1 | N1 | AD1 | 20 |
+----+------+-------------+-----+
2: join....on ,指定条件的笛卡尔连接,在on上指定查询条件
mysql> select * from A join B on A.name=B.name; //在属性name上值相等就行, 相同属性会出现多次,可以在*上代替属性集合
+----+------+-------------+----+------+-----+
| ID | name | description | ID | name | age |
+----+------+-------------+----+------+-----+
| 1 | N1 | AD1 | 1 | N1 | 20 |
| 2 | N2 | AD2 | 3 | N2 | 21 |
+----+------+-------------+----+------+-----+
3:左外自然连接,在连接natural join 左边的表的元组全部出现,右边表与左边表在相同属性上相等时,会出现。属性不同时,右边表的属性为null。
出现左表的属性和右表中与左表不同的属性。
mysql> select * from A natural left outer join B;
+----+------+-------------+------+
| ID | name | description | age |
+----+------+-------------+------+
| 1 | N1 | AD1 | 20 |
| 2 | N2 | AD2 | NULL |
+----+------+-------------+------+
4:左外连接。 自然连接会去除相同的属性
mysql> select * from A left outer join B on A.ID=B.ID;
+----+------+-------------+------+------+------+
| ID | name | description | ID | name | age |
+----+------+-------------+------+------+------+
| 1 | N1 | AD1 | 1 | N1 | 20 |
| 2 | N2 | AD2 | NULL | NULL | NULL |
+----+------+-------------+------+------+------+
5:内连接,在相同的属性上相同的值,两张表的属性都出现。
mysql> select * from A INNER join B on A.ID=B.ID;
+----+------+-------------+----+------+-----+
| ID | name | description | ID | name | age |
+----+------+-------------+----+------+-----+
| 1 | N1 | AD1 | 1 | N1 | 20 |
+----+------+-------------+----+------+-----+
二:视图
1: 创建视图C
mysql> create view C as select * from A natural left outer join B;
2:使用视图
mysql> select * from C;
+----+------+-------------+------+
| ID | name | description | age |
+----+------+-------------+------+
| 1 | N1 | AD1 | 20 |
| 2 | N2 | AD2 | NULL |
+----+------+-------------+------+
3:显式的指定视图的属性名
create view D(ID,D_name) as select ID,name from A natural left outer join B;
mysql> select * from D;
+----+--------+
| ID | D_name |
+----+--------+
| 1 | N1 |
| 2 | N2 |
+----+--------+
三:事务
1:set autocommit=0; 设置mysql手动提交。set autocommit=1; 自动提交commit. 这样就相当于每次更新之后立刻提交
2:开启事务,插入,回滚。
mysql> set autocommit=0;
mysql> start transaction; //开启事务
mysql> insert into A values(3,'N3','AD3'); //插入
mysql> select * from A;
+----+------+-------------+
| ID | name | description |
+----+------+-------------+
| 1 | N1 | AD1 |
| 2 | N2 | AD2 |
| 3 | N3 | AD3 |
+----+------+-------------+
mysql> rollback; //回滚
mysql> select * from A;
+----+------+-------------+
| ID | name | description |
+----+------+-------------+
| 1 | N1 | AD1 |
| 2 | N2 | AD2 |
+----+------+-------------+
3: 开启事务,插入,提交,回滚
mysql> start transaction;
Query OK, 0 rows affected mysql> insert into A values(3,'N3','AD3');
Query OK, 1 row affected mysql> select * from A;
+----+------+-------------+
| ID | name | description |
+----+------+-------------+
| 1 | N1 | AD1 |
| 2 | N2 | AD2 |
| 3 | N3 | AD3 |
+----+------+-------------+
3 rows in set mysql> commit work;
Query OK, 0 rows affected mysql> select * from A;
+----+------+-------------+
| ID | name | description |
+----+------+-------------+
| 1 | N1 | AD1 |
| 2 | N2 | AD2 |
| 3 | N3 | AD3 |
+----+------+-------------+
3 rows in set mysql> rollback; //回滚无效
Query OK, 0 rows affected mysql> select * from A;
+----+------+-------------+
| ID | name | description |
+----+------+-------------+
| 1 | N1 | AD1 |
| 2 | N2 | AD2 |
| 3 | N3 | AD3 |
+----+------+-------------+
3 rows in set
四:完整性
1:为id添加唯一约束
alter table A modify id int unique;
2:为属性添加约束,例如约束id<4 (mysql中不能使用check,需要为改约束定义触发器) 。 https://www.cnblogs.com/duodushu/p/5446384.html
mysql> CREATE TRIGGER TestField1_BeforeInsert BEFORE INSERT ON A
FOR EACH ROW
BEGIN
IF NEW.ID > 4 THEN
SET NEW.ID = 0;
END IF;
END;
Query OK, 0 rows affected mysql> insert into A values(5,'','');
Query OK, 1 row affected mysql> select * from A;
+----+------+-------------+
| ID | name | description |
+----+------+-------------+
| 1 | N1 | AD1 |
| 2 | N2 | AD2 |
| 3 | N3 | AD3 |
| 0 | 5 | 5 |
+----+------+-------------+
4 rows in set
五:索引
1:创建索引 create index AindexId on A(ID);
mysql> create index AindexId on A(ID);
Query OK, 0 rows affected
Records: 0 Duplicates: 0 Warnings: 0
mysql> select * from A where ID=1;
+----+------+-------------+
| ID | name | description |
+----+------+-------------+
| 1 | N1 | AD1 |
+----+------+-------------+
1 row in set
sql中的连接表达式,视图,事务等。的更多相关文章
- ABAP 7.50 新特性 – Open SQL中的宿主表达式和其它表达式
在长期的停滞后,Open SQL的发展终于从沉睡中醒来.从ABAP 7.40开始,SAP推进了某些关键的改变,以尽可能地包含SQL92中的特性,并提供与ABAP CDS中的DDL里面的SELECT一样 ...
- SQL中的连接可以分为内连接,外连接,以及交叉连接 。
SQL中的连接可以分为内连接,外连接,以及交叉连接 . 1. 交叉连接CROSS JOIN 如果不带WHERE条件子句,它将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积: 举例, ...
- SQL中的连接(极客时间)
SQL中的连接 关系型数据库的核心之一就是连接, 而在不同的标准中, 连接的写法上可能有区别, 最为主要的两个SQL标准就是SQL92和SQL99了, 后面的数字表示的是标准提出的时间. SQL92中 ...
- PL/SQL程序控制结构及在PL/SQL中更改数据和管理事务
1.条件控制 A. IF条件分支语法: if (条件1) then 语句; elsif (条件2) then 语句; elsif (条件3) then 语句; else 语句; end if; B . ...
- sql中的触发器、视图、事务
·触发器(trigger) [触发器本质上还是一个存储过程,只不过不是用exe来调用执行,而是通过增删改数据库的操作] [触发器只对增.删.改有效] 触发器的格式 (instead of与for的区别 ...
- SQL中的连接查询及其优化原则
连接查询是SQL的主要任务,只有很好的掌握了连接查询及其优化方法才算是掌握了SQL的精髓所在.最近在面试中遇到了有关连接查询的问题,感觉回答的不是很好,总结一下. 具体示例请参考:http://www ...
- 【转】SQL中内连接和外连接
如表 ------------------------------------------------- table1 | table2 | ----------------- ...
- SQL中内连接和外连接的问题!
本文系转载,版权归原作者所有. 如表 ------------------------------------------------- table1 | table2 | ...
- SQL 中的连接查询
关于SQL的应用,肯定离不开查询,而相对复杂的查询,总是离不开对表的连接,单个表操作的并不罕见,但是在应用环境大多数的查询都是针对2.3个表甚至更多的表7,至于连接,有内连接.外链接.交叉连接之分,每 ...
随机推荐
- php7 扩展模块添加
php 扩展模块添加 1. 新增安装扩展模块的位置 [root@node_22 ~]# ls /usr/local/php7/lib/php/extensions/no-debug-non-zts ...
- 关于json动态拼接响应数据
在EasyUI http://www.jeasyui.com/demo/main/get_users.php 响应数据如下格式: { "total": "11" ...
- hadoop杂记-为什么会有Map-reduce v2 (Yarn)
转自:http://www.cnblogs.com/LeftNotEasy/archive/2012/02/18/why-yarn.html 前言: 有一段时间没有写博客了(发现这是我博客最常见的开头 ...
- Spring Cloud的子项目,大致可分成两类
Spring Cloud的子项目,大致可分成两类,一类是对现有成熟框架”Spring Boot化”的封装和抽象,也是数量最多的项目:第二类是开发了一部分分布式系统的基础设施的实现,如Spring Cl ...
- IoC是一个很大的概念,可以用不同的方式实现。其主要形式有两种:
IoC是一个很大的概念,可以用不同的方式实现.其主要形式有两种: ◇依赖查找:容器提供回调接口和上下文条件给组件.EJB和ApacheAvalon都使用这种方式.这样一来,组件就必须使用容器提供的AP ...
- .bss,.data,.text,.rodata
那天工作时候发现build的时候发现问题, 问题内容是:.text的空间太小了. 我一直以为写代码,就真是弄懂代码怎么写,式样书怎么写,或者弄懂代码的问题所在, 没有想到在build的时候出现问题.结 ...
- 事务基础知识-->Spring事务管理
Spring虽然提供了灵活方便的事务管理功能,但这些功能都是基于底层数据库本身的事务处理机制工作的.要深入了解Spring的事务管理和配置,有必要先对数据库事务的基础知识进行学习. 何为数据库事务 “ ...
- AWS CLI 【S3】
1.创建一个桶&删除一个桶 root@syavingc:~# aws s3 mb s3://syavingc #创建一个桶 make_bucket: syavingc root@syaving ...
- Oracle中select使用别名
1 .将字段用as转换成别名. 2 .直接在字段的名字后面跟别名. 3 .在字段后面用双引号引起的别名. 我的朋友 大鬼不动 最近访客 fhwlj kochiyas 大極星 Alz__ deser ...
- ios笔试题(选择题)
1-10 C语言 & 计算机基础 1.请看下面一段代码 static int a = 1; int main(){ int b = 2; char *c = NULL; c = (char * ...