坑1:

使用SQLiteOpenHelper的时候如果建立的表中存在不为空的字段,但是用ContentValues()的方式来插入数据的话恰好没有往这个字段里插入数据,那么执行后市没法往数据库里插入数据的。单是写在这里可能觉得这个问题很平常,下面以代码的形式展示出来。

MySqliteDatabase.java

 package com.jikexueyuan.hellonotes;

 import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper; public class MySqliteDatabase extends SQLiteOpenHelper {
public static final String _ID = "_id";
public static final String CONTENT = "content";
public static final String TIME = "time";
public static final String TABLE = "mydiary";
public static final String TABLE_DRAFT = "draft";
public static final String DATABASENAME = "wyldb.db"; public MySqliteDatabase(Context context, String name,
CursorFactory factory, int version) {
super(context, name, factory, version);
// TODO Auto-generated constructor stub } /**
* 三个参数的构造器
*
* @param context
* @param name
* @param factory
*/
public MySqliteDatabase(Context context) {
this(context, DATABASENAME, null, 1);
System.out.println("MySqliteDatabase.MySqliteDatabase()构造器,新建表:"
+ DATABASENAME + "...");
} @Override
public void onCreate(SQLiteDatabase db) {
// TODO Auto-generated method stub
System.out.println("MySqliteDatabase.onCreate(),创建表...");
db.execSQL("create table mydiary(_id integer primary key autoincrement,content text not null,time text not null)");
db.execSQL("create table draft(_id integer primary key autoincrement,content text not null,time text not null)");
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO Auto-generated method stub } }

DetailActivity.java

 package com.jikexueyuan.hellonotes;

 import java.text.SimpleDateFormat;
import java.util.Date; import android.app.Activity;
import android.content.ContentValues;
import android.content.Intent;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast; public class DetailActivity extends Activity implements OnClickListener {
EditText et_detail;
Button btn_edit, btn_delete, btn_detail_save;
String val; @Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.detail);
et_detail = (EditText) findViewById(R.id.et_detail);
btn_edit = (Button) findViewById(R.id.btn_edit);
btn_delete = (Button) findViewById(R.id.btn_delete);
btn_detail_save = (Button) findViewById(R.id.btn_detail_save);
btn_edit.setOnClickListener(this);
btn_delete.setOnClickListener(this);
btn_detail_save.setOnClickListener(this);
Intent intent = getIntent();
val = intent.getExtras().getString(FirstActivity.KEY_CONTENT);
if (!val.equals("") || val == null) {
// Toast.makeText(this, "获取的值不为空,已经设置,,", 0).show();
et_detail.setText(val);
et_detail.setSelection(val.length());// 设置光标到最后
} } @Override
public void onClick(View v) {
// TODO Auto-generated method stub
MySqliteDatabase db = new MySqliteDatabase(DetailActivity.this);
SQLiteDatabase sdb = db.getWritableDatabase();
switch (v.getId()) {
case R.id.btn_edit:
et_detail.setEnabled(true);// 设置文本克可编辑
// 可编辑的时候删除按钮隐藏,保存按钮可见
btn_delete.setVisibility(View.GONE);
btn_detail_save.setVisibility(View.VISIBLE);
System.out.println("===val:" + val + ",====");
// 同时还要删除
sdb.delete(MySqliteDatabase.TABLE, MySqliteDatabase.CONTENT + "=?",
new String[] { val });// 有报错,暂时不处理
break;
case R.id.btn_detail_save:
String content = et_detail.getText().toString();
ContentValues cv = new ContentValues(); SimpleDateFormat format = new SimpleDateFormat();
Date date = new Date();
String time = format.format(date);
cv.put(MySqliteDatabase.CONTENT, content);
/*
* 之前没有插入time这个值,但是因为这个表里的time字段不能够为空,导致下main的代码都
* 没正确执行,即不能够按照预期把文本内容插入到数据库。
*/
cv.put(MySqliteDatabase.TIME, time);
System.out.println("-----btn_detail_save:content= ----");
sdb.insert(MySqliteDatabase.TABLE, null, cv);
Intent intent = new Intent(DetailActivity.this, FirstActivity.class);
startActivity(intent);
finish();
break; default:
break;
}
}
}

具体代码:http://pan.baidu.com/s/1sjIJRit

坑2:viewpager与fragment一起用的时候,需要传入fragment作为参数,在自己的Fragment实现类中有一个必须复写的方法,

public View onCreateView(LayoutInflater inflater,
@Nullable ViewGroup container, @Nullable Bundle savedInstanceState){

}

,具体的坑如下:

 public class Fragment2 extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater,
@Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
// return inflater.inflate(R.layout.view2, container, true);
// 这里的第二个参数只能填写null,不能像上面一行注释的那样填写container,
// 否则会报错:The specified child already has a parent. You must call
// removeView() on the child's parent first.
return inflater.inflate(R.layout.view2, null, true);
}
}

同时也可以参见:http://blog.csdn.net/mcy478643968/article/details/26812225 ,具体源码可见百度网盘里的Wyl.rar。

