关于android的坑

  

坑1:

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

MySqliteDatabase.java

 1 package com.jikexueyuan.hellonotes;
 2 
 3 import android.content.Context;
 4 import android.database.sqlite.SQLiteDatabase;
 5 import android.database.sqlite.SQLiteDatabase.CursorFactory;
 6 import android.database.sqlite.SQLiteOpenHelper;
 7 
 8 public class MySqliteDatabase extends SQLiteOpenHelper {
 9     public static final String _ID = "_id";
10     public static final String CONTENT = "content";
11     public static final String TIME = "time";
12     public static final String TABLE = "mydiary";
13     public static final String TABLE_DRAFT = "draft";
14     public static final String DATABASENAME = "wyldb.db";
15 
16     public MySqliteDatabase(Context context, String name,
17             CursorFactory factory, int version) {
18         super(context, name, factory, version);
19         // TODO Auto-generated constructor stub
20 
21     }
22 
23     /**
24      * 三个参数的构造器
25      * 
26      * @param context
27      * @param name
28      * @param factory
29      */
30     public MySqliteDatabase(Context context) {
31         this(context, DATABASENAME, null, 1);
32         System.out.println("MySqliteDatabase.MySqliteDatabase()构造器,新建表:"
33                 + DATABASENAME + "...");
34     }
35 
36     @Override
37     public void onCreate(SQLiteDatabase db) {
38         // TODO Auto-generated method stub
39         System.out.println("MySqliteDatabase.onCreate(),创建表...");
40         db.execSQL("create table mydiary(_id integer primary key autoincrement,content text not null,time text not null)");
41         db.execSQL("create table draft(_id integer primary key autoincrement,content text not null,time text not null)");
42     }
43 
44     @Override
45     public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
46         // TODO Auto-generated method stub
47 
48     }
49 
50 }

DetailActivity.java

 1 package com.jikexueyuan.hellonotes;
 2 
 3 import java.text.SimpleDateFormat;
 4 import java.util.Date;
 5 
 6 import android.app.Activity;
 7 import android.content.ContentValues;
 8 import android.content.Intent;
 9 import android.database.sqlite.SQLiteDatabase;
10 import android.os.Bundle;
11 import android.view.View;
12 import android.view.View.OnClickListener;
13 import android.widget.Button;
14 import android.widget.EditText;
15 import android.widget.Toast;
16 
17 public class DetailActivity extends Activity implements OnClickListener {
18     EditText et_detail;
19     Button btn_edit, btn_delete, btn_detail_save;
20     String val;
21 
22     @Override
23     protected void onCreate(Bundle savedInstanceState) {
24         // TODO Auto-generated method stub
25         super.onCreate(savedInstanceState);
26         setContentView(R.layout.detail);
27         et_detail = (EditText) findViewById(R.id.et_detail);
28         btn_edit = (Button) findViewById(R.id.btn_edit);
29         btn_delete = (Button) findViewById(R.id.btn_delete);
30         btn_detail_save = (Button) findViewById(R.id.btn_detail_save);
31         btn_edit.setOnClickListener(this);
32         btn_delete.setOnClickListener(this);
33         btn_detail_save.setOnClickListener(this);
34         Intent intent = getIntent();
35         val = intent.getExtras().getString(FirstActivity.KEY_CONTENT);
36         if (!val.equals("") || val == null) {
37             // Toast.makeText(this, "获取的值不为空,已经设置,,", 0).show();
38             et_detail.setText(val);
39             et_detail.setSelection(val.length());// 设置光标到最后
40         }
41 
42     }
43 
44     @Override
45     public void onClick(View v) {
46         // TODO Auto-generated method stub
47         MySqliteDatabase db = new MySqliteDatabase(DetailActivity.this);
48         SQLiteDatabase sdb = db.getWritableDatabase();
49         switch (v.getId()) {
50         case R.id.btn_edit:
51             et_detail.setEnabled(true);// 设置文本克可编辑
52             // 可编辑的时候删除按钮隐藏,保存按钮可见
53             btn_delete.setVisibility(View.GONE);
54             btn_detail_save.setVisibility(View.VISIBLE);
55             System.out.println("===val:" + val + ",====");
56             // 同时还要删除
57             sdb.delete(MySqliteDatabase.TABLE, MySqliteDatabase.CONTENT + "=?",
58                     new String[] { val });// 有报错,暂时不处理
59             break;
60         case R.id.btn_detail_save:
61             String content = et_detail.getText().toString();
62             ContentValues cv = new ContentValues();
63 
64             SimpleDateFormat format = new SimpleDateFormat();
65             Date date = new Date();
66             String time = format.format(date);
67             cv.put(MySqliteDatabase.CONTENT, content);
68             /*
69              * 之前没有插入time这个值,但是因为这个表里的time字段不能够为空,导致下main的代码都
70              * 没正确执行,即不能够按照预期把文本内容插入到数据库。
71              */
72             cv.put(MySqliteDatabase.TIME, time);
73             System.out.println("-----btn_detail_save:content=  ----");
74             sdb.insert(MySqliteDatabase.TABLE, null, cv);
75             Intent intent = new Intent(DetailActivity.this, FirstActivity.class);
76             startActivity(intent);
77             finish();
78             break;
79 
80         default:
81             break;
82         }
83     }
84 }

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

 

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

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

}

,具体的坑如下:

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

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

posted @ 2015-11-03 16:55  Sunor  阅读(228)  评论(0编辑  收藏  举报