Xamarin android使用Sqlite做本地存储数据库
android使用Sqlite做本地存储非常常见(打个比方就像是浏览器要做本地存储使用LocalStorage,貌似不是很恰当,大概就是这个意思)。
SQLite 是一个软件库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是在世界上最广泛部署的 SQL 数据库引擎。SQLite 源代码不受版权限制。
如果不是很熟悉Sqlite,建议花点时间看看鸟巢sqlite基础教程。
下面我们就开始学习一下在Xamarin android中如何使用Sqlite呢?首先我们还是这个最终的效果图,主要的流程就是先注册添加一条用户数据,然后登陆sqlite数据库,也就是做一个添加和查询。先看一下效果图:
这里要注意一下,Nuget上关于sqlite的xamarin类库非常多,很多国外的作者都写了sqlite的类库,所以要注意甄别,你会发现使用的方法几乎是一样的。
https://github.com/praeclarum/sqlite-net/blob/master/src/SQLite.cs
引入sqlite-net ,仅仅是多了SQLite.cs 和 SQLiteAsync.cs两个类库而已。比较方便的一种,可以直接看源码。
2.创建一个实体UserInfo.cs
- [Table("UserInfo")]
- public class UserInfo
- {
- [PrimaryKey,AutoIncrement,Collation("Id")]
- public int Id { get; set; }
- public string UserName { get; set; }
- public string Pwd { get; set; }
- }
3.MainActivity.cs 代码开单词就知道是什么意思
- public class MainActivity : Activity
- {
- int count = 1;
- private SQLiteConnection sqliteConn;
- private const string TableName = "UserInfo";
- private string dbPath = Path.Combine(System.Environment.GetFolderPath(System.Environment.SpecialFolder.Personal), "userinfo.db3");
- private Button btnLogin;
- private Button btnRegister;
- private TextView tv_user;
- protected override void OnCreate(Bundle bundle)
- {
- base.OnCreate(bundle);
- SetContentView(Resource.Layout.Main);
- sqliteConn = new SQLiteConnection(dbPath);
- btnLogin = FindViewById<Button>(Resource.Id.btn_login);
- btnRegister = FindViewById<Button>(Resource.Id.btn_register);
- tv_user = FindViewById<TextView>(Resource.Id.tv_user);
- btnLogin.Click += delegate {
- var userName = FindViewById<EditText>(Resource.Id.userName).Text;
- var pwd = FindViewById<EditText>(Resource.Id.pwd).Text;
- Login(userName,pwd);
- };
- btnRegister.Click += delegate
- {
- var userName = FindViewById<EditText>(Resource.Id.userName).Text;
- var pwd = FindViewById<EditText>(Resource.Id.pwd).Text;
- Register(userName,pwd);
- };
- }
- private void Login(string userName,string pwd)
- {
- if (!File.Exists(dbPath))
- {
- sqliteConn = new SQLiteConnection(dbPath);
- }
- var userInfoTable = sqliteConn.GetTableInfo(TableName);
- if (userInfoTable.Count == 0)
- {
- sqliteConn.CreateTable<UserInfo>();
- }
- var userInfos = sqliteConn.Table<UserInfo>();
- var userInfo = userInfos.Where(p => p.Pwd == pwd && p.UserName == userName).FirstOrDefault();
- if (userInfo == null)
- {
- Toast.MakeText(this, "用户名或密码不正确", ToastLength.Short).Show();
- }
- else
- {
- Toast.MakeText(this, "登录成功", ToastLength.Short).Show();
- }
- }
- private void ShowUser()
- {
- if (!File.Exists(dbPath))
- sqliteConn = new SQLiteConnection(dbPath);
- var userInfoTable = sqliteConn.Table<UserInfo>();
- StringBuilder sb = new StringBuilder();
- foreach (var item in userInfoTable)
- {
- sb.Append("username:" + item.UserName + "pwd:" + item.Pwd + "\n");
- }
- tv_user.Text = sb.ToString();
- }
- private void Register(string userName,string pwd)
- {
- if(!File.Exists(dbPath))
- sqliteConn = new SQLiteConnection(dbPath);
- var userInfoTable = sqliteConn.GetTableInfo(TableName);
- if (userInfoTable.Count == 0)
- {
- sqliteConn.CreateTable<UserInfo>();
- }
- UserInfo model = new UserInfo() {Id=1, UserName=userName,Pwd=pwd };
- sqliteConn.Insert(model);
- Toast.MakeText(this, "注册成功", ToastLength.Short).Show();
- ShowUser();
- }
- }
现在是已经能增删改查了,但是如何查看xamarin android中sqlite的数据库呢,adb shell进入sqlite数据库即可查看
就这样吧,代码比较简单,sqlite还是挺有意思,先睡了吧。
例子下载地址:http://download.csdn.net/detail/kebi007/9718965
作者:张林
标题:amarin android使用Sqlite做本地存储数据库 原文地址:http://blog.csdn.net/kebi007/article/details/53795552
转载随意注明出处
Xamarin android使用Sqlite做本地存储数据库的更多相关文章
- 使用SQLite做本地数据缓存的思考
前言 在一个分布式缓存遍地都是的环境下,还讲本地缓存,感觉有点out了啊!可能大家看到标题,就没有想继续看下去的欲望了吧.但是,本地缓存的重要性也是有的! 本地缓存相比分布式缓存确实是比较out和比较 ...
- 本地存储数据库indexedDB实现离线预览的功能
今天在学习<高级JS编程>,看到离线存储,cookie和session都十分的熟悉,但是书中还提到了indexedDB和webSQL(已废弃),indexedDB可以像mysql一样建表, ...
- Xamarin.Android之SQLite.NET ORM
一.前言 通过<Xamarin.Android之SQLiteOpenHelper>和<Xamarin.Android之ContentProvider>的学习,我们已经掌握了如何 ...
- ionic 运用pouchdb/sqlite 数据库做本地存储
配置数据库环境需要3步: 1.安装slqite插件 在ionic 工程目录对应终端执行一下命令: npm install cordova-plugin-sqlite 2.安装pouchdb 在ioni ...
- iOS本地存储-数据库(FMDB)
初识FMDB iOS中原声的SQLite API在进行数据存储的时候,需要使用C语言中的函数,操作比较麻烦,于是就出现了一系列将SQLite封装的库.本文讲解的FMDB就是其中的一个. FMDB PK ...
- Xamarin.Android 使用 SQLite 出现 Index -1 requested, with a size of 10 异常
异常: Android.Database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 10 此错误是数据返回 ...
- Xamarin.Android 使用 SQLite 出现 Couldn't read row 0, col -1 from CursorWindow. 异常
异常:Java.Lang.IllegalStateException: Couldn't read row 0, col -1 from CursorWindow. Make sure the Cu ...
- Android实训案例(三)——实现时间轴效果的ListView,加入本地存储,实现恋爱日记的效果!
Android实训案例(三)--实现时间轴效果的ListView,加入本地存储,实现恋爱日记的效果! 感叹离春节将至,也同时感叹时间不等人,一年又一年,可是我依然是android道路上的小菜鸟,这篇讲 ...
- Xamarin.Android开发实践(十四)
Xamarin.Android之ListView和Adapter 一.前言 如今不管任何应用都能够看到列表的存在,而本章我们将学习如何使用Xamarin去实现它,以及如何使用适配器和自定义适配器(本文 ...
随机推荐
- (转载)java 枚举 循环遍历以及一些简单常见的使用
本文转载自:http://blog.csdn.net/qq_27093465/article/details/51706076 作者:李学凯 什么时候想用枚举类型: 有时候,在设计一个java mod ...
- Code Kata:超级偶数数列 javascript实现
超级偶数(SuperEven)是指每一位都是偶数的正整数,例如: 0,2,4,6,8,20,22,24,26,28,40,...,88,200,202,... 要求写一个函数,输入项数n,返回数列第n ...
- jstl--->Core 核心标签库->流程控制
jstl--->Core 核心标签库->流程控制 -->if.choose.when.otherwise <c:if>条件判断 语法1:没有本体内容 <c:if ...
- 【jQuery插件】使用cropper实现简单的头像裁剪并上传
插件介绍 这是一个我在写以前的项目的途中发现的一个国人写的jQuery图像裁剪插件,当时想实现用户资料的头像上传功能,并且能够预览图片,和对图片进行简单的裁剪.旋转,花了不少时间才看到了这个插件,感觉 ...
- chromium源码阅读--HTTP Cache
最近积累了一些关于HTTP缓存的知识,因此结合Chromium的实现总结一下,主要从如下2个分面: 1.HTTP缓存的基础知识 2.Chromium关于HTTP缓存的实现分析 一.HTTP缓存的基础知 ...
- MySql的技术规范-企业版(来源于MySql官网)
MySQL技术规范 Oracle MySQL云服务 MySQL数据库即服务 灵活的架构 开源 多线程 可插拔的存储引擎架构 InnoDB,NDB集群 MyISAM,合并,内存,存档 ANSI SQL标 ...
- MySQL管理员珍藏:十大必备工具盘点
作者:dongdongzzcs 第1页: [IT168 专稿]本文的作者Daniel Nichter是MySQL工具的开发者,他为MySQL管理员推荐了十款必备工具.以下是全文内容: MySQL是一套 ...
- poj 2456 Aggressive cows && nyoj 疯牛 最大化最小值 二分
poj 2456 Aggressive cows && nyoj 疯牛 最大化最小值 二分 题目链接: nyoj : http://acm.nyist.net/JudgeOnline/ ...
- PAT B1045 快速排序(25)
1045. 快速排序(25) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CAO, Peng 著名的快速排序算法里有一个经典的划分 ...
- 在Linux中使用线程
我并不假定你会使用Linux的线程,所以在这里就简单的介绍一下.如果你之前有过多线程方面的编程经验,完全可以忽略本文的内容,因为它非常的初级. 首先说明一下,在Linux编写多线程程序需要包含头文件p ...