Android SQLite无法查询数据

Android SQLite无法查询数据,可以正常插入数据,也提示插入成功了,但是执行下列语句输入的英文字符,却总是会查出来数字,不是字符。。第一次接触这个,不清楚是怎么回事请帮忙说的详细点,谢谢。。
package com.example.path_n;
//主类
import java.sql.Date;
import java.text.SimpleDateFormat;
import java.util.Random;

import org.w3c.dom.Text;

import junit.framework.Test;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Button;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;


public class MainActivity<person> extends Activity {

private DatebaseHelper dbHelper;
private TextView txtMsg;
//public EditText edi=new EditText(this);
private static final String DATABASE_NAME="mdb1.db";
private static final String TABEL_NAME="EMP_T";
private static final int DATABASE_VERSION=1;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        final EditText edi=new EditText(this);
        //TextView txtMsg;
        // STATR 建表及数据库
        dbHelper = new DatebaseHelper(this, DATABASE_NAME, null,
        DATABASE_VERSION);
        txtMsg = (TextView) this.findViewById(R.id.textView1);
        Button btn1 = (Button) this.findViewById(R.id.button1);
        btn1.setText("初始化");
        btn1.setOnClickListener(new Button.OnClickListener() {
        public void onClick(View v) {
        CreateTable();
        }}
        );
        //END
        
        //statr 表操作  
        Button btn2 = (Button) this.findViewById(R.id.button2);
        btn2.setText("插入 记录");
        btn2.setOnClickListener(new Button.OnClickListener() {
        public void onClick(View v) {
         String str=edi.getText().toString();
         if(!(str==""||str==null)){
        insertItem(str);}else{txtMsg.setText(str+"is error");}
        }
        });
        
        
        Button btn3 = (Button) this.findViewById(R.id.button3);
        btn3.setText("显示数据");
        btn3.setOnClickListener(new Button.OnClickListener() {
        public void onClick(View v) {
         String str=edi.getText().toString();
         if(str!=""||str!=null){
         showItems(str);
         }else{
         txtMsg.setText(str+"is error");
        }
        }
        });
        
        Button btn4 = (Button) this.findViewById(R.id.button4);
        btn4.setText("删除记录");
        btn4.setOnClickListener(new Button.OnClickListener() {
        public void onClick(View v) {
        deleteItem();
        }
        });

        
        //end
    }


    protected void deleteItem() {
// TODO Auto-generated method stub

}


protected void showItems(String str) {
// TODO Auto-generated method stub
     SQLiteDatabase db = dbHelper.getReadableDatabase();
     String sql="name = "+"'"+str+"'";
     /*try{
     Cursor c = db.rawQuery("select * from emp_t where name=?",new String[]{str});
     while(c.moveToNext()){
     if(c.getCount()>0){
     String name=c.getString(c.getColumnIndex("name"));
     String data=c.getString(c.getColumnIndex("data"));
     txtMsg.setText(name+","+data);
     }else{
     insertItem(str);
     txtMsg.setText("ok");
     }
     }
     //db.execSQL(sql);
     }catch(SQLException ex){
         txtMsg.setText("读取数据失败\n" + ex.toString() + "\n");
     }*/
     try {
     String[] column = { "id", "name"};
     Cursor cursor = db.query(TABEL_NAME, column, sql, null, null,
     null, null);
     Integer num = cursor.getCount();
     txtMsg.append("共 " + Integer.toString(num) + " 条记录\n");
if(cursor!=null){
     if(cursor.moveToFirst()){
     do{
                //int id = cursor.getColumnCount();
                 String name=cursor.getString(cursor.getColumnIndexOrThrow("NAME")); 
                 txtMsg.setText(name);
     }while(cursor.moveToNext());
     }
}
     /*while (cursor.getPosition() != cursor.getCount()) {
     txtMsg.setText(Integer.toString(cursor.getPosition()) + ","
     + cursor.getString(0) + ","
     + cursor.getColumnIndex("name")  + "\n");
     cursor.moveToNext();
     }*/
     } catch (SQLException ex) {
     txtMsg.setText("读取数据失败\n" + ex.toString() + "\n");
     }  

}


protected void insertItem(String text) {
// TODO Auto-generated method stub
     SQLiteDatabase db = dbHelper.getWritableDatabase();
     //String str=edi.getText().toString();
     //if(str==""||str==null){str="TEST1";}
     try {
     // _execSQL() - 执行指定的 sql
     String sql="insert into "+TABEL_NAME+" (name) values ('"+text+"')";
     db.execSQL(sql);
    
     txtMsg.setText("成功插入 数据\n");
     } catch (SQLException ex) {
     txtMsg.setText("插入数据失败\n" + ex.toString() + "\n");
     }
     }


/*Random random = new Random();
for (int i = 0; i < 3; i++) {
String sql = "insert into " + TABEL_NAME
+ " (name, age) values ('name" + String.valueOf(i)
+ "', " + random.nextInt() + ")";*/

protected void CreateTable() {
// TODO Auto-generated method stub
     SQLiteDatabase db = dbHelper.getWritableDatabase();
   
     String sql = "CREATE TABLE IF NOT EXISTS " + TABEL_NAME
     + " (ID INTEGER PRIMARY KEY, Name TEXT);";
     try {
     db.execSQL(sql);
     txtMsg.setText("数据表成功创建\n");
     } catch (SQLException ex) {
     txtMsg.setText("数据表创建错误\n" + ex.toString() + "\n");
     }
}


@Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }
    
}
//DB类
package com.example.path_n;

import android.content.Context;
//import android.database.DatabaseErrorHandler;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase.CursorFactory;

public class DatebaseHelper extends SQLiteOpenHelper {

public DatebaseHelper(Context context, String name, CursorFactory factory,
int version) {
super(context, name, factory, version);
// TODO Auto-generated constructor stub
}

@Override
public void onCreate(SQLiteDatabase arg0) {
// TODO Auto-generated method stub

}

@Override
public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
// TODO Auto-generated method stub

}
public void onOpen(SQLiteDatabase db){
super.onOpen(db);
}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值