Xamarin.Android 本地数据库 SQLiteDatabase 操作

简介: 目的:使用 SQLiteDatabase 创建本地数据库、表,并对数据进行增删改查操作。引用命名空间:using Android.App;using Android.Widget;using Android.

目的:使用 SQLiteDatabase 创建本地数据库、表,并对数据进行增删改查操作。

引用命名空间:

using Android.App;
using Android.Widget;
using Android.OS;
using Android.Database.Sqlite;
using Android.Content;
using System.IO;
using System.Data;
using Mono.Data.Sqlite;
using System;
using Android.Database;
using System.Collections.Generic; 

Person类

public class Person
{
    public string Id { get; set; }
    public string Name { get; set; }
    public string IdCard { get; set; }
    public string Sex { get; set; }
    public string Age { get; set; }
}

创建局部变量Localhost_DataBase,以及控件,model类

SQLiteDatabase Localhost_DataBase = null;

Person person; 
List<Person> list = new List<Person>(); 
ListView lv_Person;

创建数据库

/// <summary>
/// 创建数据库
/// </summary>
void CreateDataBase()
{
    try
    {
        //打开或创建数据库 名称为:AssetsManage.db
        Localhost_DataBase = OpenOrCreateDatabase("AssetsManage.db", FileCreationMode.Private, null);

        //判断是否存在数据库
        if (string.IsNullOrEmpty(GetSharedPreferences("AssetsManage", 0).GetString("AssetsManage", "")))//未创建数据库
        {
            File.Create(Localhost_DataBase.Path);
            //继续创建数据表
            CreateTable();
            //存取已创建数据库信息
            GetSharedPreferences("AssetsManage", 0).Edit().PutString("AssetsManage", "OK").Commit();
        }
    }
    catch
    {
        //存取创建数据库时的异常
        GetSharedPreferences("Exception", 0).Edit().PutString("DataBaseException", "异常").Commit();
    }
}

创建表

/// <summary>
/// 创建表
/// </summary>
void CreateTable()
{
    string db = Localhost_DataBase.Path;
    var conn = new SqliteConnection("Data Source=" + db);
    //这里可以创建多张表
    var commands = new[] { 
                    "CREATE TABLE tb_person (Id int,name varchar(20),sex varchar(80),age varchar(20),idcard varchar(18))",

                    "CREATE TABLE tb_grade (uId int,mathgrade varchar(5),Chinese varchar(5),English varchar(5))"
    };
    try
    {
        foreach (var cmd in commands)
        {
            using (var sqlitecmd = conn.CreateCommand())
            {
                sqlitecmd.CommandText = cmd;
                sqlitecmd.CommandType = CommandType.Text;
                conn.Open();
                sqlitecmd.ExecuteNonQuery();
                conn.Close();
            }
        }

        InsertData();
    }
    catch (System.Exception e)
    {
        //存取创建数据表时的异常
        GetSharedPreferences("Exception", 0).Edit().PutString("DataTableException", "异常").Commit();
    }
}

向表中插入模拟数据

/// <summary>
/// 插入数据
/// </summary>
void InsertData()
{
    for(int i=1;i<=10;i++)
    {  
        ContentValues cv = new ContentValues();
        cv.Put("Id", i.ToString());
        cv.Put("name", "张三" + i.ToString());
        cv.Put("sex", new Random().Next(1, 2) == 1 ? "" : "");
        cv.Put("age", (20 + i).ToString());
        cv.Put("idcard", "21072619971111111" + (i - 1).ToString());
        Localhost_DataBase.Insert("tb_person", null, cv);

        ContentValues cv1 = new ContentValues();
        cv1.Put("uId", i);
        cv1.Put("mathgrade", new Random().Next(1, 100));
        cv1.Put("Chinese", new Random().Next(1, 100));
        cv1.Put("English", new Random().Next(1, 100));
        Localhost_DataBase.Insert("tb_grade", null, cv1);
    }
}

查询表中数据

/// <summary>
/// 查询数据
/// </summary>
void QueryData()
{
    ICursor ic =  Localhost_DataBase.Query("tb_person", null, null, null, null, null, null);    //全部查询 
    //ICursor ic = Localhost_DataBase.Query("tb_person", null, " id =? and name =?", new string[] { "1","张三1" }, null, null, null);    //条件查询
    for (int i = 0; i < ic.Count; i++)
    {
        if (i == 0)             //确定游标位置
        {
            ic.MoveToFirst();
        }
        else
        {
            ic.MoveToNext();
        }

        person = new Person(); 
        person.Id = ic.GetString(ic.GetColumnIndex("Id")); 
        person.Name = ic.GetString(ic.GetColumnIndex("name"));
        person.Age = ic.GetString(ic.GetColumnIndex("age"));
        person.Sex= ic.GetString(ic.GetColumnIndex("sex"));
        person.IdCard = ic.GetString(ic.GetColumnIndex("idcard")); 
        list.Add(person); 
    }
    lv_Person.Adapter = new ListViewAdapter(this, list);
}

根据条件删除表中数据

/// <summary>
/// 删除数据
/// </summary>
/// <param name="id"></param>
void DeleteData(string id)
{
    Localhost_DataBase.Delete("tb_person", " Id=?", new string[] { id });
    //Localhost_DataBase.Delete("tb_person", null, null);       //删除表中所有数据
}

