Linq To Sqlite 一一二二
说在前头
之所以写下这些文字,主要是因为使用LINQ的同志们都觉它的美好(至于有多美好,各位心里知道,我就不在描述了,如果你是你还不了解LINQ,园子里有大把的文章),微软老哥只提供了自家的SQLServer的支持 -LinqToSql ,然而很多项目,特别是小型的项目,部署SQLServer太过于麻烦(光下载就够呛),Sqlite、Access就成很多人的选择,但又不想去写那“红通通”(VS中字符串的颜色)的SQL语句,于是祭出了Google大神,发现伙伴们常用的是Dblinq,但配置让很多新手有点伤神(至少那个每次要用 DbMetal.exe命令生成对象就有点……,反正我是比较懒),收费的就不用说了(我们这一行的,口袋都有点紧……)。
进入正题
这里主要是介绍使用Linq To DB,它相对现在已有的方案来说,用法是比较简单的。下面我们就开始吧!
1、打开VS,新建一个项目(我建的是Winform)并保存,名称随意;
2、安装Nuget的Linq to SQLite包,打开Nuget包管理器控制台(VS 菜单 “工具”-->库程序包管理器-->库程序包管理器控制台)如下图;
Nuget是什么?
没有它时,我们引用一些开源的库至少需要做如的一些事:
a、找到正确的资源(库文件及其依赖项);
b、下载相应的资源(有下错及别欺骗过的经历没?);
c、添加引用;
很长一段时间,大伙儿一直重复着这样的折腾,终于有一伙人受不了拉,于是Nuget诞生了,好东西微软肯定是不放过,于是VS里集成了;
3、在PM>提示符后输入命令:(请保持网络畅通,下边命令要联网下载)
Install-Package linq2db.SQLite
4、完装完成后,自动添加了依赖项:System.Data.SQLite、linq2db、ling2db.t4models(创建Linq to SQLite的T4模板)
在解决方案资源管理器中添加了几项(是不是帮你把原来要自己做的事代劳了?,世界一下子变得美好了),如图:
5、打开解决方案资源管理器中LinqTODB.Template文件夹中的CopyMe.SQLite.tt.txt文件,如图:
图中红框依次为下面生成类文件的,命名空间,数据库目录,数据库名称 (请更改为你自己的命名空间,数据库名目录,数据库名,上图是我测试项目使用的,否则无法正常继续)。
注意:如果数据库有密码且是用“SQLite2009 Pro”创建的,密码类型请选择第三项 RSA(Compatible with ADO.NET Provider),否则打不开数据库,会一直提示“File is encrypted or is not a database”
6、将后面的.TXT去掉,保存,此时会提示,是否执行,点是。就会在此文件同目录下生成一个类文件(后面程序中会用到)如图:
7、现在就可以使用Linq To Sqlite了;
var db = new DatabaseHelper1DB(@"Data Source=F:\Yun\VolcanoCloudTest\DatabaseHelper2.db3;Version=3;Password=1");
var temp =
from c in db.Users
select c;
foreach (var c in temp)
listBox1.Items.Add(c.Name);
但是很遗憾,一个异常出来了,是说连接数符串没有定义。原来生成类中的DatabaseHelper1DB构造函数<public DatabaseHelper1DB(string configuration)>的字符串类型的参数是连接字符串配置文件中Name,不是连接字符串本身。我不想去配置连接字符串,因为多数时间(至少我是这样)连接字符串是代码动态生成的。办法总是有的,我们来看看DatabaseHelper1DB的基类 LinqToDB.Data.DataConnection ,它有一个这样的构造函数:
public DataConnection(IDataProvider dataProvider, string connectionString);
第二参数正是我们想要的连接字符串本身,问题是第一个参数怎么传入,派生类的代码又是自动生成的。怎么办呢?方法有二
a、修改生成后的类文件为:
public DatabaseHelper1DB(string configuration)
:base(configuration) //原来的
{
InitDataContext();
} public DatabaseHelper1DB(string configuration)
:base(new LinqToDB.DataProvider.SQLite.SQLiteDataProvider(), configuration) //修改后的
{
InitDataContext();
}
但这样有一个问题,代码每生成一次,我都要修改一次,不省心呀(觉得不省心的,请看第二种)
b、修改代码生成模板,这样一劳永逸。找到文件“LinqToDB.ttinclude”进行如下修改:
if (GenerateConstructors)
{
if (DefaultConfiguration == null)
DataContextObject.Members.Add(new Method(null, DataContextObject.Name, new string[], new[] { "InitDataContext();" }));
else
DataContextObject.Members.Add(new Method(null, DataContextObject.Name, new string[], new[] { "InitDataContext();" }) { AfterSignature = { ": base(\"" + DefaultConfiguration + "\")" } });
DataContextObject.Members.Add(new Method(null, DataContextObject.Name, new[] { "string configuration" }, new[] { "InitDataContext();" }) { AfterSignature = { ":base(new LinqToDB.DataProvider.SQLite.SQLiteDataProvider(), configuration)" } });
//上面的 ":base(new LinqToDB.DataProvider.SQLite.SQLiteDataProvider(),configuration)为修改后的 DataContextObject.Members.Add(new MemberGroup
{
IsCompact = true,
Members = { new Method("void", "InitDataContext") { AccessModifier = AccessModifier.Partial } }
});
}
再次运行,异常没有了。(如果你觉得这样麻烦,或是你习惯于配置里设置连接字符串的方式,你只要在配置 文件中增加连接字符串,并在使用时传入配置项的Name);
完事了? 慢!不要太高兴,查询是可以了,更新,删除呢?DatabaseHelper1DB 里没有提供相应的方法,难道这东东只支持查询,于是祭出google,开始一阵眩晕,看了一篇老外介绍 linq to db的文章,说linq to db 技术是一种linq查询解决方案。我的天,查询?!,难道真不支持,折腾了这么久就只能查询,怎么对得住自己呢?自已实现?应该不会不支持,老外做事还是细致的。提供一个库,不至于只做到一半。于是继续搜索,看了好些英文博客(那个痛苦呀,本人英文不好,你懂的)。终于找到了,原来linq to db是通过扩展方法来实现更新和删除的,而相关的扩展方法又在另外的命名空间(LinqToDB下,不是DatabaseHelper1DB类所在的命外空间 LinToSqlite),因此要引入命名空间。
using LinqToDB;
插入:
User uNew = new User();
uNew.Name = "test";
uNew.Password = "";
db.Insert(uNew);
更新:
using (var db = new DatabaseHelper1DB(@"Data Source=F:\Yun\VolcanoCloudTest\DatabaseHelper2.db3;Version=3;Password=1"))
{
db.Users
.Where(u => u.ID == )
.Set(p => p.Name,"test")
.Update();
}
删除:
using (var db = new DatabaseHelper1DB(@"Data Source=F:\Yun\VolcanoCloudTest\DatabaseHelper2.db3;Version=3;Password=1"))
{
db.Users
.Where(u => u.ID == )
.Delete();
}
另外,linqtodb还支持access(看到很多同志在找 linq to access,有人还用上收费的,这可能又是一福音)等十余中数据库,使用方法类似,本文已经很长了(我喜欢简短的文章,阅读方便),所以不在赘述,想要用的同志就自己动手吧。
末了
本文是我在园子里的第一篇(处女作),希望大家多指正,如果能帮上你,我表示灰常灰常的高兴。 2015年1月6日于图书馆。
Linq To Sqlite 一一二二的更多相关文章
- 在C#中利用Nuget包使用SQLite数据库和Linq to SQLite
本来是学习在VB中使用SQLite数据库和Linq to SQLite,结果先学习到了在C#中使用SQLite数据库和Linq to SQLite的方法,写出来与大家共同学习.(不知道算不算不务正业) ...
- 在VB中使用Linq To SQLite注意事项
昨天使Linq To SQLite 支持VB,今天在VB中写了几条Linq语句,发现了几个问题: 1.在Linq To SQLite中的Linq语句查询后并不是得到的匿名数据类,而是将Linq转换为S ...
- 在VB中利用Nuget包使用SQLite数据库和Linq to SQLite
上午解决了在C#中利用Nuget包使用SQLite数据库和Linq to SQLite,但是最后生成的是C#的cs类文件,对于我这熟悉VB而对C#白痴的来说怎么能行呢? 于是下午接着研究,既然生成的是 ...
- LINQ to SQLite完美解决方案
1.下载安装LinqConnectExpress(就是LinqConnect免费版) 2.安装好后就和LINQ TO SQL 一样了! 3.查询(增删改查和LINQ TO SQL 完全一样,你可以不 ...
- .NET环境下,通过LINQ操作SQLite数据库
//对应数据库中的某个表 [Table(Name = "main.Student")] public class Student { [Column(Na ...
- Linq To Sqlite使用心得
若要使用Linq To Sqlite类库,可以安装Devart Linq Connect Model,如图: 新建这个Model就可以和Linq To Sql一样使用Linq模型,下载地址:https ...
- Linq To SQLite by CRUD
1, 希望使用linqtoSQLite 来对数据库实现CRUD, 开发环境 VS2013, 1.1 在网上找到了 LINQ to DB T4 Models, 配置参考网址链接: http://www. ...
- Linq to Sqlite连接
本人还是挺喜欢用Sqlite,鼓捣半天终于连上了,赶紧记录一下 1.当然还是新建一个项目,还是winform, 2.Vs2012添加NoGet,点击工具--扩展和更新,搜索NoGet,安装. 3.管理 ...
- linq连接sqlite数据库(linq to sqlite) .net3.5
http://www.cnblogs.com/xianyin05/archive/2012/12/23/2829905.html using Models; using System; using S ...
随机推荐
- python 之redis
redis是一个key-value存储系统,与memcached类似,它支持存储到value类型相对更多,包括string(字符串),list(列表),set(集合),zset(sorted set ...
- 浅析Spring中的注解
Spring的配置,通常有两种:使用配置文件和注解.那么Spring如何知道各个Bean或者Service.Controller以及Bean中各类属性之间的关系呢?答案肯定是在定义各个Java文件的时 ...
- Optimizely:在线网站A/B测试平台
Optimizely:在线网站A/B测试平台是一家提供 A/B 测试服务的公司.A/B 测试能够对比不同版本的设计,选取更吸引用户眼球的那一款,从而带来更为优化的个人体验.让网站所有者易于对不同版本的 ...
- SQL server 视图、范式
视图 1.视图的概述 视图其实就是一条查询sql语句,用于显示一个或多个表或其他视图中的相关数据.视图将一个查询的结果作为一个表来使用,因此视图可以被看作是存储的查询 或一个虚拟表.视图来 ...
- div自定义的滚动条 (竖直导航条)
<style type="text/css"> .scrollBar { width: 10px; background-color: #daa520; positio ...
- 基于Jenkins的环境搭建
基于 Jenkins 快速搭建持续集成环境 持续集成是一种软件开发实践,对于提高软件开发效率并保障软件开发质量提供了理论基础.Jenkins 是一个开源软件项目,旨在提供一个开放易用的软件平台,使持续 ...
- 解决安装sql server 需要重启问题
解决办法: 一.在SQL服务器的安装盘中找到MSDE这个目录,并且点击setup.exe安装它. 二.安装完毕后,重启系统WINDOWSXP,这下就可以看到SQL服务的图标出现了. 三.再直接安装根目 ...
- A trip through the Graphics Pipeline 2011_05
After the last post about texture samplers, we’re now back in the 3D frontend. We’re done with verte ...
- JNDI数据源局部配置(解决Cannot create JDBC driver of class '' for connect URL 'null')
最开始,我是借鉴 孤傲苍狼的JNDI教程去做的,他讲得很详细,但是坏处也就是因为他讲的太详细.查了很多书,都是建议说不要用全局去配置JNDI,一是要修改tomcat的server.xml,容易破坏to ...
- hibernate学习(5)——对象状态与一级缓存
1.对象状态 1.1 状态介绍 hibernate 规定三种状态:瞬时态.持久态.脱管态 瞬时态:transient,session没有缓存对象,数据库也没有对应记录.没有与hibernate关联 ...