java和c#比较(一)jdbc VS ado.net取100万条记录到内存

java代码:

java 复制代码
 String databaseUrl = "jdbc:sqlite:" + selectedFile.getPath();
        ObservableList<ObservableList<Object>> masterData = FXCollections.observableArrayList();

        try (Connection connection = DriverManager.getConnection(databaseUrl)) {
            Statement statement = connection.createStatement();
            ResultSet resultSet = statement.executeQuery("SELECT * FROM H_113_Sheet1");
            ResultSetMetaData metaData = resultSet.getMetaData();
            int columnCount = metaData.getColumnCount(); // 获取列的数量

            while (resultSet.next()) {
                ObservableList<Object> row = FXCollections.observableArrayList();
                for (int i = 1; i <= columnCount; i++) {
                    row.add(resultSet.getObject(i));
                }
                masterData.add(row);
            }

        } catch (SQLException e) {
            e.printStackTrace();
        }

c#代码:

cs 复制代码
 string databaseUrl = "Data Source=" + selectedFilePath; 
        List<List<object>> masterData = new List<List<object>>();

        using (SQLiteConnection connection = new SQLiteConnection(databaseUrl))
        {
            connection.Open();
            using (SQLiteCommand command = new SQLiteCommand("SELECT * FROM H_113_Sheet1", connection))
            {
                using (SQLiteDataReader reader = command.ExecuteReader())
                {
                    DataTable schemaTable = reader.GetSchemaTable();
                    int columnCount = schemaTable.Columns.Count;

                    while (reader.Read())
                    {
                        List<object> row = new List<object>();
                        for (int i = 0; i < columnCount; i++)
                        {
                            row.Add(reader.GetValue(i));
                        }
                        masterData.Add(row);
                    }
                }
            }
        }

        catch (SQLiteException e)
        {
            Console.WriteLine(e.ToString());
        }

结论:同样的一个sqlite数据库表,同样一台电脑,单机测试数据读取到内存。

java jdbc ,c# ado.net

java jdbc:用时26秒,内存占用2.58G。

c# ado.net:用时34秒,内存占用1.68。

就是说取数这项,java内存占用是.net的1.5倍,速度比.net快30%多。

相关推荐
我滴老baby1 分钟前
企业级工具链设计从单一工具到分层工具体系的架构实践
java·开发语言·架构
月昤昽2 分钟前
C#实现AutoCAD旋转与直径标注
c#·.net·二次开发·autocad·autocad二次开发
Hello.Reader3 分钟前
算法基础(三)—— 插入排序从整理扑克牌到有序数组
java·算法·排序算法
罗超驿4 分钟前
3.快乐数专题学习笔记——双指针法在LeetCode 202题中的应用
java·算法·leetcode·职场和发展
liann1197 分钟前
Agent 内存马禁止 Attach JVM
java·jvm·安全·网络安全·系统安全·网络攻击模型·信息与通信
小雅痞12 分钟前
[Java][Leetcode middle] 36. 有效的数独
java·算法·leetcode
代码漫谈13 分钟前
JVM 参数调优:Spring Boot与JDK新特性的最佳结合
java·jvm·spring boot
卷毛的技术笔记17 分钟前
双十一零点扛过10倍流量洪峰:Sentinel与Redis+Lua的分布式限流深度避坑指南
java·redis·分布式·后端·系统架构·sentinel·lua
逻辑驱动的ken17 分钟前
Java高频面试考点场景题27
java·开发语言·面试·职场和发展·求职招聘
专注VB编程开发20年30 分钟前
专业分析python底层调用与按键精灵,ah3等的对比,hookdll,内存加载,调用.net dll
开发语言·javascript·python·microsoft·php·.net