mirror of
https://github.com/didi/KnowStreaming.git
synced 2025-12-24 11:52:08 +08:00
连接信息写DB优化为批量写入
This commit is contained in:
@@ -13,8 +13,6 @@ import java.util.List;
|
||||
public interface TopicConnectionDao {
|
||||
int batchReplace(List<TopicConnectionDO> doList);
|
||||
|
||||
int replace(TopicConnectionDO topicConnectionDO);
|
||||
|
||||
List<TopicConnectionDO> getByTopicName(Long clusterId, String topicName, Date startTime, Date endTime);
|
||||
|
||||
List<TopicConnectionDO> getByAppId(String appId, Date startTime, Date endTime);
|
||||
|
||||
@@ -27,29 +27,12 @@ public class TopicConnectionDaoImpl implements TopicConnectionDao {
|
||||
|
||||
@Override
|
||||
public int batchReplace(List<TopicConnectionDO> doList) {
|
||||
int count = 0;
|
||||
for (TopicConnectionDO elem: doList) {
|
||||
try {
|
||||
count += sqlSession.insert("TopicConnectionDao.replace", elem);
|
||||
} catch (DeadlockLoserDataAccessException e1) {
|
||||
|
||||
} catch (Exception e) {
|
||||
LOGGER.error("add topic connection info, clusterId:{} topicName:{}."
|
||||
, elem.getClusterId(), elem.getTopicName(), e);
|
||||
}
|
||||
}
|
||||
return count;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int replace(TopicConnectionDO topicConnectionDO) {
|
||||
try {
|
||||
return sqlSession.insert("TopicConnectionDao.replace", topicConnectionDO);
|
||||
return sqlSession.insert("TopicConnectionDao.batchReplace", doList);
|
||||
} catch (DeadlockLoserDataAccessException e1) {
|
||||
return 0;
|
||||
} catch (Exception e) {
|
||||
LOGGER.error("add topic connection info, clusterId:{} topicName:{}."
|
||||
, topicConnectionDO.getClusterId(), topicConnectionDO.getTopicName(), e);
|
||||
LOGGER.error("add topic connections info failed", e);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -13,7 +13,7 @@
|
||||
<result property="createTime" column="create_time"/>
|
||||
</resultMap>
|
||||
|
||||
<insert id="replace" parameterType="com.xiaojukeji.kafka.manager.common.entity.pojo.gateway.TopicConnectionDO">
|
||||
<insert id="batchReplace" parameterType="java.util.List">
|
||||
REPLACE INTO topic_connections (
|
||||
cluster_id,
|
||||
topic_name,
|
||||
@@ -22,16 +22,19 @@
|
||||
ip,
|
||||
client_version,
|
||||
create_time
|
||||
)
|
||||
VALUES (
|
||||
#{clusterId},
|
||||
#{topicName},
|
||||
#{type},
|
||||
#{appId},
|
||||
#{ip},
|
||||
#{clientVersion},
|
||||
#{createTime}
|
||||
)
|
||||
)
|
||||
VALUES
|
||||
<foreach collection="list" item="item" index="index" separator=",">
|
||||
(
|
||||
#{item.clusterId},
|
||||
#{item.topicName},
|
||||
#{item.type},
|
||||
#{item.appId},
|
||||
#{item.ip},
|
||||
#{item.clientVersion},
|
||||
#{item.createTime}
|
||||
)
|
||||
</foreach>
|
||||
</insert>
|
||||
|
||||
<select id="getByTopicName" parameterType="java.util.Map" resultMap="TopicConnectionMap">
|
||||
|
||||
Reference in New Issue
Block a user