在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进行数据操作的更多相关文章

  1. 【月入41万】Mono For Android中使用百度地图SDK

    借助于Mono For Android技术,.Net开发者也可以使用自己熟悉的C#语言以及.Net来开发Android应用.由于Mono For Android把Android SDK中绝大部分类库都 ...

  2. Mono For Android中AlarmManager的使用

    最近做了一个应用,要求如下: 程序运行之后的一段时间,分别触发3个不同的事件.当然很快就想到了Android中的AlarmManager和BroadcastReceiver.但是毕竟Mono环境和Ja ...

  3. Mono For Android中简单实现按钮的动画效果

    Android中动画的分Tween Animation和Frame Animation,本节主要讲Tween Animation的实现. 一般是通过XML文件来定义动画的,具体如下: 1.在项目res ...

  4. Mono For Android中完美使用百度地图SDK(v2.1.2&v2.1.3)(转)

    在Xamarin Mono For Android的开发中,如果要使用第三方的jar,就必须进行绑定.通过创建Java Bindings Library项目来自动生成C#到java的代码映射代码,最终 ...

  5. Android中API建议的方式实现SQLite数据库的增、删、改、查的操作

    package com.examp.use_SQLite.dao; import java.util.ArrayList; import java.util.List; import android. ...

  6. Android中使用BufferedReader.readline阻塞读取不到数据,但是ready返回true

    通过socket测试工具在电脑上发送消息,Android真机可以收到响应BufferedReader.ready()返回true,但是readline却一直阻塞. 原因:readline()只有在遇到 ...

  7. Android中Service通信(一)——启动Service并传递数据

    启动Service并传递数据的小实例(通过外界与服务进行通信): 1.activity_main.xml: <EditText android:layout_width="match_ ...

  8. Android 中如何获取 H5 保存在 LocalStorage 的数据

    主要分三步: 写个接口,接收 Js 回调 添加到 WebView 主动调用 Js 获取 比如我要获取保存在 LocalStorage 中的 userKey 字段: 1.写个接口,接收 Js 回调 pu ...

  9. 在Android中afinal框架下實現sqlite數據庫版本升級的辦法

    public abstract void onUpgrade(SQLiteDatabase db,int oldVersion,int new Version) 這個方法在實現時需要重寫.   pub ...

随机推荐

  1. 关于CryptoJS中md5加密以及aes加密的随笔

    最近项目中用到了各种加密,其中就包括从没有接触过得aes加密,因此从网上各种查,官方的一种说法: 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学 ...

  2. HTML 事件(二) 事件的注册与注销

    本篇主要介绍HTML元素事件的注册.注销的方式. 其他事件文章 1. HTML 事件(一) 事件的介绍 2. HTML 事件(二) 事件的注册与注销 3. HTML 事件(三) 事件流.事件委托 4. ...

  3. HTML5 localStorage本地存储

    介绍 localStorage(本地存储)的使用方式.包括对存储对象的添加.修改.删除.事件触发等操作. 目录 1. 介绍 1.1 说明 1.2 特点 1.3 浏览器最小版本支持 1.4 适合场景 2 ...

  4. scrapy爬虫docker部署

    spider_docker 接我上篇博客,为爬虫引用创建container,包括的模块:scrapy, mongo, celery, rabbitmq,连接https://github.com/Liu ...

  5. 基于netty http协议栈的轻量级流程控制组件的实现

    今儿个是冬至,所谓“冬大过年”,公司也应景五点钟就放大伙儿回家吃饺子喝羊肉汤了,而我本着极高的职业素养依然坚持留在公司(实则因为没饺子吃没羊肉汤喝,只能呆公司吃食堂……).趁着这一个多小时的时间,想跟 ...

  6. SignalR SelfHost实时消息,集成到web中,实现服务器消息推送

    先前用过两次SignalR,但是中途有段时间没弄了,今天重新弄,发现已经忘得差不多了,做个笔记! 首先创建一个控制台项目Nuget添加引用联机搜索:Microsoft.AspNet.SignalR.S ...

  7. PHP static静态属性和静态方法

    这里分析了php面向对象中static静态属性和静态方法的调用.关于它们的调用(能不能调用,怎么样调用),需要弄明白了他们在内存中存放位置,这样就非常容易理解了.静态属性.方法(包括静态与非静态)在内 ...

  8. 反应器(Reactor)和主动器(Proactor)

    网络方面用的比较多的库是libevent和boost.asio,两者都是跨平台的.其中libevent是基于Reactor实现的,而boost.asio是基于Proactor实现的.Reactor和P ...

  9. TFS 2015 敏捷开发实践 – 看板的使用

    看板在现代应用开发过程中使用非常广泛,不管是使用传统的瀑布式开发还是敏捷开发,都可以使用看板管理.因为看板拥有简单的管理方法,直观的显示方式,所以很多软件开发团队选择使用看板进行软件开发管理.本文不在 ...

  10. 【一起学OpenFOAM】03 OpenFOAM基本使用流程

    OpenFOAM初学者常常对于软件的使用流程感到很迷惑,与其他的具有GUI的CFD软件不同,OpenFOAM的所有操作均为基于文本操作,譬如说里面各种计算模型.计算参数.流程控制参数等,均为通过修改对 ...