- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对 .Net 中的 Sqlite 没有太多经验,但我看到的行为很奇怪。假设我们有一个具有以下 project.json
的 .Net 核心应用程序:
{
"version": "1.0.0-*",
"buildOptions": {
"debugType": "portable",
"emitEntryPoint": true
},
"dependencies": {
"Microsoft.Data.Sqlite": "1.0.0",
"Dapper": "1.50.2"
},
"frameworks": {
"netcoreapp1.0": {
"dependencies": {
"Microsoft.NETCore.App": {
"type": "platform",
"version": "1.0.0"
}
},
"imports": "dnxcore50"
}
}
}
我们还有一个简单的类Item
:
public class Item
{
public Item() { }
public Item(int id, string name, decimal price)
{
this.Id = id;
this.Name = name;
this.Price = price;
}
public int Id { get; set; }
public string Name { get; set; }
public decimal Price { get; set; }
}
然后我创建一个内存数据库并用数据填充它(使用 Dapper):
var connection = new SqliteConnection("Data Source=:memory:");
connection.Open();
connection.Execute("CREATE TABLE IF NOT EXISTS Items(Id INT, Name NVARCHAR(50), Price DECIMAL)");
var items = new List<Item>
{
new Item(1, "Apple", 3m),
new Item(2, "Banana", 1.4m)
};
connection.Execute("INSERT INTO Items(Id, Name, Price) VALUES (@Id, @Name, @Price)", items);
然后我尝试从 Items
表中读取:
var dbItems = connection.Query<Item>("SELECT Id, Name, Price FROM Items").ToList();
当我运行解决方案时,出现以下异常:
Unhandled Exception: System.InvalidOperationException: Error parsing column 2 (Price=1.4 - Double) ---> System.Invali dCastException: Unable to cast object of type 'System.Double' to type 'System.Int64'.
好的,那我尝试使用Microsoft.Data.Sqlite
来获取数据:
var command = connection.CreateCommand();
command.CommandText = "SELECT Price FROM Items";
var reader = command.ExecuteReader();
while (reader.Read())
{
Console.WriteLine(reader[0].GetType());
}
结果我得到:
System.Int64 // Price = 3
System.Double // Price = 1.4
我尝试在真实数据库上使用十进制价格运行查询,返回的数据类型是正确的并且始终是十进制(如预期的那样)。
应该往哪个方向深挖?我的内存数据库有问题吗?如何使其与小数保持一致?
最佳答案
在 SQLite 中,如果您创建一个具有数字/小数列数据类型的表,它与数字类型亲和性相关联,并且它的默认行为是在值没有小数时存储整数,或者如果值包含小数,则存储实数。这有助于节省字节存储,因为最常用的整数值(对于中小型应用程序小于一百万的值)需要比实际数据类型更少的字节:
整数(大约):
针对 8 字节真实 IEEE 数据类型
如果您需要始终存储实数,则有必要声明一个 float /实数数据类型,以便被视为实数类型关联,因此即使您向 SQLite 发送整数,它也会被存储为实数
来源:https://sqlite.org/datatype3.html
我知道 real 可能不精确,但我已经使用 C# Decimal 数据类型和 SQLite 以 wal 模式在磁盘中的数据库进行了一些测试,如果所有操作都是在 C# 中进行的,我从来没有遇到过舍入错误。但是当我直接在 SQLite 中进行一些计算时,由于 2 个整数除法,我得到了一些舍入错误和一些错误的计算
我使用 EF6 和 Dapper 读取/写入数值(来自 SQLite 的整数/实数)并且从未出现错误。
现在,我计划利用 SQLite 数字行为来使用小巧的 TypeHandler 节省磁盘空间,因此我可以复制 SQL Server Money
实现(在内部,SQL Server 保存一个 8 字节整数和当它加载到内存中时除以 10000):
public class NumericTypeHandler : SqlMapper.TypeHandler<decimal>
{
public override void SetValue(IDbDataParameter parameter, decimal value)
{
parameter.Value = (long)(value / 10000);
}
public override decimal Parse(object value)
{
return ((decimal)value)/10000M;
}
}
此外,我设置了 datetime UnixEpoch 实现以节省磁盘空间并提高性能
注意:
SQLite 可以在低需求的 asp.net 应用程序中处理数十个用户,诀窍是使用 pragmas 指令和其他东西调整 SQLite:
我还在 C# 方面做了一些改进:
避免保存不必要的数据(错误日志、电子邮件 html 文本)
如果您打算使用 SQLite 作为后端,我认为您应该使用像 EFx 或 Dapper 这样的 ORM。使用 dapper,您需要创建自己的微框架以节省开发时间(基本的 CRUD 功能和 Linq 查询转换)。
我找到的最好的工具是 https://github.com/linq2db/linq2db ,您使用 linq 以非常快的速度和 linq 的易用性访问数据库。并且可以制作 CRUD 功能。
如果这个答案有帮助我会很高兴
问候
关于c# - Decimal 类型从 In-memory Sqlite 数据库中读取为 double 或 int,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40075599/
在 ARM 中,内存类型指定为: 正常 设备 强烈有序 在Device type里面,好像这个类型也可以区分 不可共享的设备内存 可共享设备内存 不可共享和可共享设备内存有什么区别?我们如何分别使用这
在 ARM 中,内存类型指定为: 正常 设备 强烈有序 在Device type里面,好像这个类型也可以区分 不可共享的设备内存 可共享设备内存 不可共享和可共享设备内存有什么区别?我们如何分别使用这
This diagram很清楚不同YARN和Spark内存相关设置之间的关系,除了spark.python.worker.memory。 spark.python.worker.memory 如何适应
我正在尝试使用复杂的if-else决策树来实现GLSL片段着色器。不幸的是,着色器编译器很早就失败,并出现“语法错误-内存耗尽”错误。 GLSL中的代码大小或决策树深度是否有任何限制?有什么建议如何克
什么是“标记内存”,它如何帮助减小程序大小? 最佳答案 您可能指的是 tagged union ,或更具体地说是硬件实现,如 LISP 机器中使用的标记架构。基本上是一种存储具有类型信息的数据的方法。
我的内存有问题。我不明白为什么当我的程序长时间运行时 Go 使用越来越多的内存(从不释放它)。 第一次分配后,程序使用了将近 9 MB 的内存。然后在 12 小时后,它开始以指数方式使用更多内存,直到
在 Windows 机器上,MATLAB 用户可以使用 memory或 feature memstats命令。但是,这些都不能在机器上工作,失败如下: >> memory??? Error using
引导 Linux 内核时,可以在 RAM 中加载 initramfs 存档和 DTB 文件,并将这些物理地址指定给内核。例如,使用 U-Boot,您可以执行以下操作: bootz 0x80008000
我正在学习虚拟内存的概念,但是这个问题让我困惑了一段时间。由于大多数现代计算机都使用虚拟内存,因此当程序正在执行时,操作系统应该在 RAM 和磁盘之间将数据分页进出。但为什么我们仍然遇到“内存不足”的
我在 Colab Pro+(使用高 RAM 选项)上运行神经网络时发现了这个问题。 运行时错误:CUDA 内存不足。尝试分配 8.00 GiB(GPU 0;15.90 GiB 总容量;12.04 Gi
当我在任何地方阅读基于操作系统的书籍时,考虑到时间限制和开销很高,从内存和 I\O(子系统)获取数据是昂贵的,这就是为什么在某些硬件制造商中提供一些其他方式来访问它们,如ARM7 some ISAs像
据我所知,ADS v.10 尝试将查询结果保留在内存中,直到它变得非常大。对于 __output 表和临时表也应该如此。当结果变大时,交换声明。 问题是为查询、 worker 等设置了什么内存限制?可
序言 我正在写一个小演示文稿来列出使用 Docker 时的一些“陷阱”,我也遇到了自己的一个问题。 在解释让 Docker 在没有内存限制的情况下运行的危险时,我发现它的行为不像我预期的那样。 我使用
我们有一个 ASP.NET 项目(40 个左右的 Web 表单、50 个表、相当标准的 IO 内容,并尽可能减少),很快需要部署。系统上大约有 100 个并发用户,但任何时候只有大约 20 个用户在使
我在 dotcloud 上使用 redis 内存存储,但尽管 key 已过期,但它的 used_memory 再也不会下降。从 redis-cli 使用 flushdb 或 flushall 不会导致
我使用的是 Xcode 10.2.1 和 macOS Catalina Developer Beta 2。每当我尝试使用内存图调试器时,我都会收到此错误: Memory Graph Debugger:
所以我一直在寻找这个问题的解决方案有一段时间了。我编写了一个程序来从两个单独的文本文件中获取数据,对其进行解析,然后输出到另一个文本文件和一个 ARFF 文件以供 Weka 分析。我遇到的问题是我编写
对不起,我对 erlang 文档中的以下描述不太清楚: erlang:memory() -> [{Type, Size}] with Type: "total" means: "The total a
在查看示例合约时,有时会在带有“内存”的方法中声明数组,有时则不会。有什么区别? 最佳答案 如果没有内存关键字,Solidity会尝试在存储中声明变量。 首席 Solidity 开发者 chriset
我不明白Matlab并行计算工具箱中的parfor cicle是如何与内存一起工作的:我读到它在所有worker之间共享内存(然后我认为每个worker(核心)都可以访问感兴趣的内存位置而无需制作本地
我是一名优秀的程序员,十分优秀!