List<类名> selectListResult(@Param(“参数”) List<类名> 参数);
<
select id
=
"方法名"
resultMap
=
"返回数据匹配类"
>
select
*
from table_name where
1
=
1
<
!
--
使用
1
=
1
防止list为
null
时sql语句报错
--
>
<
!
--
判断
--
>
<
if
test
=
"list!= null"
>
and id
in
<
!
--
for
循环
,
item
:
循环后的值
,
index
:
循环下标列式
for
循环的 i
,
collection
:
参数名
--
>
<
!
--
open
=
"("
close
=
")"
separator
=
","
就是把循环的值组成
(
item1
,
item2
,
item3
)
的格式
--
>
<
foreach item
=
"item"
index
=
"index"
collection
=
"list"
open
=
"("
close
=
")"
separator
=
","
>
#
{
item
}
<
/
foreach
>
<
/
select
>
<foreach collection="yourListName" item="item" index="index" open="(" close=")" separator=",">
#{item}
</foreach>
collection:要做foreach的对象,作为入参时,List<?>对象默认用list代替作为键,数组对象有array代替作为键,Map对象用map代替作为键,该参数必选;
item:循环体中的具体对象,支持属性的点路径访问,该参数必选;
index:在list和数组中,index是元素的序号,在map中,index是元素的key,该参数可选;
open:foreach代码的开始符号,一般是(和close=")"合用,该参数可选;
close:foreach代码的关闭符号,一般是)和open="("合用,该参数可选;
separator:元素之间的分隔符,例如在in()的时候,separator=","会自动在元素中间用“,“隔开,避免手动输入逗号导致sql错误,该参数可选;
mapper中对order by 进行排序?????????????????
在做mybatis的mapper.xml文件的时候,我们时常用到这样的情况:动态生成sql语句的查询条件,这个时候我们就可以用mybatis的foreach了
foreach元素的属性主要有item,index,collection,open,separator,close。
item:集合中元素迭代时的别名,该参数为必选,意思是每次遍历时的别名,这里是什么参数名,下面引用也是引用这个参数名。
index:在list和数组中,index是元素的序号,在map中,index是元素的key,该参数可选
foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合。
foreach元素的属性主要有 item,index,collection,open,separator,close。
item :表示集合中每一个元素进行迭代时的别名
index :指定一个名字,用于表示在迭代过程中,每次迭代到的位置
open :表...
Author:kak
MySql的动态语句foreach,当传入参数为数组或者集合时需要通过foreach标签进行遍历,其主要是在in条件中,可以在SQL语句中迭代一个集合;
<foreach collection="dto.orderStatusList" item="item" index="index" open="("
1、试题表和选项表,对于单选多选等会在选项表里存选项内容
2、选项表里的选项内容字段是以json格式存放的,但由于json检索和插入太慢存的是longtext格式的json格式。
三、sql语句
1、返回题干id(这步sql很简单的,略了)
2、这些id下的选项是否...
Log Explorer主要用于对MSSQLServer的事物分析和数据恢复。你可以浏览日志、导出数据、恢复被修改或者删除的数据(包括执行过update,delete,drop和truncate语句的表格)。一旦由于系统故障或者人为因素导致数据丢失,它能够提供在线快速的数据恢复,最大程度上保证恢复期间的其他事物不间断执行。
他可以支持SQLServer7.0和SQLServer2000,提取标准数据库的日志文件或者备份文件中的信息。
其中提供两个强大的工具:日志分析浏览,对象恢复。具体功能如下:
l 日志文件浏览
l 数据库变更审查
l 计划和授权变更审查
l 将日志记录导出到文件或者数据库表
l 实时监控数据库事物
l 计算并统计负荷
l 通过有选择性的取消或者重做事物来恢复数据
l 恢复被截断或者删除表中的数据
l 运行SQL脚本
LogExplore包含两部分
l 客户端软件
l 服务器代理
服务器端代理是保存在SQLServer主机中的一个只读存储过程,他的作用是接受客户端请求,读取在线事物日志块并通过网络传给客户端软件,由客户端软件来读取这些原始的数据块来完成Log Explore所提供的所有功能。
他依赖来的网络协议包括:
l Named Pipe:局域网中适用
l Tcp/Ip:广域网中适用
数据库相关介绍
事物日志(Transaction Log)
SQLServer的每个数据库都包含事物日志,它以文件的形式存储,可以记录数据库的任何变化。发生故障时SQLServer就是通过它来保证数据的完整性。
操作(Operation)
操作是数据库中定义的"原子行为",每个操作都在日志文件中保存为一条记录。它可以是用户直接输入的SQL语句,比如标准的insert命令,日志文件中便会记录一条操作代码来标志这个insert操作。
事物(Transaction)
事物是一系列操作组成的序列。他可以理解为直观的不可分割的一笔业务,可以执行成功或者失败。典型的事物比如由应用程序发出的具有开启-提交功能的一组SQL语句。不同的事物靠事物Id号(transaction ID)来区分,具有相同ID的事物记录的日志也相同。
在线事物日志(Online Transaction Log)
在线事物日志是指当前活动数据库所用的日志。可以通过如下命令来确定其对应文件
Select * from SYSFILES
他的文件后缀名一般是.LDF
离线事物日志(Offline Transaction Log)
离线事物日志是指非活动数据库所用的日志。当其数据库处于关闭(ShutDown)才状态下可以进行复制备份操作。他的结果同在线事物日志完全相同。
备份文件
备份文件是保存食物日志备份的文件,通常管理员通过运行SQL语句或者企业管理器来生成该文件。备份文件的内部结构和事物日志不同,他采用称为MTF的格式来保存数据。一个备份文件可以包含一个日志的多组备份,甚至包括多个数据库的混合备份.
设置为自动收缩
企业管理器--服务器--右键数据库--属性--选项--选择"自动收缩"
强烈要求该项不要选中.否则SQLServer将已循环的方式来覆盖先前的日志记录,将会导致LogExplore无法恢复错误.
数据恢复介绍
LogExplore允许你恢复应为误操作或者程序错误而导致的数据丢失或者更改.比如执行update/Delete语句时丢失了where子句,或者错误使用了Dts功能.
LogExplore不支持直接修改数据库.他可以生成事物的逆操作脚本.
如果log是delete table where ...的话,生成的文件代码就是insert table ....
你可以通过SQL查询分析器,或者LogExplore的Run SQL Script功能来执行生成脚本.
关于Undo
Undo功能可以逆操作一组指定的用户事物。包括insert,delete和update,其局限性如下:
l 事物类别:LogExplore只能undo用户事物。用户事物是指在用户表上定义的事物,不支持系统表的更新恢复。同时,他也不支持计划变更的回滚。
l Blob类型:包括text,ntext,image类型。LogExplore只支持这些类型的insert和delete恢复,不支持update语句恢复。
关于redo
Redo功能可以再次运行一组指定事物。它可以在以下情况中用到:
丢失数据库而且没有任何备份文件。
l 如果原始日志文件没有丢失可以通过Redo来实现恢复。
l 通过完整备份文件来把数据库恢复到某指定时间点,再通过redo功能完整恢复。它可以重放Create Table和Create Index命令,来重新生成被删掉的表,同时也受blob字段的限制。
拯救Dropped/Truncate命令导致的数据丢失
执行Drop Table和Truncate Table命令虽然会被SQLServer记录到日志文件中,但是并不记录被删除的数据。你可以使用LogExplore提供的功能来恢复这些数据。LogExplore提供两种机制来恢复被Drop或者Truncate的数据。
1、如果你有备份文件可以直接通过备份文件恢复。
2、通过LogExplore提供的方法来恢复。
当执行如上命令时,SQLServer会将保存数据的页面放入空闲页面列表中。如果此页没有被再次使用则将一直保存原始数据。恢复时,LogExplore将从空闲页面列表中搜寻没有被再次使用的页面,然后生成一个SQL脚本来从这些页面重组原始数据。LogExplore可以确定被删掉的原始数据行,并在完成时显示原始行数和实际恢复的行数,由此可以断定是否全部恢复。
SQL逆操作
1、Insert--Delete
2、Delete--Insert
3、Update
1、 View Log功能:
列表如图,可以用TransID来区分事物并用不同颜色标识。工具栏的按钮是一些基本查询操作。鼠标右键弹出菜单中有Undo Transaction和UndoOperation可以恢复黑色箭头选中的事物或者操作项。
Real-Time Monitor:
实时监控事物日志,通过轮询来实现。可以暂停或者停止监控,可以更改轮询周期。
相关DML语言和DDL语言可以在Row Revision History、Row Transaction History以及View DDL Commands来查询。
2、 Export Log Report
包括Export To SQL和Export To File,根据向导即可完成。
3、 其余菜单:Undo,Redo,Salvage Dropped/Truncated data,Restore 以及Run SQL Script前面已经叙述过,可以根据其向导完成。
log explorer使用的几个问题
1)对数据库做了完全 差异 和日志备份
备份时选用了删除事务日志中不活动的条目
再用Log explorer打试图看日志时
提示No log recorders found that match the filter,would you like to view unfiltered data
选择yes 就看不到刚才的记录了
3)然后恢复备份,(注意:恢复是断开log explorer与数据库的连接,或连接到其他数据上,
否则会出现数据库正在使用无法恢复)
恢复完后,再打开log explorer 提示No log recorders found that match the filter,would you like to view unfiltered data
选择yes 就看不到刚才在2中修改的日志记录,所以无法做恢复.
动态 SQL
所谓动态 SQL就是根据用户输入参数等才能确定的语句,根据用户输入参数执行不同的增删改查。
动态 SQL 是 MyBatis 的强大特性之一。如果你使用过 JDBC 或其它类似的框架,你应该能理解根据不同条件拼接 SQL 语句有多痛苦,例如拼接时要确保不能忘记添加必要的空格,还要注意去掉列表最后一个列名的逗号。利用动态 SQL,可以彻底摆脱这种痛苦。
使用动态 SQL 并非一件易事,但借助可用于任何 SQL 映射语句中的强大的动态 SQL 语言,MyBatis 显著地提升了这一特性的易用性。
INSERT INTO table_name (column1, column2, column3, ...)
VALUES
(value1, value2, value3, ...),
(value1, value2, value3, ...),
(value1, value2, value3, ...),
其中,table_name 是表的名称,column1, column2, column3 是要插入的字段名称,value1, value2, value3 是要插入的数据。
如果您使用 Mybatis 来进行 SQL 的操作,可以在 mapper.xml 中使用以下语句进行批量插入:
<insert id="batchInsert" parameterType="java.util.List">
insert into table_name (column1, column2, column3, ...)
values
<foreach collection="list" item="item" index="index" separator=",">
(#{item.value1}, #{item.value2}, #{item.value3}, ...)
</foreach>
</insert>
其中,list 是要插入的数据列表,item 是对列表中每个元素的引用,value1, value2, value3 分别是要插入的数据。
windows系统关闭指定端口Identify and stop the process that‘s listening on port XXX or configure this applica
idea如何关闭项目文件显示的浏览器图标