距离上次写Gc.Db框架已经有一段时间了,最近默默对框架代码已经做了不少优化和功能,且已经提交至nuget,大家如果想使用此框架,可以通过nuget搜索:Gc.Db进行下载和安装包。

本篇文章主要是介绍现目前为止,Gc.Db框架功能特性和演示代码,后期会完善此框架帮助文档,同时将也会将代码在git上进行开源,请大家多多指教。

Gc.Db是一套基于ADO.Net数据库快速开发框架和轻量级半ORM框架。特点如下:

1.支持数据库有MSSql、MySql、Oracle、Access。

2.对各数据库操作完全是基于接口设计,能够与各种IOC框架很好集成,便于程序解耦。

3.对单表提供了ORM功能,同时又封装ado.net常用SQL语句、参数化SQL语句、存储过程方法,为MSSql、MySql单表提供了分页功能,提供了开发效率。

4.支持单库事务操作。

Gc.Db配置相关简单,只需在主键、是否需要获取自动增长、是否获取自动增长值,目前对SqlSver和MySQL支持配置自动增长和获取自动增长值特性。Gc.Db配置和示例代码如下。

(1)  创建实体类,添加字段,配置主键,配置自动增长和获取自动增长值采用是的是缺省配置,默认是false.

using Gc.Db;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace TestGcDb
{
   public class UserInfo
    {
        [Column("UserId", true)]
       public int UserId { get; set; }

       public string UserName { get; set; }

       public int Age { get; set; }

       public DateTime CreateTime { get; set; }
    }
}

(2)创建一个对数据库操作示例类,添加了些对数据访问常用方法。

using Gc.Db;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Gc.Db;
using System.Data;

namespace TestGcDb
{
   public class UserInfoDao
    {
        //因为此演示代码是用的sqlserver,如果是mysql:MySqlDb,oracle:OracleSqlDb,同时各数据连接串
        private ISqlDb msDb = new MsSqlDb();

        //数据库连接,请根据各自数据库进行配置数据库连接串
        private string msDbConnStr = "Data Source=.;Initial Catalog=testdb;User ID=sa;Password=123456;";

        /// <summary>
        /// 添加数据
        /// </summary>
       public void Add()
        {
            UserInfo model = new UserInfo()
            {
                UserId = ,
                UserName = "abc",
                Age = ,
                CreateTime = DateTime.Now
            };
            msDb.Insert<UserInfo>(msDbConnStr, model);
        }

        /// <summary>
       /// 根据主键删除数据
        /// </summary>
       public void Delete()
        {
            ;
            msDb.Delete<UserInfo>(msDbConnStr, uid);
        }

        /// <summary>
       /// 修改数据
        /// </summary>
       public void Update()
        {
            UserInfo model = GetModel();
            if (model != null)
            {
                model.CreateTime = DateTime.Now;
                msDb.Update<UserInfo>(msDbConnStr, model);
            }
        }

        /// <summary>
       /// 获取单条数据
        /// </summary>
        /// <returns></returns>
       public UserInfo GetModel()
        {
            ;
            UserInfo model = msDb.Find<UserInfo>(msDbConnStr, uid);
            return model;
        }

       /// <summary>
       /// 查询object to in
       /// </summary>
       /// <param name="uid"></param>
       public int  GetObject()
       {
           ;
           string sqlStr="select count(*) from UserInfo";
           object data = msDb.ExecuteScalar(msDbConnStr, sqlStr);
           if (data != null)
           {
               num = Convert.ToInt32(data);
           }
           return num;
       }

        /// <summary>
        /// 数据查询
        /// </summary>
       public void GetList()
        {
            //查询列表
            List<UserInfo> list1 = msDb.Where<UserInfo>(msDbConnStr);
            List<UserInfo> list2 = msDb.Where<UserInfo>(msDbConnStr, "UserId>0");
            List<UserInfo> list3 = msDb.Where<UserInfo>(msDbConnStr, "", null, "CreateTime desc");
            List<UserInfo> list4 = msDb.Where<UserInfo>(msDbConnStr,  }, "CreateTime desc");

            //查询分页列表
            PageDataResult<List<UserInfo>> result = msDb.GetPageList<UserInfo>(msDbConnStr, , );
            List<UserInfo> list6 = result.Data;
            int toatl = result.TotalCount;
        }

       /// <summary>
       /// 事务用法
       /// </summary>
       /// <param name="uid"></param>
       public void TransOperator1()
       {
           msDb.BeginTransaction();
           ; i <= ; i++)
           {
               UserInfo model = new UserInfo()
               {
                   UserId = i,
                   UserName = "abc" + i.ToString(),
                   Age = ,
                   CreateTime = DateTime.Now
               };
               msDb.Insert<UserInfo>(msDbConnStr, model);
           }
           msDb.CloseTransaction();
       }

       /// <summary>
       /// 事务用法2
       /// </summary>
       /// <param name="uid"></param>
       public void TransOperator2()
       {
           msDb.BeginTransaction();
           msDb.Delete<UserInfo>(msDbConnStr, );
           msDb.ExecuteWithParam(msDbConnStr, "delete from UserInfo where Userid=2", null);
           msDb.ExecuteWithParam(msDbConnStr,  });
           msDb.CloseTransaction();
       }
    }
}