根据条件修改表中数据

/// <summary>
/// 修改数据
/// </summary>
/// <param name="name"></param>
void UpdateData(string id)
{
    ContentValues cv = new ContentValues();
    cv.Put("name", "张三1000");
    Localhost_DataBase.Update("tb_person", cv, " Id=?  ", new string[] { id });
}

ListViewAdapter 类

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;

namespace LocalhostDataBaseTest
{
    public class ListViewAdapter:BaseAdapter<Person>
    {
        Activity context;
        public List<Person> mings;

        public ListViewAdapter(Activity context, List<Person> mings)
        {
            this.context = context;
            this.mings = mings;
        }

        public override int Count
        {
            get
            {
                return this.mings.Count;
            }
        }

        public override long GetItemId(int position)
        {
            return position;
        }

        public override Person this[int position]
        {
            get
            {
                return this.mings[position];
            }
        }

        public override View GetView(int position, View convertView, ViewGroup parent)
        {
            var itme = this.mings[position];

            convertView = LayoutInflater.From(context).Inflate(Resource.Layout.Person_Items, parent, false);

            TextView item_id = convertView.FindViewById<TextView>(Resource.Id.item_id);
            TextView item_name = convertView.FindViewById<TextView>(Resource.Id.item_name);
            TextView item_idcard = convertView.FindViewById<TextView>(Resource.Id.item_idcard);
            TextView item_sex = convertView.FindViewById<TextView>(Resource.Id.item_sex);
            TextView item_age = convertView.FindViewById<TextView>(Resource.Id.item_age);

            item_id.Text = (position + 1).ToString();
            item_name.SetText(itme.Name, TextView.BufferType.Normal);
            item_idcard.SetText(itme.IdCard, TextView.BufferType.Normal);
            item_sex.SetText(itme.Sex, TextView.BufferType.Normal);
            item_age.SetText(itme.Age, TextView.BufferType.Normal); 

            return convertView;
        }
    }
}

OnCreate调用

protected override void OnCreate(Bundle savedInstanceState)
{
    base.OnCreate(savedInstanceState);

    // Set our view from the "main" layout resource
    SetContentView(Resource.Layout.Main);

    lv_Person = FindViewById<ListView>(Resource.Id.listViewPerson);
    CreateDataBase();
    DeleteData("10");
    UpdateData("9");
    QueryData();
}

到这里就结束了,那里写的不足希望大家补充~ 

链接: https://pan.baidu.com/s/1QhDkfSXyVlmWEnIU6VGy-g

密码: isa8

目录
相关文章
|
7月前
|
XML Java 数据库连接
【MyBatis】MyBatis操作数据库(一)
【MyBatis】MyBatis操作数据库(一)
65 1
|
6月前
|
Oracle 关系型数据库 Java
实时计算 Flink版操作报错合集之cdc postgres数据库,当表行记录修改后报错,该如何修改
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
6月前
|
SQL 监控 关系型数据库
实时计算 Flink版操作报错合集之在设置监控PostgreSQL数据库时,将wal_level设置为logical,出现一些表更新和删除操作报错,怎么办
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
6月前
|
关系型数据库 Java 数据库
实时计算 Flink版操作报错合集之flinksql采PG数据库时报错,该如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
6月前
|
关系型数据库 MySQL 数据库
实时计算 Flink版操作报错合集之在处理PostgreSQL数据库遇到报错。该如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
6月前
|
消息中间件 关系型数据库 数据库
实时计算 Flink版操作报错合集之在使用RDS数据库作为源端,遇到只能同步21个任务,是什么导致的
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
6月前
|
SQL 数据库 Python
Django框架数据库ORM查询操作(6)
【7月更文挑战第6天】```markdown Django ORM常用数据库操作:1) 查询所有数据2) 根据ID查询 3) 精确查询 4) 分页排序
101 1
|
7月前
|
Java Devops API
阿里云云效操作报错合集之云效页面提示数据库保存不进去,该怎么办
本合集将整理呈现用户在使用过程中遇到的报错及其对应的解决办法,包括但不限于账户权限设置错误、项目配置不正确、代码提交冲突、构建任务执行失败、测试环境异常、需求流转阻塞等问题。阿里云云效是一站式企业级研发协同和DevOps平台,为企业提供从需求规划、开发、测试、发布到运维、运营的全流程端到端服务和工具支撑,致力于提升企业的研发效能和创新能力。
|
7月前
|
分布式计算 大数据 数据处理
MaxCompute操作报错合集之odps数据库T1有几百行的数据,为什么出来只有5行的数据
MaxCompute是阿里云提供的大规模离线数据处理服务,用于大数据分析、挖掘和报表生成等场景。在使用MaxCompute进行数据处理时,可能会遇到各种操作报错。以下是一些常见的MaxCompute操作报错及其可能的原因与解决措施的合集。
|
6月前
|
存储 监控 安全
安全规范问题之跟数据库交互涉及的敏感数据操作需要有哪些措施
安全规范问题之跟数据库交互涉及的敏感数据操作需要有哪些措施

热门文章

最新文章