`
huiqinbo
  • 浏览: 354850 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

无废话Android 系列教程32 [创建SQLite数据库&测试:SQLiteOpenHelper]

 
阅读更多

1.  首先创建Android 项目工程, 创建的过程参照教程一。

2.  创建PersonSQLiteOpenHelper 类,同时继承SQLiteOpenHelper 抽象类

package com.andy.db;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

/**
 * 创建PersonSQLiteOpenHelper类 继承SQLiteOpenHelper抽象类,此时必须创建构造方法
 * @author huiqinbo
 *
 */
public class PersonSQLiteOpenHelper extends SQLiteOpenHelper {

	/**
	 * 数据库的构造方法, 用来定义数据库的名称/数据库的查询结果集/数据库的版本号
	 * @param context
	 * @param name
	 * @param factory
	 * @param version
	 */
	public PersonSQLiteOpenHelper(Context context) {
		super(context, "person.db", null, 1);
		// TODO Auto-generated constructor stub
	}
	
	

	/**
	 * 数据库第一次被创建的时候调用的方法
	 * @param db 被创建的数据库
	 */
	@Override
	public void onCreate(SQLiteDatabase db) {
		db.execSQL("create table person (id integer primary key autoincrement, name varchar(20), number varchar(20))");
	}

	@Override
	public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
		// TODO Auto-generated method stub

	}

}

 

3.  配置AndroidManifest.xml 文件

 

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.andy.db"
    android:versionCode="1"
    android:versionName="1.0" >

    <instrumentation
        android:name="android.test.InstrumentationTestRunner"
        android:targetPackage="com.andy.db" />
    
    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <uses-library android:name="android.test.runner" />
        <activity
            android:name="com.andy.db.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

 

注1: 在项目工程自动生成的配置文件中加入以下:

 

<instrumentation
        android:name="android.test.InstrumentationTestRunner"
        android:targetPackage="com.andy.db" />

 和

 <uses-library android:name="android.test.runner" />

 

否则会报以下错误:

数据库_SqlLite does not specify a android.test.InstrumentationTestRunner instrumentation or does not declare uses-library android.test.runner in its AndroidManifest.xml

 

4. 创建测试类"TestPersonDB",并继承"AndroidTestCase"类

package com.andy.db.test;

import com.andy.db.PersonSQLiteOpenHelper;

import android.test.AndroidTestCase;
/**
 * 运行过程如果报以下错误,说明没有配置测试环境
 * 数据库_SqlLite does not specify a android.test.InstrumentationTestRunner instrumentation or does not declare uses-library android.test.runner in its AndroidManifest.xml
 * @author HuiQinBo
 *
 */
public class TestPersonDB extends AndroidTestCase {
	
	/**
	 * getContext() 是测试框架给提供的上下文件
	 * 
	 * 来源:android.test.AndroidTestCase.getContext()
	 */
	public void testCreatePersonDb(){
		PersonSQLiteOpenHelper db = new PersonSQLiteOpenHelper(getContext());
		db.getWritableDatabase();
	}

}

 

 

5. 项目被创建图示:



 

 

测试Case成功图示:



 

 

通过DDMS 查看person表已被创建成功图示:



 

 

 

  • 大小: 116.8 KB
  • 大小: 728.9 KB
  • 大小: 927.9 KB
分享到:
评论

相关推荐

    无废话Android 系列教程33 [Adroid下SQLite数据库增删改查&测试]

    本教程将深入讲解如何在Android环境下进行SQLite数据库的增删改查操作以及相关的测试方法。 首先,我们需要创建一个SQLite数据库。在Android中,我们通常通过继承SQLiteOpenHelper类来实现这个功能。...

    无废话Android 系列教程34 [使用系统api实现SQLite增删改查&&测试]

    本教程将深入探讨如何使用系统API实现SQLite数据库的增删改查操作,并进行相关的测试。以下是对这个主题的详细讲解: 一、SQLite数据库基础 SQLite是Android系统内置的SQL数据库引擎,无需单独安装。开发者可以创建...

    cmd脚本-bat批处理-IIS最小权限分配.zip

    cmd脚本-bat批处理-IIS最小权限分配.zip

    冬奥会复杂山地百米尺度10...预报的机器学习订正对比试验_徐景峰.caj

    冬奥会复杂山地百米尺度10...预报的机器学习订正对比试验_徐景峰.caj

    基于Matlab实现的OFDM通信系统设计与仿真研究

    OFDM(正交频分复用)是一种高效的多载波通信技术,它将高速数据流拆分为多个低速子流,并通过多个并行的低带宽子载波传输。这种技术具有高频谱效率、强抗多径衰落能力和灵活的带宽分配优势。 OFDM系统利用大量正交子载波传输数据,子载波间的正交性可有效避免码间干扰(ISI)。其数学表达为多个离散子载波信号的线性组合,调制和解调过程通过FFT(快速傅立叶变换)和IFFT(逆快速傅立叶变换)实现。其关键流程包括:数据符号映射到子载波、IFFT转换为时域信号、添加循环前缀以减少ISI、信道传输、接收端FFT恢复子载波数据和解调原始数据。 Matlab是一种广泛应用于科研、工程和数据分析的高级编程语言和交互式环境。在OFDM系统设计中,首先需掌握Matlab基础,包括编程语法、函数库和工具箱。接着,根据OFDM原理构建系统模型,实现IFFT/FFT变换、循环前缀处理和信道建模等关键算法,并通过改变参数(如信噪比、调制方式)评估系统性能。最后,利用Matlab的绘图功能展示仿真结果,如误码率(BER)曲线等。 无线通信中主要考虑加性高斯白噪声(AWGN),其在频带上均匀分布且统计独立。通过仿真OFDM系统,可在不同信噪比下测量并绘制BER曲线。分析重点包括:不同调制方式(如BPSK、QPSK)对BER的影响、循环前缀长度选择对性能的影响以及信道估计误差对BER的影响。 OFDM技术广泛应用于多个领域,如数字音频广播(DAB)、地面数字电视广播(DVB-T)、无线局域网(WLAN)以及4G/LTE和5G移动通信,是这些通信标准中的核心技术之一。 深入研究基于Matlab的OFDM系统设计与仿真,有助于加深对OFDM技术的理解,并提升解决实际通信问题的能力。仿真得到的关键性能指标(如BER曲线)对评估系统可靠性至关重要。未来可进一步探索复杂信道条件下的OFDM性能及系统优化,以适应不同应用场景

    最新罗技鼠标宏一键导入即用

    最新罗技Lua鼠标宏,直接导入即可使用。相关教程视频可在导入文件中找到,视频链接为:罗技鼠标宏教程。

    基于51单片机电子时钟的Keil程序与Proteus仿真电路

    51单片机是电子工程领域常用的入门级微控制器,广泛应用于小型电子设备,例如电子时钟。本项目将介绍如何利用51单片机设计一款简单的电子时钟,并通过Keil软件进行程序开发,同时借助Proteus仿真工具进行电路模拟,帮助初学者掌握51单片机的基础应用。 51单片机基于Intel 8051内核,集成了CPU、RAM、ROM、定时器/计数器和I/O端口等功能模块,具有易于编程和性价比高的优势。在电子时钟项目中,主要利用其定时器实现时间的精确计算。Keil μVision是51单片机的常用开发环境,支持C语言和汇编语言编程。开发时,需编写代码以控制单片机显示和更新时间,包括初始化时钟硬件、设置定时器中断、编写中断服务程序以及与LCD显示屏交互等步骤。关键环节如下:一是初始化,配置时钟源(如外部晶振)设定工作频率;二是定时器设置,选择合适模式(如模式1或模式2),设置计数初值以获得所需时间分辨率;三是中断服务,编写定时器中断服务程序,定时器溢出时更新时间并触发中断;四是显示控制,通过I/O端口驱动LCD显示屏显示当前时间。 Proteus是一款虚拟原型设计软件,可用于模拟硬件电路,帮助开发者在编程前验证电路设计。在Proteus中,可搭建51单片机、LCD模块、晶振及电阻、电容等元件,形成电子时钟电路模型。运行仿真后,可观察程序在实际电路中的运行情况,及时发现并解决问题。 实际项目中,51单片机电子时钟还涉及以下知识点:一是时钟信号产生,定时器通过计数外部时钟脉冲实现时间累计,可通过调整晶振频率和定时器初始值设置不同时间间隔;二是LCD接口,需理解LCD的命令和数据传输协议,以及如何控制背光、显示模式、行列地址等;三是中断系统,了解中断概念、中断向量及程序中中断的启用和禁用方法;四是数码管显示,若使用数码管而非LCD,需了解其显示原理及段选、位选的驱动方式。 本项目融合了单片机基础、

    项目计划书模板.PPT

    项目计划书PPT

    SROMANS.SHX

    使用方法:拷贝到Auto CAD的Fonts下

    基于蚁群算法的机械臂三维路径规划避障仿真研究

    在机器人技术领域,机械臂的避障路径规划是一项关键任务,而本压缩包中的资源专注于利用蚁群算法解决三维空间中的路径规划问题。蚁群算法(Ant Colony Optimization,ACO)是一种仿生优化算法,其灵感来源于蚂蚁在寻找食物时的信息素沉积行为,能够有效找到全局最优解,尤其适合复杂路径规划。 蚁群算法由Marco Dorigo等人提出,模拟蚂蚁寻找食物路径时释放信息素的过程。在算法中,每条可能路径被视作“虚拟”蚂蚁的路径,蚂蚁在移动时会留下信息素。信息素浓度会随时间蒸发,同时被新经过的蚂蚁加强。通过迭代,算法优化路径选择,强化高效路径,最终找到全局最优解。 在机械臂避障路径规划中,三维空间路径规划尤为重要。为此,通常将三维空间划分为网格,每个小格子代表一种状态,如无障碍、障碍或未知。通过判断每个格子的状态,确定机械臂的可行移动区域,即“可视区域”。蚁群算法应用于该三维网格,寻找从起点到终点的最佳路径。每只蚂蚁在网格上随机移动时,会考虑信息素浓度和距离因素。高浓度信息素路径更易被选择,短距离路径更具吸引力。经过多次迭代,信息素逐渐积累在最优路径上,从而得出避开障碍物的最短路径。 实际应用中,机械臂路径规划需考虑运动学限制,如关节角度范围、速度限制等,同时实时性也至关重要,算法需快速生成新路径以适应动态环境。因此,蚁群算法常与其他优化方法结合,如遗传算法或粒子群优化,以提升计算效率和路径质量。 压缩包内文件可能包含算法源代码、数据结构定义、模拟环境设定及结果可视化等内容。通过这些资源,学习者可深入了解蚁群算法在机械臂避障路径规划中的实现,并直观理解三维路径规划。该应用涉及机器人学、计算机科学、控制理论等多学科交叉,通过仿真项目,既能加深对算法的理解,又能培养解决实际问题的能力。无论是学术研究还是工业应用,掌握这种路径规划方法都极具价值。

    cmd脚本-bat批处理-Autorun 病毒清除工具.zip

    cmd脚本-bat批处理-Autorun 病毒清除工具.zip

    cmd-bat-批处理-脚本-百钱买百鸡的买法.zip

    cmd-bat-批处理-脚本-百钱买百鸡的买法.zip

    cmd-bat-批处理-脚本-变色+翻滚字符.zip

    cmd-bat-批处理-脚本-变色+翻滚字符.zip

    25年上半年湖师大学位报考附件.zip

    25年上半年湖师大学位报考附件.zip

    cmd-bat-批处理-脚本-IE 界面批处理通讯录.zip

    cmd-bat-批处理-脚本-IE 界面批处理通讯录.zip

    cmd-bat-批处理-脚本-阿拉伯数字转为罗马数字.zip

    cmd-bat-批处理-脚本-阿拉伯数字转为罗马数字.zip

    cmd脚本-bat批处理-查看电脑硬件信息.zip

    cmd脚本-bat批处理-查看电脑硬件信息.zip

    cmd脚本-bat批处理-OptimizeXp.zip

    cmd脚本-bat批处理-OptimizeXp.zip

    cmd-bat-批处理-脚本-date.zip

    cmd-bat-批处理-脚本-date.zip

    【移动应用测试】Appium自动化测试框架详解:跨平台多语言支持及应用场景Appium这一开源

    内容概要:Appium 是一个开源的移动应用自动化测试框架,能够帮助开发者和测试人员自动完成对移动应用的测试工作,支持 iOS 和 Android 平台,并兼容多种编程语言(如 Java、Python、JavaScript 等)。它的主要优势包括跨平台的超强适应性、丰富的语言支持以及与持续集成工具的无缝融合。文章详细介绍了如何使用 Python 编写测试脚本,包括前期准备、编写脚本、执行和分析结果。此外,还探讨了 Appium 在功能测试、兼容性测试和回归测试中的应用场景,并指出了性能优化和维护成本方面的挑战及应对措施。 适合人群:具备一定编程基础,尤其是从事移动应用开发或测试工作的人员,包括初级到中级的开发者和测试工程师。 使用场景及目标:①跨平台自动化测试,减少针对不同平台编写独立测试脚本的工作量;②利用多语言支持,选择熟悉的语言编写测试脚本,降低学习成本;③通过与持续集成工具结合,提高测试效率,确保代码质量;④执行功能测试、兼容性测试和回归测试,保障应用在不同设备和版本上的稳定性和一致性。 阅读建议:本文不仅介绍了 Appium 的基本概念和优势,还提供了详细的使用指南和常见问题解决方案,建议读者结合实际项目需求逐步实践,特别是在构建和优化测试脚本时,注意性能调优和版本兼容性问题。

Global site tag (gtag.js) - Google Analytics