Demo点击下载

Gc.Db之循序渐进的更多相关文章

  1. 玩转Redis之Window安装使用(干货)

    距离上次定Gc.Db框架,好久没有更新博客了,今日没什么事,就打算就Redis写点东西. Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理.它支持字符 ...

  2. EcShop开发手册

    Ecshop文件结构 ecshop文件架构说明 ECShop 结构图及各文件相应功能介绍 ECShop upload 的目录 ┣ activity.php 活动列表 ┣ affiche.php 广告处 ...

  3. session放入缓存(redis)、DB

    为什么要把SESSION保存在缓存 就php来说,语言本身支持的session是以文件的方式保存到磁盘文件中,保存在指定的文件夹中,保存的路径可以在配置文件中设置或者在程序中使用函数session_s ...

  4. 循序渐进开发WinForm项目(4)--Winform界面模块的集成使用

    随笔背景:在很多时候,很多入门不久的朋友都会问我:我是从其他语言转到C#开发的,有没有一些基础性的资料给我们学习学习呢,你的框架感觉一下太大了,希望有个循序渐进的教程或者视频来学习就好了. 其实也许我 ...

  5. GC学习笔记

    GC学习笔记 这是我公司同事的GC学习笔记,写得蛮详细的,由浅入深,循序渐进,让人一看就懂,特转到这里. 一.GC特性以及各种GC的选择 1.垃圾回收器的特性 2.对垃圾回收器的选择 2.1 连续 V ...

  6. 非常详细GC学习笔记

    转载:http://blog.csdn.net/fenglibing/article/details/6321453 这是我公司同事的GC学习笔记,写得蛮详细的,由浅入深,循序渐进,让人一看就懂,特转 ...

  7. db file sequential read (数据文件顺序读取)

    转载:http://www.dbtan.com/2010/04/db-file-sequential-read.html db file sequential read (数据文件顺序读取): db ...

  8. Java GC 专家系列3:GC调优实践

    本篇是”GC专家系列“的第三篇.在第一篇理解Java垃圾回收中我们学习了几种不同的GC算法的处理过程,GC的工作方式,新生代与老年代的区别.所以,你应该已经了解了JDK 7中的5种GC类型,以及每种G ...

  9. 全表扫描引发的db file sequential read

    今天我要做一个SQL调优,监控该SQL, 利用ASH 监控 该SQL是在sid=4848 上面跑的 db file sequential read等待事件有3个参数:file#,first block ...

随机推荐

  1. 《连载 | 物联网框架ServerSuperIO教程》-4.如开发一套设备驱动,同时支持串口和网络通讯。附:将来支持Windows 10 IOT

    1.C#跨平台物联网通讯框架ServerSuperIO(SSIO)介绍 <连载 | 物联网框架ServerSuperIO教程>1.4种通讯模式机制. <连载 | 物联网框架Serve ...

  2. Consul的一个更新:服务端节点故障后重连

    研究了一段时间Consul,想写个攻略来着,但太赖了而且表达能力非正常人...今天发现HashiCorp果然接纳大众意见改了点东西.. 场景是: 假如Consul集群内有三个Server Node 时 ...

  3. mysql常处理用时间sql语句

    Mysql日期函数,时间函数使用的总结,以及时间加减运算(转) select timediff('23:40:00', ' 18:30:00'); -- 两时间相减SELECT substring( ...

  4. JavaScript基本数据类型和引用数据类型

    ECMAScript包含两种不同数据类型的值:基本类型值和引用类型值.基本类型值指的是简单的数据段,而引用类型值那些可能有多个值构成的对象. 在进行变量赋值时,解析器必须确定这个值是基本类型值还是引用 ...

  5. iOS 下拉刷新-上拉加载原理

    前言 讲下拉刷新及上拉加载之前先给大家解释UIScrollView的几个属性 contentSize是UIScrollView可以滚动的区域. contentOfinset 苹果官方文档的解释是&qu ...

  6. Laravel大型项目系列教程(四)显示文章列表和用户修改文章

    小编心语:不知不觉已经第四部分了,非常感谢很多人给小编提的意见,改了很多bug,希望以后能继续帮小编找找茬~小编也不希望误导大家~这一节,主要讲的 是如何显示文章列表和让用户修改文章,小编预告一下(一 ...

  7. Perforce 与Source Insight, Visual Studio集成

    转自:http://shashanzhao.com/archives/837.html 1.Perforce 首先需要为perforce设置系统环境变量,以便perforce命令行可以正常使用. 环境 ...

  8. java中的浮点数

    浮点数值不适用于禁止出现舍入误差的金融计算中.例如,命令System.out.println(2.0-1.1)将打印出0.8999999999999999999999999,而不是人们想象的0.9.其 ...

  9. 如何实现可动态调整隐藏header的listview

    (转自:http://blog.sina.com.cn/s/blog_70b9730f01014sgm.html) 需求:根据某种需要,可能需要动态调整listview的页眉页脚,譬如将header作 ...

  10. python3.5批量修改文件名

    考虑到要手工修改许多的文件名太费时,而且网上下载的图片大多如下(完全不能满足强迫症) 就用python来代替我们完成这个过程直接贴上代码 #encoding:utf-8 import os def r ...