mono for android中使用dapper或petapoco对sqlite进行数据操作
在mono for android中使用dapper或petapoco,很简单,新建android 类库项目,直接把原来的文件复制过来,对Connection连接报错部分进行注释和修改就可以运行了.(用可移植类库PCL项目也可以的.)
如果需要源码可以联系我.10元收费哈..
以下内容包括
1.在安卓中创建sqlite数据库;
2.检查数据库是否存在;
3.返回数据库路径;
4.插入数据(前置知识,dapper的使用方法或petapoco的);
5.查询数据;
本人小菜鸟一枚,以下代码写得很烂,希望有好的想法可以指点下我.
知识点提示
1.安卓sqlite数据提交,默认每一次都是事务提交,所以如果不采用一次性全部事务提交,会造成很多事务的建立.也就是把提交部分,用一个事务包起来,不要不用事务.否则很慢.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Android.App;
using Android.Content;
using Android.OS;
using Android.Runtime;
using Android.Views;
using Android.Widget; using System.IO;
using Mono.Data.Sqlite;
using System.Data;
using Android.Util;
using Microsoft.CSharp;
using Mono.CSharp;
using Dapper;
using BaseModel;
using PetaPocoForMobile; namespace monoandroid1.Controllers
{
[Activity(Label = "启动页", MainLauncher = true, Icon = "@drawable/icon")]
public class Start : Activity
{
private TextView tips;
private EditText keyword; protected override void OnCreate(Bundle bundle)
{
base.OnCreate(bundle); // Create your application here
SetContentView(Resource.Layout.Main);
tips = FindViewById<TextView>(Resource.Id.Results); Button BtCreatDatabase = FindViewById<Button>(Resource.Id.CreatDatabase);
BtCreatDatabase.Click += new EventHandler(CreatDatabase); Button BtImportData = FindViewById<Button>(Resource.Id.ImportData);
BtImportData.Click += delegate { ImportData(); }; Button BtDataDisplay = FindViewById<Button>(Resource.Id.DataDisplay);
BtDataDisplay.Click += delegate
{
keyword = FindViewById<EditText>(Resource.Id.Input);
tips.Text = DataDisplay(keyword.Text) == null ? "查询不到" : DataDisplay(keyword.Text).UserName;
}; Button BtCheckDatabase = FindViewById<Button>(Resource.Id.CheckDatabase);
BtCheckDatabase.Click += delegate
{
CheckDatabase("/data/data/monoandroid1.monoandroid1/files/UserData.db3");
};
}
/// <summary>
/// 创建数据库
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void CreatDatabase(object sender, EventArgs e)
{
string databaseName = "UserData.db3";
string dbFilePath = GetDatabaseFilePath(databaseName);
bool existsDB = CheckDatabase(dbFilePath);
if (existsDB == true)
{
SqliteConnection.CreateFile(dbFilePath);
} var conn = new SqliteConnection("Data Source=" + dbFilePath);
var commands = new[]
{
"drop table if exists dog",
"create table if not exists dog (UserId integer primary key autoincrement, UserName varchar(20),Age int,Address varchar(50))",
};
try
{
if (conn.State == ConnectionState.Broken)
conn.Close();
if (conn.State == ConnectionState.Closed)
{
conn.Open();
} foreach (string cmd in commands)
using (SqliteCommand sqlitecmd = conn.CreateCommand())
{
sqlitecmd.Connection = conn;
sqlitecmd.CommandText = cmd;
sqlitecmd.CommandType = CommandType.Text;
//conn.Open();
sqlitecmd.ExecuteNonQuery();
//conn.Close();
} tips.Text = "数据库创建成功";
}
catch (System.Exception sysExc)
{
tips.Text = "Exception: " + sysExc.Message;
}
finally
{
if (conn.State != ConnectionState.Closed)
{
conn.Close();
}
conn.Dispose();
}
} /// <summary>
/// 返回数据库完整路径
/// </summary>
/// <param name="databaseName">数据库名</param>
/// <returns>返回数据库完整路径</returns>
private string GetDatabaseFilePath(string databaseName)
{
string documents = System.Environment.GetFolderPath(System.Environment.SpecialFolder.Personal);
string dbFilePath = Path.Combine(documents, databaseName);
return dbFilePath;
} /// <summary>
/// 检查数据库是否存在
/// </summary>
/// <param name="dbFilePath"></param>
/// <returns>true不存在,false已经存在</returns>
private bool CheckDatabase(string dbFilePath)
{
bool exists = File.Exists(dbFilePath);
if (!exists)
{
//SqliteConnection.CreateFile(dbFilePath);
tips.Text = "数据库不存在";
Log.Info("CreateFile", "路径不存在数据库,并创建数据库");
return true;
}
else
{
tips.Text = "数据库已经存在";
Log.Info("CreatFile", "已经存在数据库,放弃创建");
return false;
}
}
private SqliteConnection OpenDatabase()
{
string databaseName = "UserData.db3";
string dbFilePath = GetDatabaseFilePath(databaseName);
//<add name="ConnectionStringName" connectionString="sever=服务器名;database=数据库名;User ID=用户;Password=密码" providerName="System.Data.SqlClient" />
//<add name="ConnectionStringName" connectionString="Data Source=服务器名;Initial Catalog=数据库名;User ID=用户;Password=密码" providerName="System.Data.SqlClient" />
string connectionstr = "Data Source=" + dbFilePath;
SqliteConnection connection = new SqliteConnection(connectionstr);
if (connection.State == ConnectionState.Broken)
connection.Close();
if (connection.State == ConnectionState.Closed)
{
connection.Open();
} return connection;
}
/// <summary>
/// 导入数据
/// </summary>
protected void ImportData()
{
//dapper版
// List<Dog> Dogs = new List<Dog>();
// for (int i = 0; i < 100000; i++)
// { // Dogs.Add(new Dog { UserId = i, UserName = "DogName" + i.ToString(), Age = i, Address = "ADD" + i.ToString() }); // }
// string sql ="INSERT INTO dog (UserId,UserName,Age,Address) VALUES (@UserId,@UserName,@Age,@Address)";
// using (SqliteConnection connection = OpenDatabase())
// {
// //SqlConnection connection = GetOpenConnection(sqlconnectionString);
// //插入100000条数据到数据库
// DateTime starttime = DateTime.Now;
// TimeSpan timespan;
// int records = 0; // using (var trans = connection.BeginTransaction())
// {
// try
// {
// records += connection.Execute(sql, Dogs, trans, 30, CommandType.Text);
//// for (int i = 0; i < 100000; i++)
//// {
//// connection.Execute("INSERT INTO dog (UserId,UserName,Age,Address) VALUES (@UserId,@UserName,@Age,@Address)",
//// new { );//System.Guid.NewGuid().ToString()全球唯一标识符 (GUID) 是一个字母数字标识符,用于指示产品的唯一性安装。
//// }
// }
// catch (DataException ex)
// {
// trans.Rollback();
// throw ex;
// }
// finally
// {
// trans.Commit();
// timespan = DateTime.Now.Subtract(starttime);//获取就是开始时间很结束时间差
// if (connection.State != ConnectionState.Closed)
// {
// connection.Close();
// }
// connection.Dispose();
// tips.Text = "数据导入完成" + timespan.ToString();
// }
// }
// } //petapoco版 //var db = new PetaPocoForMobile.Database(OpenDatabase());
//SqliteConnection connection = OpenDatabase()
using (SqliteConnection connection = OpenDatabase())
{
int records = 0;
using (var db = new PetaPocoForMobile.Database(connection))
{
List<Dog> Dogs = new List<Dog>();
for (int i = 0; i < 10000; i++)
{
Dogs.Add(new Dog { UserId = i, UserName = "DogName" + i.ToString(), Age = i, Address = "ADD" + i.ToString() });
}
DateTime starttime = DateTime.Now;
TimeSpan timespan;
using (var ts = db.GetTransaction())
{
try
{
//插入100000条数据到数据库
foreach (Dog item in Dogs)
{
db.Insert("dog", "UserId", item);//速度稍微慢点点,没多少差别
//db.Execute("INSERT INTO dog (UserId,UserName,Age,Address) VALUES (@0,@1,@2,@3)", item.UserId, item.UserName, item.Age, item.Address);
}
ts.Complete();
}
catch (Exception ex)
{
throw ex;
}
finally
{
timespan = DateTime.Now.Subtract(starttime);//获取就是开始时间很结束时间差
if (connection.State != ConnectionState.Closed)
{
connection.Close();
}
connection.Dispose();
tips.Text = "数据导入完成" + timespan.ToString();
}
}
} } } /// <summary>
/// 根据ID查询单条数据
/// </summary>
/// <param name="keyword"></param>
/// <returns></returns>
protected Dog DataDisplay(string keyword)
{
SqliteConnection connection = OpenDatabase();
//获取单条记录
//var edog = connection.Query<Dog>("select * from dog where id = @Id", new { Id = 2 }).Single<Dog>();
//var edog = connection.Query<Dog>("select * from dog where UserId = @UserId", new { UserId = keyword }).SingleOrDefault<Dog>();
try
{
var edog = connection.Query<Dog>("select * from dog where UserId = @UserId", new { UserId = keyword }).SingleOrDefault<Dog>();
return edog;
}
catch (System.Exception sysExc)
{
//tips.Text = "Exception: " + sysExc.Message;
//Log.Info("e", "Exception: " + sysExc.Message); return null;
}
finally
{
if (connection.State != ConnectionState.Closed)
{
connection.Close();
}
connection.Dispose();
}
} }
}
mono for android中使用dapper或petapoco对sqlite进行数据操作的更多相关文章
- 【月入41万】Mono For Android中使用百度地图SDK
借助于Mono For Android技术,.Net开发者也可以使用自己熟悉的C#语言以及.Net来开发Android应用.由于Mono For Android把Android SDK中绝大部分类库都 ...
- Mono For Android中AlarmManager的使用
最近做了一个应用,要求如下: 程序运行之后的一段时间,分别触发3个不同的事件.当然很快就想到了Android中的AlarmManager和BroadcastReceiver.但是毕竟Mono环境和Ja ...
- Mono For Android中简单实现按钮的动画效果
Android中动画的分Tween Animation和Frame Animation,本节主要讲Tween Animation的实现. 一般是通过XML文件来定义动画的,具体如下: 1.在项目res ...
- Mono For Android中完美使用百度地图SDK(v2.1.2&v2.1.3)(转)
在Xamarin Mono For Android的开发中,如果要使用第三方的jar,就必须进行绑定.通过创建Java Bindings Library项目来自动生成C#到java的代码映射代码,最终 ...
- Android中API建议的方式实现SQLite数据库的增、删、改、查的操作
package com.examp.use_SQLite.dao; import java.util.ArrayList; import java.util.List; import android. ...
- Android中使用BufferedReader.readline阻塞读取不到数据,但是ready返回true
通过socket测试工具在电脑上发送消息,Android真机可以收到响应BufferedReader.ready()返回true,但是readline却一直阻塞. 原因:readline()只有在遇到 ...
- Android中Service通信(一)——启动Service并传递数据
启动Service并传递数据的小实例(通过外界与服务进行通信): 1.activity_main.xml: <EditText android:layout_width="match_ ...
- Android 中如何获取 H5 保存在 LocalStorage 的数据
主要分三步: 写个接口,接收 Js 回调 添加到 WebView 主动调用 Js 获取 比如我要获取保存在 LocalStorage 中的 userKey 字段: 1.写个接口,接收 Js 回调 pu ...
- 在Android中afinal框架下實現sqlite數據庫版本升級的辦法
public abstract void onUpgrade(SQLiteDatabase db,int oldVersion,int new Version) 這個方法在實現時需要重寫. pub ...
随机推荐
- Xshell 连接CentOS服务器解密
平台之大势何人能挡? 带着你的Net飞奔吧!http://www.cnblogs.com/dunitian/p/4822808.html Xshell生成密钥key(用于Linux 免密码登录)htt ...
- 4.Windows Server2012 R2里面部署 MVC 的网站
网站部署之~Windows Server | 本地部署:http://www.cnblogs.com/dunitian/p/4822808.html#iis 后期会在博客首发更新:http://dnt ...
- SignalR代理对象异常:Uncaught TypeError: Cannot read property 'client' of undefined 推出的结论
异常汇总:http://www.cnblogs.com/dunitian/p/4523006.html#signalR 后台创建了一个DntHub的集线器 前台在调用的时候出现了问题(经检查是代理对象 ...
- Servlet监听器笔记总结
监听器Listener的概念 监听器的概念很好理解,顾名思义,就是监视目标动作或状态的变化,目标一旦状态发生变化或者有动作,则立马做出反应. Servlet中的也有实现监听器的机制,就是Listene ...
- Windows下Visual studio 2013 编译 Audacity
编译的Audacity版本为2.1.2,由于实在windows下编译,其源代码可以从Github上取得 git clone https://github.com/audacity/audacity. ...
- MongoDB集群配置
本文演示:(一个主服务器,一个备份服务器,三个仲裁服务器) 官方推荐副本集的成员数量为奇数,最多12个副本集节点,最多7个节点参与选举. 本文演示基于本机,用端口区分服务(每个服务器下新建db文件夹用 ...
- __Block与__Weak区别
一.__block理解: Blocks可以访问局部变量,但是不能修改, 声明block的时候实际上是把当时的临时变量又复制了一份, 在block里即使修改了这些复制的变量,也不影响外面的原始变量.即所 ...
- H3 BPM初次安装常见错误详解1-4
错误1: 首次安装完成无法访问,效果如下. 错误原因:没有配置IIS. 解决方法: 控制面板-程序-打开或关闭Windows功能,选择internet信息服务. 因为安装的时候没有没有iis,所以程序 ...
- 烂泥:wiki系统confluence5.6.6安装、中文、破解及迁移
本文由ilanniweb提供友情赞助,首发于烂泥行天下 想要获得更多的文章,可以关注我的微信ilanniweb confluence是一个专业的企业知识管理与协同软件,可以用于构建企业wiki.通过它 ...
- 基于AngularJs的上传控件-angular-file-upload
今天跟大家分享的是一个依赖于angular的上传控件. 前段时间做项目遇到一个需求是上传文件,大概需要实现的样式是这样子的,见下图: 需要同时上传两个文件.并且规定文件格式和文件大小.因为前端框架使用 ...