关于android的坑的更多相关文章

  1. Android填坑—Error:Execution failed for task ':app:transformClassesWithDexForRelease'

    昨晚正在干着自己的事,另外一个同学说项目打包不了,但是可以debug运行.又急着需要打包apk发给那边人去测试.真的是搞事情,赶紧打开项目试试打包.项目从之前的$Eclipse$中转过来的,清楚的记得 ...

  2. Android爬坑之路

    做了那么久前端,现在终于可以回到我的老本行, 今天我用了一天的时间配置里Android开发环境,mac和windows双平台,eclipse和IDEA双平台,别问为什么,我就喜欢,中间大坑不断,再加上 ...

  3. Android填坑系列:在小米系列等机型上放开定位权限后的定位请求弹框

    背景: 近期因实际项目需要,在特定操作下触发定位请求,取到用户位置及附近位置. 问题: 经初步选型,最终决定接入百度定位,按照百度定位SDK Android文档,接入过程相对顺利.但随后发现,在小米系 ...

  4. Android爬坑之旅:软键盘挡住输入框问题的终极解决方案

    前言 开发做得久了,总免不了会遇到各种坑.而在Android开发的路上,『软键盘挡住了输入框』这个坑,可谓是一个旷日持久的巨坑--来来来,我们慢慢看. 入门篇 Base 最基本的情况,如图所示:在页面 ...

  5. ReactNative for Android入坑(一)

    最近找工作发现有些公司要求会ReactNative,决定入坑. 搭建环境:官网详细的教程附链接. 坑一:FQ,建议整个搭建过程中FQ.(FQ链接,注册有200M试用流量,环境搭建够了)第一步:安装Ch ...

  6. Android WebView坑摘要

    要抓好近期iPad HybridApp至Android举,坑遇到太多.让我折腾过Android临近4在退伍军人头痛! 今天前者被列出,以满足,然后慢慢自己解决.现在,它已经解决android键盘覆盖问 ...

  7. android 趟坑记

    又是一个伤感的故事,但阿古好像已经习以为常了. 大半年的辛苦又泡汤了,故事是这样. 帝都某高端小区,封闭局域网,做一个可视对讲+门禁的APP,之前那一版因为使用了商业代码,又不想花钱,于是找阿古换一个 ...

  8. Android填坑系列:Android JSONObject 中对key-value为null的特殊处理

    在与服务端通过JSON格式进行交互过程中,不同版本的JSON库在对于key-value为null情况上的处理不同. Android自带的org.json对key-value都要求不能为null,对于必 ...

  9. Android MonoGame坑记

    1.Content 加载声音API错误: 2.TouchPanel.GetState()属于抢占式的,用一次后面不能继续使用,否则状态尚属第一次: 3.TouchPanel 坐标来自于硬件本身: 4. ...

随机推荐

  1. JSP打印九九乘法表

    ##index.jsp: <%@ page language="java" import="java.util.*" pageEncoding=" ...

  2. Codeforces 706D Vasiliy's Multiset(可持久化字典树)

    [题目链接] http://codeforces.com/problemset/problem/706/D [题目大意] 要求实现一个集合中的三个操作,1:在集合中加入一个元素x,2:从集合中删除一个 ...

  3. 在美国,一名 Uber 司机能赚多少?

    在美国,Uber 司机是最热门的职业.有了 uberX,任何有车一族都能成为司机.Uber 让我们很容易成为司机. 虽然 Uber 做不到赚得盆满钵满,但对于水深火热的司机这一行来说,多了许多盈利机会 ...

  4. req.body取不到值的问题;

    随着express升级,bodyParser从express中被分离了出来,因此,在使用express新版本的时候,需要npm install body-parser 来安装bodyParser. 在 ...

  5. 用ahk脚本自己主动删除flashcookies

    手动方法(请戳点击打开链接): 点击桌面左下脚的"開始"键 打开"控制面板" 并点击 "flash player" 项 进入 并点击&quo ...

  6. 一步一步学c#(五):泛型

    泛型 性能 泛型的一个重要的优点是性能.system.collections和system.collections.generic名称空间的泛型和非泛型集和类.对值类型使用非泛型集合类,在把值类型转换 ...

  7. zoj 2966 Build The Electric System

    就是套了个prim算法就ac了 #include <stdio.h> #include <string.h> #define MaxInt 0x3f3f3f3f #define ...

  8. MSSQL数据库统计所有表的记录数

    今天需要筛选出来库中行数不为零的表,于是动手写下了如下存储过程. CREATE PROCEDURE TableCount AS BEGIN SET NOCOUNT ON ),RowsCount INT ...

  9. [Jobdu] 题目1511:从尾到头打印链表——单链表的倒置输出

    // ListNode typedef struct LNode { int key; struct LNode *next; }LNode;   分析:这是一道很有意思的面试题,此题以及此题的变体经 ...

  10. UVa1339 Ancient Cipher

    #include <iostream>#include <string>#include <cstring> // for memset#include <a ...