1.mysql架构介绍

mysql的架构大致可划分为四层:

  1. 第一层客户端的连接;
  2. 第二层处理客户端连接;
  3. 第三层处理客户端的sql语句;
  4. 第四层存储引擎执行处理后的sql语句。

如图:

mysql 事件 调用多函数 mysql事物并发_数据库

2.并发控制和事物

1.事物的特性:

  1. 原子性(automicity):一个事务必须被看作一个不可分割的最小单元。对于事务里的操作要么全部成功,要么全部失败,不可能执行其中一部分。这就是事务的原子性。
  2. 一致性(consistency):数据库总是从一个一致性的状态转换到另外一个一致性的状态。在事务没有提交之前,事务中做出的修改不会被保存到数据库中。
  3. 隔离性(isolation):通常来说,一个事务做的修改,对于其他事务是不可见的。当然这取决于隔离的级别。
  4. 持久性(durability):一旦事务提交,数据将会被永久地保存在数据库中,永远保存在数据库。2.并发

2.当多个查询需要在同一时刻修改数据,就会引发并发控制,如何控制并发是数据库领域中非常重要的问题之一。这里简单介绍一下读写锁的概念。

读写锁

为了最大化数据库事务的并发能力,数据库中的锁被设计为两种模式,分别是共享锁和互斥锁。当一个事务获得共享锁之后,它只可以进行读操作,所以共享锁也叫读锁;而当一个事务获得一行数据的互斥锁时,就可以对该行数据进行读和写操作,所以互斥锁也叫写锁。

3.SQL语句

SQL即结构化查询语言(Structured Query Language),是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。SQL语句无论是种类还是数量都是繁多的,很多语句也是经常要用到的,SQL查询语句就是一个典型的例子,无论是高级查询还是低级查询,SQL查询语句的需求是最频繁的。

基本sql语句:

创建数据库
CREATE DATABASE database-name
删除数据库
drop database dbname
备份sql server
--- 创建 备份数据的 device
USE master
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'
--- 开始 备份
BACKUP DATABASE pubs TO testBack
创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
根据已有的表创建新表:
A:create table tab_new like tab_old (使用旧表创建新表)
B:create table tab_new as select col1,col2… from tab_old definition only
删除新表
drop table tabname
增加一个列
Alter table tabname add column col type
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
添加主键: Alter table tabname add primary key(col)
说明:删除主键: Alter table tabname drop primary key(col)
创建索引:create [unique] index idxname on tabname(col….)
删除索引:drop index idxname
注:索引是不可更改的,想更改必须删除重新建。
创建视图:create view viewname as select statement
删除视图:drop view viewname
几个简单的基本的sql语句
选择:select * from table1 where 范围
插入:insert into table1(field1,field2) values(value1,value2)
删除:delete from table1 where 范围
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ ---like的语法很精妙,查资料!
排序:select * from table1 order by field1,field2 [desc]
总数:select count as totalcount from table1
求和:select sum(field1) as sumvalue from table1
平均:select avg(field1) as avgvalue from table1
最大:select max(field1) as maxvalue from table1
最小:select min(field1) as minvalue from table1