热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[UWP小白日记-2]SQLite数据库DOME

原文:[UWP小白日记-2]SQLite数据库DOME数据库说简单点就是增删改查,但是对新手来说也是要爆肝的。作为一个新手爆肝无数次啊,血的教训啊现在UWP的教程又少,说多了都是泪。留下来
原文: [UWP小白日记-2]SQLite数据库DOME

  数据库说简单点就是增删改查,但是对新手来说也是要爆肝的。作为一个新手爆肝无数次啊,

血的教训啊现在UWP的教程又少,说多了都是泪。留下来免得以后又爆肝。还有:一定要写注释!一定要写注释!一定要写注释! 重要的事情说三遍!

  1.首先,准备工作:

  1)引用:

      

    获取途径:VS里的扩展和更新、NuGet等。

  2)数据库模型:

 1 internal class ACCOURT
2 {
3 public ACCOURT() { } //空构造函数
4 public ACCOURT(int ID,double Amount,string Descr,DateTime Time,string Mark,string Company)
5 {//重载构造函数,用来后面把UI上的数据传入数据库
6 this.UID = ID;
7 this.Amount = Amount;
8 this.Descr = Descr;
9 this.Time = Time;
10 this.Mark = Mark;
11 this.Company = Company;
12 }
13 ///
14 /// 编号
15 ///

16 [PrimaryKey] //主键
17 [AutoIncrement]//自增
18 [NotNull]//不能为空
19 public int UID { get; set; }
20
21 ///
22 /// 金额
23 ///

24 public double Amount { get; set; }
25
26 ///
27 /// 备注
28 ///

29 public string Descr { get; set; }
30
31 ///
32 /// 时间
33 ///

34 public DateTime Time { get; set; }
35
36 ///
37 /// 标签
38 ///

39 public string Mark { get; set; }
40
41 ///
42 /// 所属公司
43 ///

44 public string Company { get; set; }
45 }

 

  3.写帮助类:

    0)引入SQLite.net

1 using SQLite.Net;
2 using SQLite.Net.Platform.WinRT;
3 using SQLite.Net.Interop;
4 using SQLite.Net.Attributes;
5 //管它用不用先放进来

 

 

  1)数据库路径:

1  /// 
2 /// 数据路径
3 ///

4 public string DbName = "SQLite.db";//名字你就随便取了
5 public string DbPath;//可以再这初始化,亦可以在后面在初始化
6 // public string DbPath=Path.Combine(ApplicationData.Current.LocalFolder.Path, DbName);

 

 

  2)创建数据库连接:

 1 #region 创建数据库链接
2 ///
3 /// 创建数据库连接
4 ///

5 ///
6 internal SQLite.Net.SQLiteConnection GetCreateConn()
7 {
8 DbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, DbName);
9 var con = new SQLite.Net.SQLiteConnection(new SQLitePlatformWinRT(), DbPath);
10
11 return con;
12
13 }
14 #endregion

  3)创建数据库:

 1 #region 创建数据库
2 ///
3 /// 如果没有数据库,就创建一个数据库。
4 ///

5 internal void CreateDB()
6 {///
7 /// 数据库文件所在路径,这里使用 LocalFolder
8 ///

9 DbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, DbName);
10 using (var cOnn= GetCreateConn())
11 {
12 //这里什么都不写就是创建一个空数据库
13 conn.CreateTable();//根据ACCOURT模型创建数据表
14
15 }
16 }
17 #endregion

   特别说明:增删改这3个方法调用传入的ACCOURT addAccourt 参数,最好改为object类型,这样更具有通用性,应为一个APP不可能只有一个表

哇哈哈,写完才看到ACCOURT本来是写ACCOUNT的写错了,那就将错就错。嘎嘎。

  4)插入数据:

 1 #region
       2 internal int AddData(ACCOURT addAccourt)
3 {
4 int result = 0;
5 using (var cOnn= GetCreateConn())
6 {
7 result = conn.Insert(addAccourt);
8 conn.Close();
9 }
10
11 return result;
12 }
13 #endregion

 

  5)删除数据:

 1 #region
2 internal int DeleteData(ACCOURT AccourtUID)
3 {
4 int result = 0;
5 DbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, DbName);
6 using (var cOnn= GetCreateConn())
7 {
8 result = conn.Delete(AccourtUID);
9 conn.Close();
10 }
11 return result;
12 }
13
14 #endregion

 

  6)修改数据:

 1  #region
2 internal int UpadateData(ACCOURT updataAccourt)
3 {
4 int result = 0;
5 DbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, DbName);
6 using (var cOnn= GetCreateConn())
7 {
8 result = conn.Update(updataAccourt);
9 //conn.Close();
10 }
11 return result;
12 }

 

  7)查询数据:

 1 #region
2 ///
3 /// 模糊查询
4 ///

5 /// 文本框输入的条件
6 ///
7 internal List CheckData(string conditions)
8 {
9
10 var temSTR = "%"+conditions+"%";
11 #region
12 using (var cOnn= GetCreateConn())
13 {
14
15 return conn.Query("select * from ACCOURT where Company like ? or Descr like ? or UID like ? or Mark like ? or Time like ? or Amount like ?;", temSTR, temSTR, temSTR, temSTR, temSTR, temSTR);
16
17
18
19 }
20 #endregion
21 }
22
23 #endregion

  查询只个方法要说明下:这个他的原型:

1 Query(string sql,params objcet [] args)

Sql:这就不用说明了就是SQL语句。

params:不确定个数的参数列表。

  

1 Query("select * from ACCOURT where Company like ? or Descr like ? or UID like ? or Mark like ? or Time like ? or Amount like ?;", temSTR, temSTR, temSTR, temSTR, temSTR, temSTR)
2 //多字段模糊查询,SQL中有多少个"?"就在后面的params中输入多少个参数

 

  8)读取数据:

 1 #region
2 internal ObservableCollection ReadData(ObservableCollection accourt)
3 {
4 accourt.Clear();
5 DbPath = Path.Combine(ApplicationData.Current.LocalFolder.Path, DbName);
6 CreateDB();
7 using (var cOnn= GetCreateConn())
8 {
9 var dbAccourt = conn.Table();
10 foreach (var item in dbAccourt)
11 {
12 accourt.Add(item);
13 }
14 //conn.Close();
15 }
16 return accourt;
17 }
18 #endregion

总结

可以看出:增、删、改 这3个方法是差不多的

查询要复杂一点,我想其他任何数据库应该都差不多,我自己目前还没有接触过其他的数据库。

哦,还有一点忘记了,在VS用代码分析的时候会提示:conn.Close(); 多次释放,最好还是删除它。                           

 

欢迎大家留言交流

最后是一个dome的代码:

下载

 


推荐阅读
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 生成式对抗网络模型综述摘要生成式对抗网络模型(GAN)是基于深度学习的一种强大的生成模型,可以应用于计算机视觉、自然语言处理、半监督学习等重要领域。生成式对抗网络 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
    本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
  • 本文讨论了Kotlin中扩展函数的一些惯用用法以及其合理性。作者认为在某些情况下,定义扩展函数没有意义,但官方的编码约定支持这种方式。文章还介绍了在类之外定义扩展函数的具体用法,并讨论了避免使用扩展函数的边缘情况。作者提出了对于扩展函数的合理性的质疑,并给出了自己的反驳。最后,文章强调了在编写Kotlin代码时可以自由地使用扩展函数的重要性。 ... [详细]
author-avatar
手机用户2602908893
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有