android 中操作SQLite数据库

SQLiteOpenHelper类 SQLiteOpenHelper是SQLiteDatabase的一个帮助类,用来管理数据库的创建和版本的更新。一般是建立一个类继承它,并实现它的onCreate和onUpgrade方法。 SQLiteOpenHelper(Context context,String name,SQLiteDatabase.CursorFactory factory,int version) 构造方法,一般是传递一个要创建的数据库名称那么参数 onCreate(SQLiteDatabase db) 创建数据库时调用 onUpgrade(SQLiteDatabase db,int oldVersion , int newVersion) 版本更新时调用 getReadableDatabase() 创建或打开一个只读数据库 getWritableDatabase( ...

SQLite

注意点 绝大多数大小写不敏感 存储类型 NULL 空值。 INTEGER 有符号整数,根据值的大小以1,2,3,4,6 或8字节存储。 REAL 浮点数,以8字节 IEEE 浮点数存储。 TEXT 文本字符串,使用数据库编码(UTF-8, UTF-16BE 或 UTF-16LE)进行存储。 BLOB 一个数据块,按它的输入原样存储。 不同的数据类型在存储后会转换为存储类型, 在读取后在转换为一般的数据类型, 所以在定义时可以使用常见的其它数据库的类型 SQL 语法 SELECT – 从数据库表中获取数据 UPDATE – 更新数据库表中的数据 DELETE – 从数据库表 ...

数据库事务

批量操作需要使用事务以节省时间 同一类型的数据库操作, 每一次操作都去打开关闭数据库会比较耗时, 此时使用事务的方式去操作数据库, 会将操作暂时缓存起来, 在最后执行时只需要打开一次数据库, 会大大的减少操作时间 新建一个列表存操作 ArrayList<ContentProviderOperation> operations = new ArrayList<ContentProviderOperation>(); 1 ArrayList<ContentProviderOperation> operations = new ArrayList<ContentProviderOperat ...

ViewStub

ViewStub 与 View.GONE 的比较 ViewStub延迟加载指定的布局, 比View.GONE节省资源, 在显示之前是不占用资源的 使用View.GONE属性布局在界面加载时仍会创建对象, 耗费内存 ViewStub 的显示 ViewStub在界面加载时不创建, 设置可见或.inflate();才会创建并显示里面的内容 ViewStub对象只可以使用inflate()一次, 即开始占用内存 在ViewStub在界面上创建之前调用它的布局中的控件(findViewById)会出错 android:id在ViewStub不可见前使用(可见后失效), android:inflatedId 在可见之后使用 使用例子 布局文件中 ...

通过 selector 资源自动改变文字颜色

一: 在 drawable 文件夹下新建xml文件 通过不同的状态自动选择颜色 text_color.xml xml <?xml version="1.0" encoding="utf-8"?> <item android:color="@color/text_blue_color" android:state_pressed="true"/> <item android:color="@color/text_defu_color"/> 12 <item android:color="@color/text_blue_color" android:state_pressed="true"/><item android:color="@color/text_defu_color"/> ...

eclipse 使用

报错: 导入项目已存在

Some projects cannot be imported because they already exist in the workspace

今天想导入一个项目A, 这个项目A是在项目B的基础上改的, 已经修改了项目A的包名, 在我的PC笔记本上两个项目可以同时存在, 当我想将项目A导入我的Macbook上时, 提示已存在, 项目B已在我的工作区内。
最后通过查资料发现eclipse可以通过项目下的 .project 的 name 标签区分不同的项目, 自己的项目A的 name 确实还是项目B的 name。改了之后可以顺利导入。

MarkDown语法

在不同的MarkDown编辑器上显示可能存在差异 标题 用#表示,几个#号就是几级标题 一级标题字号最大 #号后面添加一个空格 列表 无序列表 前面加上“-”或“*” 有序列表 前面加上“1.”,“2.” 一个缩进一级列表 符号后面打一个空格 引用 在文本前加入 > 这种尖括号(大于号) 引用里的引用 >> (两个) 引用里的其他标识符同样可用 图片与链接 插入链接与插入图片的语法很像,区别在一个 !号 图片为:[](){ImgCap}{/ImgCap} 链接为: 显示的人文本 [ 默认显示的文本] 粗体与斜体 Markdown 的粗体和斜体也 ...

android插件化开发一

类加载器 DexClassLoader 加载sdcard目录下的apk或jar文件 PathClassLoader 加载路径必须在/data/app路径下 注意点 同一个Class = 相同的 ClassName + PackageName + ClassLoader DexClassLoader构造参数需要一个父加载器, 在父加载器里找不到类时,再从子加载器里加载 DexClassLoader调用loadClass方法加载指定类 代码示例 加载apk里的一个类里的一个方法 插件apk // package com.example.plug; public class GetPlug { public int getAdd(int a, int b) { return a + b; ...