mysql 事b务 查询_MySQL进阶学习笔记二(包括连接查询、子查询、联合查询、事务、存储过程)...

1、高级查询

(1)了解笛卡尔积:笛卡尔乘积是指在数学中,两个集合X和Y的笛卡尔积(Cartesian product),又称直积,表示为X × Y,第一个对象是X的成员而第二个对象是Y的所有可能有序对的其中一个成员,笛卡尔积在SQL中的实现方式既是交叉连接(Cross Join)。所有连接方式都会先生成临时笛卡尔积表,笛卡尔积是关系代数里的一个概念,表示两个表中的每一-行数据任意组合。

(2) 关联查询(连接查询)

(a)内连接:内连接与连接顺序无关

关联表中都出现的字段值最终才能出现再结果集中

SELECT * FROM app_order_base a,app_order_details b WHERE a.id=b.goods_id

SELECT * FROM app_order_base a INNER JOIN app_order_details b on a.id=b.goods_id

#通用列字段名称必须一致,可以去掉重复字段

SELECT * FROM app_order_base a INNER JOIN app_order_details USING(id)

(b)外连接:有主从表之分,与连接顺序有关

依次遍历主表中记录,与从表中记录进行匹配;如果匹配到则连接展 示,否则以null填充。

左外连接:left[outer] join on

SELECT * FROM app_order_base a LEFT JOIN app_order_details b on a.id=b.goods_id

右外连接:right[outer] join on

SELECT * FROM app_order_base a RIGHT JOIN app_order_details b on a.id=b.goods_id

自然连接(特殊连接):

自然连接肯定是等值连接,但是等值连接不一定是自然连接

SELECT * FROM app_order_base NATURAL JOIN app_order_details;

查看数据库编码

#查看数据库编码

SHOW VARIABLES LIKE '%char%'

(3)子查询(嵌套查询):

嵌套查询:将一个查询的结果当作另一个查询的条件或者结果集。

子查询比较接近思考方式,最自然的查询。

分类

(a)单行子查询:子查询的结果有一条

(b)多行子查询:子查询的结果有多条

in: in(value,value)

any: =any 相当于in

>any 大于最小值

all: >all 大于最大值

#in和exists的区别:

in 先执行子查询,将结果返回给主查询,主查询继续执行

exists 先执行主查询,将主查询的值依次在子查询中进行匹配,根据是否匹配返回true和false,如果是true值连接展示,否则不展示

#多表和子查询

子查询 --->查询条件和结果放在一张表中。

查询结果分布于多张表

关联查询

(4)联合查询:

关键字:union/union all union可以去除重复

2、存储引擎和事务

(1)存储引擎(show ENGINES):数据库底层软件组织,dbms通过存储引擎实现对数据的操作,MySQL核心就是存储引擎。

MySQL中可以设置多种存储引擎,不同的存储引擎在索引,存储,以及策略上是不同的。

数据库存储引擎是数据库底层软件组织,数据库管理系统(DBMS)使用数据引擎进行创建、查询、更新和删除数据。不同的存储引擎提供不同的存储机制、素引技巧、锁定水平等功能,使用不同的存储引擎,还可以获得特定的功能。Mysql 的核心就是存储引擎。

InnoDB是事务型数据库的首选,执行安全性数据库,行锁定和外键。mysql5.5 之后默认使用。

MyISAM插入速度和查询效率较高,但不支持事务。

MEMORY将表中的数据存储在内存中,速度较快。

各个存储引擎的不同之处:

功能

MyISAM

MEMORY

InnoDB

Archive

存储限制

256TB

RAM

64TB

None

支持事务

N

N

Y

N

支持全文索引

Y

N

N

N

支持数索引

Y

Y

Y

N

支持哈希索引

N

Y

N

N

支持数据缓存

N

N/A

Y

N

支持外键

N

N

Y

N

mysql5.5以前默认存储引擎为MyISAM:支持全文搜索,不支持事务。

mysql5.5+默认存储引擎为INNODB:支持事务、行级锁。

(2)事务:保持数据一致性,一组DML操作要么同时成功,要么同时失败。

(a)事务的acid特性:

原子性:放在同一事务的一组操作时不可分割的;

一致性:在事务的执行前后整体的状态保持不变;

隔离性:并发事务之间相互不干扰;

持久性:事务执行之后将永久化到数据库;

(b) 事务语法(数据库中):MySQL默认采用事务自动提交。

#查看MySQL的事务自动提交

show variables like 'autocommit'

#修改自动提交

set autocommit = 0; #手动提交事务

set autocommit = 1; #自动提交事务

#显示开启事务(begin):

start transaction;

#手动提交事务或回滚

commit; #提交

rollback #回滚

(c)并发事务产生的问题

脏读:一个事务执行范围内读到了另一条未提交的数据;

不可重复读:一个事务在只读范围内,被另一事务修改并提交事务,导致多次读取事务不一致的问题。

