PetaPoco 快速上手
今天来给大家分享一个好用的轻型的.net框架的ORM——PetaPoco
本着快速上手的原则,我们通过和EF对比,让大家能快速使用PetaPoco
PetaPoco大家可能没有听说过,但大家一定听说过或者用过EF吧,其实,PetaPoco和EF是一个性质的东西,只不过PetaPoco相对于EF而言较为轻量级的。
与EF一样,我们可以再NuGet中将其引用安装进来。

安装完毕之后,我们可以就可以在解决方案中看到多个文件夹。

注:ExModels这个文件夹是我自己加上的,不是自己生成的。
在EF中,分为好几种模式,如:代码优先(Code First),数据库优先(DataBase First) 等等……在PetaPoco中只有与EF类似的数据库优先即DataBase First(可能还有其他模式,但笔者没有深入研究)。
我们来说一下PetaPoco中几个关键的文件

在Generated文件有一个Database.tt的文件,他下面还有个Database.cs的文件,这两个文件,是PetaPoco'数据库优先模式'的关键文件。本着快速上手的原则,其他文件就不做一一说明了。
下面我们来看一下如何在一个项目中来快速使用PetaPoco。
第一步:在App.config或Web.config 文件中配置数据库连接字符串。

第二步:配置Database.tt文件。
打开Database.tt文件,给大家说一下几个比较重要的配置属性,没有提到的,可以用他们给的默认值。

上面标注的就是几个在项目中需要用到的比较重要的配置属性,还有一些配置属性没有做一一的说明,小伙伴们可以自己研究一下,或者去网上查一下资料。
点击保存(Ctrl+S),则PetaPoco会自动关联相应的数据库,给我们生成每个表的表实例,表明即为实例的类名,表字段名即为实例类的属性名,是不是感觉和EF的DataBase First 很类似啊。
PetaPoco将自动生成的类实例保存到了PetaPoco.cs文件中了。我们可以在这个文件中查看。如果遇到数据库数据结构发生变化,我们可以在Database.tt中重新点击保存(Ctrl+S)一下,即可更新了。
PetaPoco配置完了,下面就可以真枪实弹的来用它进行对数据库的一系列操作了。
根据上面的Database.tt的配置,我们生成的Database.cs文件中,命名空间和类名如下:

