zoukankan      html  css  js  c++  java
  • 在C#中利用Nuget包使用SQLite数据库和Linq to SQLite

    本来是学习在VB中使用SQLite数据库和Linq to SQLite,结果先学习到了在C#中使用SQLite数据库和Linq to SQLite的方法,写出来与大家共同学习。(不知道算不算不务正业)

    1、建立或打开一个C#项目,如果是新建的项目则需要先保存一下,不然无法安装Nuget包。

    2、安装Nuget的Linq to SQLite包,打开Nuget包管理器控制台:

     3、在PM>提示符后输入安装命令:(电脑要联网)

    Install-Package linq2db.SQLite

    4、安装成功后:

    自动添加了依赖项:System.Data.SQLite、linq2db、ling2db.t4models(创建Linq to SQLite的T4模板)

    在解决方案资源管理器中添加了几项:

     5、现在就可以使用SQLite数据库了:

    using System.Data.SQLite;

     由于对C#代码不是太熟悉,就不写具体的连接方法了。

    6、实现Linq to SQLite:

    打开解决方案资源管理器中LinqTODB.Template文件夹中的CopyMe.SQLite.tt.txt文件:

    显示如下:

    7、模板说明的第一步、第二部都不用管,我们直接来做第三部,在Web/app.config文件中添加数据库连接:

    打开解决方案的属性窗口,选择”设置“,添加一个”connectionStrings“的连接字符串,并设置值后保存:

    打开Web/app.config文件,修改文件,在connectionString="Data Source=E:Address.db3" 后添加providerName="SQLite":

    整个配置文件如下:(其中E:Address.db3应为你的SQLite数据库文件)

    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
        <configSections>
        </configSections>
        <connectionStrings>
            <add name="WindowsFormsApplication1.Properties.Settings.connectionStrings"
                connectionString="Data Source=E:Address.db3" providerName="SQLite" />
        </connectionStrings>
        <startup> 
            <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
        </startup>
    </configuration>

    8、回到CopyMe.SQLite.tt.txt文件窗口,修改两个位置后保存:

    第一个位置是数据库文件所在的目录,本例应修改为“E:”,第二个位置是SQLite数据库的文件名,本例应为“Address.db3"。(也可以修改NamespaceName来修改为自己的命名空间)

     9、在解决方案资源管理器窗口,右击CopyMe.SQLite.tt.txt文件重命名:"Address.tt",文件名随便起,后面的.txt去掉,得到模板文件:

    出现询问是否执行模板文件窗口:

    确定后在解决方案资源管理器窗口多出了Linq to SQLite类:

    10、现在可以在你的代码中运行Linq To SQLite了:

    private void Form1_Load(object sender, EventArgs e)
            {
                var db=new DataModel.addressDB;
                var temp=
                    from c in db.AddressDistricts 
                    select c;
                foreach (var c in temp)
                        Console.WriteLine(c.DistrictName );
    
            }

    悲剧啊,vb中什么时候能实现啊。

    题后话:Nuget的Linq TO SQLite包十分的强大,不仅实现了Linq对SQLite数据库的支持,同时还实现了Linq 对Access、DB2、Firebird、Oracle等11种数据库的支持。

  • 相关阅读:
    LeetCode (Two Sum & Add Two nums)
    打包时记录编译开始时间并在App中获取
    CocoaPods
    不知所云
    苹果审核相关内容
    iOS权限的一些备注
    触发网络权限弹窗的一些特别方式记录
    iOS13和iOS14里面访问相册选取图片的两种方式的区别
    @Configuration@Bean
    ACID
  • 原文地址:https://www.cnblogs.com/lxzhangying/p/3227110.html
Copyright © 2011-2022 走看看