mysql存储过程主键
要求如下要求A:输入表名、建立对应副表,其中副表要有额外的记录主键(ID_ROW_SEQ_NO)自增长,额外字段,更新时间(LG_CHG_TIME),操作标记,记录状态,来源系统
要求B:建立表名,建立触发器带有增删改功能将捕获变化数据写入对应副表,主表添加一条记录,副表中增加一条记录,标记“I”,主表删除一条记录,副表中增加一条记录,标记“D”,主表更新一条记录,副表中增加一条记录,标记“U”
C要求:操作A表触发B表
‘贰’ mysql 存储过程 若主键冲突则更新,不冲突则插入数据
你可以分两部份导入
先导入在表里有IDDATE的更新部份
mysql> UPDATE 表1 SET 列名=(SELECT 列名 FROM 表2
WHERE 表1.IDDATE=表2.IDDATE)
WHERE IDDATE in (SELECT IDDATE FROM 表2);
再导入插入部份
INSERT INTO 表1 (SELECT IDDATE,列名 FROM 表2
WHERE DDATE not in (SELECT IDDATE FROM 表2));
‘叁’ mysql 存储过程总结(一)
1、存储过程定义:
存储过程是事先经过编译并存储在数据库中的一段 SQL 语句的集合,调用存储过程可以简化应用开发 人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。 存储过程思想上很简单,就是数据库 SQL 语言层面的代码封装与重用。
2、特点:
封装,复用 : 可以把某一业务SQL封装在存储过程中,需要用到 的时候直接调用即可。
可以接收参数,也可以返回数据 :再存储过程中,可以传递参数,也可以接收返回 值。
减少网络交互,效率提升 : 如果涉及到多条SQL,每执行一次都是一次网络传 输。 而如果封装在存储过程中,我们只需要网络交互一次可能就可以了。
3、基本语法
(1)创建:
(2)调用:
(3)查看:
(4)删除
注意: 在命令行中,执行创建存储过程的SQL时,需要通过关键字 delimiter 指定SQL语句的 结束符。
‘肆’ mysql存储过程出现锁表锁行的情况怎么解决
行锁的等待
在介绍如何解决行锁等待问题前,先简单介绍下这类问题产生的原因。产生原因简述:当多个事务同时去操作(增删改)某一行数据的时候,MySQL 为了维护 ACID 特性,就会用锁的形式来防止多个事务同时操作某一行数据,避免数据不一致。只有分配到行锁的事务才有权力操作该数据行,直到该事务结束,才释放行锁,而其他没有分配到行锁的事务就会产生行锁等待。如果等待时间超过了配置值(也就是 innodb_lock_wait_timeout 参数的值,个人习惯配置成 5s,MySQL 官方默认为 50s),则会抛出行锁等待超时错误。
如上图所示,事务 A 与事务 B 同时会去 Insert 一条主键值为 1 的数据,由于事务 A 首先获取了主键值为 1 的行锁,导致事务 B 因无法获取行锁而产生等待,等到事务 A 提交后,事务 B 才获取该行锁,完成提交。这里强调的是行锁的概念,虽然事务 B 重复插入了主键,但是在获取行锁之前,事务一直是处于行锁等待的状态,只有获取行锁后,才会报主键冲突的错误。当然这种 Insert 行锁冲突的问题比较少见,只有在大量并发插入场景下才会出现,项目上真正常见的是 update&delete 之间行锁等待,这里只是用于示例,原理都是相同的。
三、产生的原因根据我之前接触到的此类问题,大致可以分为以下几种原因
‘伍’ 可能有点麻烦 但还是想给这段MySQL加上注释 (创建一个存储过程,计算表tb_student 数据行数)
delimiter//
createproceresp_sum(outrowsint)--创建存储过程定义rows为int类型的输出
->begin--语法
->declaresnochar;--申明sno变量为char类型
->;--申明found变量boolean类型默认为true
->declarecurcursorfor--这个和下面的一行为一句申明游标为查询tb_student表的NO字段
->selectNofromtb_student;
->--如果没有查询到数据(3行连读)
->setfound=false;--设置found和rows的值
->setrows=0;
->opencur;--排除掉上面的情况打开游标
->fetchcurintosno;--fetchinto为游标遍历方式类似于while循环
->whilefounddo--下面4句为循环语句就是直到找不到停止循环把当前的行数赋予遍历rows
->setrows=rows;
->fetchcurintosno;
->endwhile;
->closecur;--关闭游标
ps:selectCOUNT(*)fromtb_student直接赋值给rows不就完事了
不知道你写这个存储过程有啥子意义就算No不为主键可以加where条件三
‘陆’ mysql存储过程及流程控制
存储过程(Stored
Procere)是一组为了完成特定功能的SQL语句集功能是将常用或复杂的工作,预先用SQL语句写好并用一个指定名称存储起来,
以后需要数据库提供与已定义好的存储过程的功能相同的服务时,只需调用
call
存储过程名字,
即可自动完成命令。存储过程是由流控制和SQL语句书写的过程,这个过程经编译和优化后存储在数据库服务器中,可由应用程序通过一个调用来执行,而且允许用户声明变量
。同时,存储过程可以接收和输出参数、返回执行存储过程的状态值,也可以嵌套调用。