Floodlight源码阅读之内存数据库

2024-05-10 18:18

本文主要是介绍Floodlight源码阅读之内存数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

内存数据库的种类有很多,基于java数据结构就可以实现一个内存数据库,Floodlight里面的网络设备和拓扑结构就保存在写内存数据库中首先看

内存表MemoryTable


这个类主要的代码是

    private String tableName;private Map<Object,Map<String,Object>> rowMap;private int nextId;MemoryTable(String tableName) {this.tableName = tableName;rowMap = new TreeMap<Object,Map<String,Object>>();nextId = 0;}
通过Map<Object,Map<String,Object>>这个TreeMap保存行信息,nextid相当于自增主键。
插入删除行也非常简单

    void insertRow(Object key, Map<String,Object> rowValues) {assert(key != null);rowMap.put(key, rowValues);}void deleteRow(Object rowKey) {rowMap.remove(rowKey);}
ok看完了基本数据库model要看这个数据库怎么用了。

MemoryStorageSource这个类使用刚才定义的table,首先看insert方法

    @Overrideprotected void insertRows(String tableName, List<Map<String,Object>> insertRowList) {MemoryTable table = getTable(tableName, false);String primaryKeyName = getTablePrimaryKeyName(tableName);synchronized (table) {for (Map<String,Object> row : insertRowList) {Object primaryKey = row.get(primaryKeyName);if (primaryKey == null) {if (primaryKeyName.equals(DEFAULT_PRIMARY_KEY_NAME)) {row = new HashMap<String,Object>(row);primaryKey = table.getNextId();row.put(primaryKeyName, primaryKey);}}table.insertRow(primaryKey, row);}}}

这个方法指定table的名称和行的list集合。通过for循环插入行,每行都是一个map,如果主键id是空的话就自增,如果不是空就直接插入即可。

有插入的方法自然就有对应删除方法

  @Overrideprotected void deleteRowsImpl(String tableName, Set<Object> rowKeys) {MemoryTable table = getTable(tableName, false);synchronized (table) {for (Object rowKey : rowKeys) {table.deleteRow(rowKey);}}}

查询获取一行的方法

    @Overrideprotected Map<String,Object> getRow(String tableName, String[] columnNameList, Object rowKey) {MemoryTable table = getTable(tableName, false);return table.getRow(rowKey);}

这样一个简单的内存数据就完成了







这篇关于Floodlight源码阅读之内存数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/977191

相关文章

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Win11安装PostgreSQL数据库的两种方式详细步骤

《Win11安装PostgreSQL数据库的两种方式详细步骤》PostgreSQL是备受业界青睐的关系型数据库,尤其是在地理空间和移动领域,:本文主要介绍Win11安装PostgreSQL数据库的... 目录一、exe文件安装 (推荐)下载安装包1. 选择操作系统2. 跳转到EDB(PostgreSQL 的

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们

Spring Boot 整合 MyBatis 连接数据库及常见问题

《SpringBoot整合MyBatis连接数据库及常见问题》MyBatis是一个优秀的持久层框架,支持定制化SQL、存储过程以及高级映射,下面详细介绍如何在SpringBoot项目中整合My... 目录一、基本配置1. 添加依赖2. 配置数据库连接二、项目结构三、核心组件实现(示例)1. 实体类2. Ma

查看Oracle数据库中UNDO表空间的使用情况(最新推荐)

《查看Oracle数据库中UNDO表空间的使用情况(最新推荐)》Oracle数据库中查看UNDO表空间使用情况的4种方法:DBA_TABLESPACES和DBA_DATA_FILES提供基本信息,V$... 目录1. 通过 DBjavascriptA_TABLESPACES 和 DBA_DATA_FILES