幻读(虚读):一个事务只读范围内,被另一事务删除或者添加数据,导致读取数据不一致问题。

(d)事务隔离级别:

读未提交:不能处理任何问题;

读已提交:解决脏读问题;

可重复读:解决脏读和不可重复读问题;

串行化:解决所有问题,效率较低;

#查看事务隔离级别

SELECT @@tx_isolation

#修改事务隔离级别

set session transaction isolation level

3、存储程序

(1)、运行于服务器端程序

(2)、优点:

简化开发,执行效率较高,

(3)缺点:

程序保存在服务器端,占用服务器资源

数据迁移的时候考虑迁移所有的存储程序

调试编写程序不方便

(4)、分类

存储过程:服务器端运行的可重复调用的sql代码块,包含名称,输入输出参数,一组sql。

#修改结束标志

delimiter //;

#创建存储过程

create procedure sel_emp()

begin

#sql

select * from student;

end;

#存储过程调用

call sel_emp();

#参数的传入

delimiter //;

create procedure findEmpByNo(in eno int)

begin

selete * from emp where deptno = dno;

end;

call findEmpByNo(20);

#参数的输出

delimiter //;

create procedure findNameByNo(in eno int,out v_name varchar(20))

begin

select ename into v_name from emp where empno = eno;

end;

call findNameByNo(7788,@v_name);

select @v_name;

存储函数:存储在服务器端,有返回值,函数作为sql一部分使用。

delimiter //;

create function findNameByNo(eno int)

returns varchar(20) #返回值类型

DETERMINISTIC #确定的

begin

declare v_name varchar(20);#与上边定义的一致

select ename from where empon=eno;

return v_name;

end;

#调用

select findNameByNo(7788);

函数和存储过程的区别:

关键字不同

存储过程三种参数模式实现数据输入输出,函数有返回值返回数据

存储过程可以作为单独个体执行,函数只能作为sql的一部分执行

触发器

存储程序,存储再服务器端

由事件(增删改)调用,不能传参

不要添加过多的触发器(降低效率)

存储程序中不能使用事务控制

#创建触发器

delimiter //;

create trigger tri_user

after delete

on userinfo for each row

begin

#old new

insert into user_bak values(old.uid,old.uname,old.password)

end;

4、清除表中数据的方式:

(1)、清空全部数据,不写日志,不可恢复,速度很快

truncate table 表名;·

(2)、清空全部数据,写日志,可恢复,速度很慢

delete from 表名;

本文地址:https://blog.csdn.net/Java_xiaoxinxin/article/details/107319331

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/573385.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

当前,我们的DJANGO项目的requirements.txt文件

晒一晒,看用得多不多。。:) amqp1.4.7 anyjson0.3.3 billiard3.3.0.21 celery3.1.19 celery-with-redis3.0 cx-Oracle5.1.2 Django1.8.4 django-bootstrap36.2.2 django-celery3.1.17 django-grappelli2.7.3 django-tinymce2.2.0 djangorestf…

python字典的应用实验报告_Python字典应用的一个例子

#!/usr/bin/env python#定义一个空字典db {}def newuser():prompt --login desired: while True:name raw_input(prompt)#根据关键字name看字典中是否已存在此键值对if db.has_key(name):prompt --name taken, try another: continueelse:breakpwd raw_input(passwd: )#存…

Untiy3D Material 材质系统

材质系统在任何引擎里面都算一个大模块,我也遍了解遍写,写到哪里算哪里。 里面涉及到材质属性系统,底层Shader模块和纹理Texture模块。所以比较复杂,如果理解材质系统,那就能控制整个游戏画面渲染效果。 Material 材质…

python弹出另一个窗口_Python 中PyQt5 点击主窗口弹出另一个窗口的实现方法

