一个通用数据库操作组件DBUtil(c)、支持SqlServer、Oracle、Mysql、postgres、SQLITE

发布:admin08-27分类: 网站源码

  注意:它并不是一个orm工具(常见的orm框架如:EF、Dapper等)。

  2. 添加依赖方法1:打开工具NuGet包管理器程序包管理器控制台,输入:

  3. 添加依赖方法2:使用可视化的nuget管理窗口搜索“DBUtil”,选择安装即可!

  在所有的数据库操作之前,都必须先创建IDbAccess对象,创建的方法如下:

  sqlite数据库存储是单个文件存储的,所以在访问之前你需要先创建它,参照如下代码:

  在这个组件中设计为:根据指定的查询语句和分页参数生成分页的查询语句,参照以下代码:

  默认情况下,每进行一次数据库的操作都会打开和关闭数据库。在密集的操作下这种方法并不推荐。

  数据库表的ID的生成是一个常见的问题,常见的有表字段设置为自增、设为序列、程序控制ID生成。下面分别说说这三种模式:

  1) 表字段自增:在sqlserver中有个致命的缺陷就是一旦遇到数据迁移,那么这些ID都将重新生成,如果其他的表引用了这个 ID,后果可想而知。在mysql中有办法解决这个问题,但是这种办法最根本的缺陷在于:“不能在数据插入到表之前获取对应的ID”,试想一下:如果你在插入数据之前还要用到这个ID做其他的工作该怎么办?

  2) 序列法:在oracle中可以新建一个序列控制ID的生成(sqlserver中好像也开始支持了),这种方法其实已经解决了绝大部分问题了,但是在每次生成ID之前你还是需要访问一遍数据库,如果需要批量生成的时候性能肯定受影响(不知道序列支不支持批量生成)。

  3) 程序控制ID生成法:这个组件是用的这种方法生成ID的,它可以解决上述提到的问题。它的原理是:

  你在程序中通过指定表名和字段名来获取ID,程序中进行判断当前内存中是否缓存了这个ID,如果缓存了ID的话就直接自增并返回,如果没有缓存ID的话就通过表名和字段名去数据库里面去查找最大的ID,然后自增并返回。

  1. 因为ID的生成缓存到了程序中,所以针对一张表必须保证只有一个服务器会进行ID的生成,否则会出现重复的ID

  有人可能已经注意到问题,分布式的ID是怎么生成(1个数据库,多个服务器)?这里我提供一个思路,但是这个组件中并没有实现:针对不同的服务器预先设置ID的前缀,比如服务器A的ID 生成从1开始,服务器B的ID 生成从100 0000开始,这样就不会重叠了。如果担心数据量太大,那么你就不能在用int类型的ID了,你应该使用字符串唯一编号。这个组件中也实现了唯一编号的生成控制,原理和ID一样的都是在程序中缓存,只不过使用的时候要配置编号生成的规则...

温馨提示如有转载或引用以上内容之必要,敬请将本文链接作为出处标注,谢谢合作!

欢迎使用手机扫描访问本站