下面我用简单的几个小例子来给大家介绍一下PetaPoco操作数据库的一些方法函数。
1、初始化
var db = new AntManManagerDB();
var db = new AntManManagerDB("AntManManager");
上述两行是常用的初始化Database的代码,还有很多初始化的重载,大家可以自己看一下。
2、Insert
//message 是PetaPoco根据数据库表生成的类实例
var db = new AntManManagerDB();
db.Insert(message);
db.Execute("Insert语句");
3、Delete
//message 是PetaPoco根据数据库表生成的类实例
var db = new AntManManagerDB();
db.Delete(message)
db.Execute("Delete语句");
4、Update
//message 是PetaPoco根据数据库表生成的类实例
var db = new AntManManagerDB();
db.Update(message)
db.Execute("Update语句");
5、Select
//单条查询
var a=db.SingleOrDefault<Message>("SELECT * FROM articles WHERE article_id=@0", );
//分页查询,返回Page类实例,其属性中,有很多你需要的值哦
var result=db.Page<Message>(, , // <-- 第几页,每页几条
"SELECT * FROM articles WHERE category=@0 ORDER BY date_posted DESC", "coolstuff");
// 查询所有数据
foreach (var a in db.Query<Message>("SELECT * FROM message"))
{
Console.WriteLine("{0} - {1}", a.message_id, a.title);
}
//查询所有数据
var a=db.Fetch<Message>("SELECT * FROM message")
6、事务
var db = new AntManManagerDB();
db.BeginTransaction();
try
{
foreach (var message in listMessage)
{
db.Insert(message);
}
db.CompleteTransaction();
return true;
}
catch (Exception e)
{
db.AbortTransaction();
throw new Exception(e.Message);
}
常用的数据库操作就这些了。
挺好用的,拿出来分享一下。
PetaPoco 快速上手的更多相关文章
- 【Python五篇慢慢弹】快速上手学python
快速上手学python 作者:白宁超 2016年10月4日19:59:39 摘要:python语言俨然不算新技术,七八年前甚至更早已有很多人研习,只是没有现在流行罢了.之所以当下如此盛行,我想肯定是多 ...
- 快速上手Unity原生Json库
现在新版的Unity(印象中是从5.3开始)已经提供了原生的Json库,以前一直使用LitJson,研究了一下Unity用的JsonUtility工具类的使用,发现使用还挺方便的,所以打算把项目中的J ...
- [译]:Xamarin.Android开发入门——Hello,Android Multiscreen快速上手
原文链接:Hello, Android Multiscreen Quickstart. 译文链接:Hello,Android Multiscreen快速上手 本部分介绍利用Xamarin.Androi ...
- [译]:Xamarin.Android开发入门——Hello,Android快速上手
返回索引目录 原文链接:Hello, Android_Quickstart. 译文链接:Xamarin.Android开发入门--Hello,Android快速上手 本部分介绍利用Xamarin开发A ...
- 快速上手seajs——简单易用Seajs
快速上手seajs——简单易用Seajs 原文 http://www.cnblogs.com/xjchenhao/p/4021775.html 主题 SeaJS 简易手册 http://yslo ...
- Git版本控制Windows版快速上手
说到版本控制,之前用过VSS,SVN,Git接触不久,感觉用着还行.写篇博文给大家分享一下使用Git的小经验,让大家对Git快速上手. 说白了Git就是一个控制版本的工具,其实没想象中的那么复杂,咱在 ...
- Objective-C快速上手
最近在开发iOS程序,这篇博文的内容是刚学习Objective-C时做的笔记,力图达到用最短的时间了解OC并使用OC.Objective-C是OS X 和 iOS平台上面的主要编程语言,它是C语言的超 ...
- Netron开发快速上手(二):Netron序列化
Netron是一个C#开源图形库,可以帮助开发人员开发出类似Visio的作图软件.本文继前文”Netron开发快速上手(一)“讨论如何利用Netron里的序列化功能快速保存自己开发的图形对象. 一个用 ...
- Netron开发快速上手(一):GraphControl,Shape,Connector和Connection
版权所有,引用请注明出处:<<http://www.cnblogs.com/dragon/p/5203663.html >> 本文所用示例下载FlowChart.zip 一个用 ...
随机推荐
- 2.13.2. 对结果集进行筛选(Core Data 应用程序实践指南)
Core Data通过谓词(NSPredicate)来筛选,比如限定获取的数量等.谓词基本对存储区不敏感,但也有例外,比如:matches可用在 in-memory存储区,但是不能用在SQLite存储 ...
- jQuery 获取和设置type为hidden的input的值
HTML代码 <input type="hidden" name="type" id="type" value="1&quo ...
- BNU Online Judge-34976-数细菌
题目链接 http://www.bnuoj.com/bnuoj/problem_show.php?pid=34976 题目分析通过a b可以设x,y x+y=a x+3*y=b 解出x,y, ...
- JSP EL表达式使用
JSP EL表达式使用: Servlet: package com.stono.servlet; import java.io.IOException; import java.util.HashMa ...
- Android 自定义通用的loadingview
介绍 好久没有写博客啦,最近在接近新年了,年前的工作都要收尾,所以特别忙,周末抽空写了个通用的加载view,写篇博客分享出来. 功能 1.显示加载视图,加载失败的时候显示加载失败视图,数据为空时显示数 ...
- PrefixSpan算法原理总结
前面我们讲到频繁项集挖掘的关联算法Apriori和FP Tree.这两个算法都是挖掘频繁项集的.而今天我们要介绍的PrefixSpan算法也是关联算法,但是它是挖掘频繁序列模式的,因此要解决的问题目标 ...
- 使用数字签名实现数据库记录防篡改(Java实现)
本文大纲 一.提出问题 二.数字签名 三.实现步骤 四.参考代码 五.后记 六.参考资料 一.提出问题 最近在做一个项目,需要对一个现成的产品的数据库进行操作,增加额外的功能.为此,需要对该产品对数据 ...
- 简单的Elf逆向Writeup
ElfCrackMe1 html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acrony ...
- Python自然语言处理学习笔记之性别识别
从今天起开始写自然语言处理的实践用法,今天学了文本分类,并没用什么创新的东西,只是把学到的知识点复习一下 性别识别(根据给定的名字确定性别) 第一步是创建一个特征提取函数(feature extrac ...
- 【小分享】Date对象封装,时间格式化函数time()
今天再来分享下Date的应用知识点 先看效果,类似于php里边的time('yyyy-mm-dd')用法,但是我这里没有完全依照php的参数格式来,如果有需要稍微修改一下就行. 首先,明确需要用到的参 ...