1.先使用Qt designer设计两个窗口,一个是主窗口,一个是子窗口其中主窗口是新建-Main Window,子窗口是Dialog窗体。两个窗口不能是同一类型,否则会崩溃。并保存为EyeTracking_main.ui和EyeTracking_process.ui(因为我在做眼动追踪,因此窗体命名…

python读取文件数据堆栈溢出的原因_堆栈溢出一般是什么原因?

堆栈是一个在计算机科学中经常使用的抽象数据类型。堆栈中的物体具有一个特性: 最后一个放入堆栈中的物体总是被最先拿出来, 这个特性通常称为后进先出(LIFO)队列。 堆栈中定义了一些操作。 两个最重要的是PUSH和POP。 PUSH操作在堆栈的顶部加入一 个元素…

.NET Core 开发之旅 (1. .NET Core R2安装教程及Hello示例)

前言 前几天.NET Core发布了.NET Core 1.0.1 R2 预览版,之前想着有时间尝试下.NET Core。由于各种原因,就没有初试。刚好,前几天看到.NET Core发布新版本了,决定要去一探究竟。于是乎,就立马去官网查找相关的信息&…

java引用传递_理解Java中的引用传递和值传递

关于Java传参时是引用传递还是值传递,是一个讨论比较多的话题,有说Java中只有值传递,也有些地方说引用传递和值传递都存在,本篇记录思考过程,不保证正确性,感兴趣的同学一起讨论。1.基本类型和引用类型在内…

程雷被机器人_太意外了:49岁知名主持人程雷,得遗传性病和女友终分手!

注本文部分文字与图片资源来自于网络,转载此文是出于传递更多信息之目的,若有来源标注错误或侵犯了您的合法权益,请立即通知我们,情况属实,我们会第一时间予以删除,并同时向您表示歉意遗传性肝病发女友不离不弃&#x…

java flatmap_Java 8 Steam API map和flatMap方法使用详解

java 8 stream api 中有两个方法map和flatMap非常实用,应用场景也非常广泛,能极大提升编程效率。下面我们详细介绍一下这两个方法的用法。map方法我们来看个示例:把一个整数列表转换成字符串列表,java 8之前常用的实现方法如下Lis…

java post 多文件报头_Spring MVC-------文件上传,单文件,多文件,文件下载

Spring MVC框架的文件上传是基于 commons-fileupload 组件的文件上传,只不过SpringMVC 框架在原有文件上传组件上做了进一步封装,简化了文件上传的代码实现,取消了不同上传组件上的编程差异。commons-fileupload组件由于 Spring MVC 框架的文…

java 按照概率生成随机数_JAVA 根据设置的概率生成随机数的方法

import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;import java.util.Random;public class RandomTest {// String 可以为任意类型 也可以自定义类型static Map keyChanceMap new HashMap();static {keyChanceMap.put("a…

java文本域 图片_java swing中给面板或者文本域设置背景图片的方法!

以JPanel为例public class MyTextArea extends JPanel{/*** param args*/private Image bgImg null;public MyTextArea(){setOpaque(false);bgImg Toolkit.getDefaultToolkit().createImage(BGTextArea.class.getResource( "login2.gif ")); //图片要…

win10 java无法运行_Win10中配置jdk之后javac无法运行

环境变量(environment variables)一般是指在操作系统中用来指定操作系统运行环境的一些参数,如:临时文件夹位置和系统文件夹位置等。环境变量是在操作系统中一个具有特定名字的对象,它包含了一个或者多个应用程序所将使用到的信息。例如Windo…

cocos2d c 调用java_cocos2d-x之C++ 调用Java函数并接收返回值

参考:http://blog.csdn.net/xiaominghimi/article/details/7602984//java中string转C中string#if (CC_TARGET_PLATFORM CC_PLATFORM_ANDROID)//jstring to char*std::string jstringTostring(JNIEnv* env,jstring jstr){char* rtn NULL;jclass clsstring env->…

java的reentrantlock_JAVA中ReentrantLock详解(转)

转自https://www.cnblogs.com/java-learner/p/9651675.html前言:本文解决的问题RentrantLock与Synchronized区别ReentrantLock特征ReentrantLock类的方法介绍1.什么是ReentrantLock1.1ReentrantLock 与Synchronized区别在面试中询问ReentrantLock与Synchronized区别…

Servlet添加商品

Servlet实现添加商品 <% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd&…

java运行win10_win10配置java运行环境

1.下载jdk根据自己的电脑下载对应的版本&#xff0c;需要先注册账号才可以下载百度网盘&#xff1a;链接&#xff1a;https://pan.baidu.com/s/1gjpdQo8t8Va8uPiHDDvB3Q提取码&#xff1a;5a0c2.下载完成&#xff0c;点击安装&#xff0c;一般直接根据默认安装即可&#xff0c;…

[转]C#网络编程(同步传输字符串) - Part.2

本文转自&#xff1a;http://www.tracefact.net/CSharp-Programming/Network-Programming-Part2.aspx 服务端客户端通信 在与服务端的连接建立以后&#xff0c;我们就可以通过此连接来发送和接收数据。端口与端口之间以流&#xff08;Stream&#xff09;的形式传输数据&#xf…

tomcat 设置java_为tomcat配置java环境变量

我的tomcat 中java标签里是这么写的java virual Machine:C:\Program Files\Java\jre1.6.0\bin\client\jvm.dlljava classpath:C:\Program Files\Apache Software Foundation\Tomcat 5.5\bin\bootstrap.jarjava options:-Dcatalina.homeC:\Program Files\Apache Software Founda…

项目开发流程标准

1 项目各阶段主要成果列表 项目阶段 主要内容 1、商务谈判阶段 《业务需求说明书》、《项目风险评估报告》、 《项目可行性报告书》&#xff08;可由市场或TC部提供&#xff09; 或1、技术部项目立项 《技术部项目立项表》、《项目可行性报告书》 2、计划与设计阶…