博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于ibatis中mysql的@变量问题作用域、污染问题
阅读量:5352 次
发布时间:2019-06-15

本文共 724 字,大约阅读时间需要 2 分钟。

搞了1天,过程不想多说,结论如下:

 

ibatis.net 是有连接池的,用ab.exe 并发测试,可以测出默认的max连接数

 

ibatis.net的数据操作 xml 中可以用@变量,也就是 Session/会话 变量,但是要注意这个@变量 是会维持状态的,因为有连接池在保持连接(会话)。

 

即如果一用户在操作数据库中,产生了@Id = 2,这个用户关闭后,这个连接不会消失,连接中的@变量也不会消失,随后,另一用户也有可能获取到这个值。

 

另外,经过测试 在ibatis.net中,同一页面流程中,不同的操作数据库方法(哪怕是前后2个方法),也可能会有不同的连接。所以如果想用 @变量 在同一页面,不同数据库方法之间进行共享变量,是不安全的。

 

好在同一XML块,肯定是独占的,一个连接只能被一个数据库操作方法(注意是方法,不是页面)占用(测试也证明),所以在XML中这样写,是没有安全问题的。

 

<udpate>

  set @id = 0;

  select id into @id from tb_1;

  update tb_2 set name ='xx' where id = @id;

  update tb_3 set name='cc' where id = @id;

</update>

 

1.第一句  set @Id =0;这个很关键,因为完全有可能这次操作会取得上一次某个用户产生的@Id值

2.XML块中,连接是独占的,一个连接只会提供给一个数据库查询,所以 @Id在 select 和 update之间,是不会受到污染的。

 

转载于:https://www.cnblogs.com/lishenglyx/p/4278268.html

你可能感兴趣的文章
成功连上数据库顿感世界美好许多
查看>>
编程注意2
查看>>
《C++ Primer Plus》第12章 类和动态内存分配 学习笔记
查看>>
javascript中sort()排序方法总结
查看>>
实现聊天界面的代码
查看>>
自己生成一个NDK的浅析
查看>>
Excel数据导入到数据库
查看>>
jQuery最佳实践
查看>>
SELinux FAQ
查看>>
Java中synchronized同步的理解
查看>>
python 数值计算库
查看>>
java 服务重启 js 中被注释代码仍然执行
查看>>
我并不是不闻不问![C#]
查看>>
web前端经典小题
查看>>
AutoCAD如何倒角 倒圆角 倒直角
查看>>
Office PPT中如何插入flash
查看>>
C# Fade Form Effect With the AnimateWindow API Function
查看>>
golang多维数组的切片
查看>>
IP 网际协议
查看>>
C语言_第五章__实践(密码转换)
查看>>