android sqlite中如何求和后赋值到TextView中

Macksensen 2018-06-25 09:31:03

Intent intent1 = getIntent();
String key1 = intent1.getStringExtra("one");
String sum_turnover = "select sum(turnover) from svalue where date like "+"'%" + key1 + "%'";
String sum_tc = "select sum(tc) from svalue where date like "+"'%" + key1 + "%'";
Cursor cursor1 = db.rawQuery(sum_turnover,null);
while ((cursor1.moveToNext())) {
String stu = cursor1.getString(4);
sturnover.setText(stu);
cursor1.close();

这是代码,但是运行后会报错,请问如何将sqlite查询求和后赋值呢
...全文
179 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq_40273284 2019-05-04
  • 打赏
  • 举报
回复
String stu = cursor1.getString(cursor1.getColumnIndex(“sum(turnover)”)); 你试试这样改能不能出来
本项目主要是对数据库进行增删改查操作 DBAdapter_mll类主要是对数据库进行操作的类 package bjedu.dky.mll; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteException; import android.database.sqlite.SQLiteOpenHelper; public class DBAdapter_mll { private final String DB_NAME="people.db";//定义类的变量 private final static String DB_TABLE="peopleinfo"; private final int DB_VERSION=1; public final static String KEY_ID="_id"; public final static String KEY_NAME="name"; public final static String KEY_AGE="age"; public final static String KEY_HEIGHT="height"; private final Context context; private SQLiteDatabase db; DBOpenHelper dbOpenHelper; public DBAdapter_mll(Context _context){//定义类的构造方法,给变量context赋值 this.context=_context; } public long insert(People_mll people){//创建插入方法,并给四个变量赋值 ContentValues newValues=new ContentValues(); newValues.put(KEY_NAME, people.name);//用put()方法将数据放入ContentValues对象 newValues.put(KEY_AGE, people.age); newValues.put(KEY_HEIGHT, people.height); return db.insert(DB_TABLE, null, newValues); } public long deleteOneData(long id) {//定义有参数删除方法 return db.delete(DB_TABLE,KEY_ID+"="+id,null);//根据传的id值来判断要删除的数据库的列,返回删除的条数 } public long deleteAllData() {//定义全部删除方法 return db.delete(DB_TABLE,null,null);//删除数据库所有的数据,返回删除的条数 } private People_mll [] convertToPeople(Cursor cursor){//定义People_mll类型的参数为游标类型的方法 int resultCounts=cursor.getCount();//获得返回记录的个数赋给变量 if(resultCounts==0||!cursor.moveToFirst()){//当记录的个数的值为0或指针指向第一条记录时,执行花括号的语句 return null; } People_mll[] peoples=new People_mll [resultCounts];//用People_mll类定义一个数组,数组的长度为记录的个数 for(int i = 0;i中的形参,并将peoples数组的值返回 } public People_mll[] queryIdData(long id){//定义一个类型为People_mll更新全部记录的方法 //用query方法返回游标Cursor对象 Cursor results=db.query(DB_TABLE, new String[]{KEY_ID,KEY_NAME,KEY_AGE,KEY_HEIGHT}, KEY_ID+"="+id, null, null, null, null); return this.convertToPeople(results); } public long upData(long id,People_mll people){//更新数据方法 ContentValues newValues=new ContentValues();//要插入的字段值 newValues.put(KEY_NAME, people.name);//用put()方法将数据放入ContentValues对象 newValues.put(KEY_AGE, people.age); newValues.put(KEY_HEIGHT, people.height); return db.update(DB_TABLE, newValues, KEY_ID+"="+id, null); } public void open() throws SQLiteException{//打开数据库 dbOpenHelper=new DBOpenHelper(context,DB_NAME,null,DB_VERSION); try { db= dbOpenHelper.getWritableDatabase();//向数据库写入数据获得一个可写入的SQliteDatabase对象 } catch (SQLiteException e){ db= dbOpenHelper.getReadableDatabase(); //从数据库读取数据 } } public void close(){//关闭数据库 if (db!=null){ close(); db=null; } } private static class DBOpenHelper extends SQLiteOpenHelper{//定义一个类主要实现数据库表的创建,数据更新功能 public DBOpenHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); // TODO Auto-generated constructor stub } //创建列名 private static final String DB_CREATE="create table "+DB_TABLE+"("+KEY_ID+ " integer primary key autoincrement,"+KEY_NAME+" text not null," +KEY_AGE+" integer,"+KEY_HEIGHT+" float);"; public void onCreate(SQLiteDatabase db) {//创建和初始化数据库的表的等数据库对象 并且初始化表的数据 // TODO Auto-generated method stub db.execSQL(DB_CREATE); } //当数据库的数据的值发生变化时 会调用此数据 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // TODO Auto-generated method stub db.execSQL("DROP TABLE IF EXITS"+DB_TABLE); onCreate(db); } } } package bjedu.dky.mll; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.EditText; import android.widget.TextView; import android.widget.Toast; public class SQLListDemoActivity extends Activity { DBAdapter_mll dbOpenHelper; public void onCreate(Bundle savedInstanceState) { dbOpenHelper =new DBAdapter_mll(this);//创建DBAdapter_mll类的对象 dbOpenHelper.open();//调用类的方法 super.onCreate(savedInstanceState); setContentView(R.layout.main); Button addButton=(Button)findViewById(R.id.addButton);//找到在xml文件的控件 Button allDeleteButton=(Button)findViewById(R.id.allDeleteButton); Button allXianShiButton=(Button)findViewById(R.id.allXianShiButton); Button idChaXunButton=(Button)findViewById(R.id.idChaXunButton); Button idDeleteButton=(Button)findViewById(R.id.idDeleteButton); Button idUpdataButton=(Button)findViewById(R.id.idUpdataButton); Button qingChuXianShiButton=(Button)findViewById(R.id.qingChuXianShiButton); final EditText ageEditText=(EditText)findViewById(R.id.ageEditText); final EditText heightEditText=(EditText)findViewById(R.id.heightEditText); final EditText idEditText=(EditText)findViewById(R.id.idEditText); final EditText nameEditText=(EditText)findViewById(R.id.nameEditText); final TextView shuChuTextView=(TextView)findViewById(R.id.shuChuTextView); final TextView resultTextView=(TextView)findViewById(R.id.resultTextView); addButton.setOnClickListener(new View.OnClickListener() {//给addButton添加事件监听 public void onClick(View v) { // TODO Auto-generated method stub People_mll people=new People_mll(); //首先判断输入框是否为空 if(nameEditText.getText().toString().equals("")|| ageEditText.getText().toString().equals("")||heightEditText.getText().toString().equals("")) { Toast.makeText(SQLListDemoActivity.this, "请输入要添加的数据", Toast.LENGTH_LONG).show();//弹出一个即时窗口 } else{//不为空时,将输入输入框的字符串赋给People_mll类的变量 people.name=nameEditText.getText().toString(); people.age=Integer.parseInt(ageEditText.getText().toString()); people.height=Integer.parseInt(heightEditText.getText().toString()); long colunm=dbOpenHelper.insert(people);//调用DBAdapter的方法,将people作为参数,将数据传入数据库 if(colunm==-1){ resultTextView.setText("添加失败");//重新设置TextView的值 }else{ resultTextView.setText("添加成功"); } } Toast.makeText(SQLListDemoActivity.this, "你点击了添加按钮", Toast.LENGTH_LONG).show(); } }); allDeleteButton.setOnClickListener(new View.OnClickListener() {//给全部删除按钮做事件监听 public void onClick(View v) { // TODO Auto-generated method stub shuChuTextView.setText(""); dbOpenHelper.deleteAllData();//调用DBAdapter类的方法 Toast.makeText(SQLListDemoActivity.this, "全部删除成功", Toast.LENGTH_LONG).show(); } }); idDeleteButton.setOnClickListener(new View.OnClickListener() {//全部删除按钮做事件监听 public void onClick(View v) { People_mll[] peoples=dbOpenHelper.queryAllData(); if(idEditText.getText().toString().equals("")){//判断id输入框是否有数据 Toast.makeText(SQLListDemoActivity.this, "请输入ID", Toast.LENGTH_LONG).show(); } else{//当输入框有数据时,再给id赋值 long id=Integer.parseInt(idEditText.getText().toString()); long colunm=dbOpenHelper.deleteOneData(id); if(colunm==0){//根据删除记录的条数判断是否删除成功 shuChuTextView.setText(""); resultTextView.setText("删除失败 数据库无此数据"); }else{ shuChuTextView.setText(""); resultTextView.setText("删除成功"); Toast.makeText(SQLListDemoActivity.this, "删除成功", Toast.LENGTH_LONG).show(); } } } }); allXianShiButton.setOnClickListener(new View.OnClickListener() {//给全部显示做事件监听 public void onClick(View v) { // TODO Auto-generated method stub People_mll[] peoples=dbOpenHelper.queryAllData(); if(peoples==null){//判断peoples是否有值 Toast.makeText(SQLListDemoActivity.this, "没有数据记录", Toast.LENGTH_LONG).show(); return ; } String mag =""; for(int i=0;i中的记录通过调用方法showAll()赋给mag,并显示在textView mag+=peoples[i].showAll()+"\n"; } shuChuTextView.setText(mag); resultTextView.setText("显示结果"); } }); idChaXunButton.setOnClickListener(new View.OnClickListener() {//给id查询做事件监听 public void onClick(View v) { // TODO Auto-generated method stub if(idEditText.getText().toString().equals(""))//判断id是否有值 { Toast.makeText(SQLListDemoActivity.this, "请输入要查询的id", Toast.LENGTH_LONG).show(); } else{//当id输入框有值时,再调用DBAdapter类的方法 long id=Integer.parseInt(idEditText.getText().toString()); People_mll[] peoples=dbOpenHelper.queryIdData(id); if(peoples==null){//判断peoples是否有值 shuChuTextView.setText(""); resultTextView.setText("查询失败 数据库无此数据"); }else{ shuChuTextView.setText("查询结果"); shuChuTextView.setText(peoples[0].showAll());//将查询结果显示在TextView } } Toast.makeText(SQLListDemoActivity.this, "你点击了ID查询按钮", Toast.LENGTH_LONG).show(); } }); idUpdataButton.setOnClickListener(new View.OnClickListener() {//id更新按钮做事件监听 public void onClick(View v) { // TODO Auto-generated method stub People_mll people=new People_mll(); //判断输入框是否有值 if(nameEditText.getText().toString().equals("")||idEditText.getText().toString().equals("")|| ageEditText.getText().toString().equals("")||heightEditText.getText().toString().equals("")) { Toast.makeText(SQLListDemoActivity.this, "请完整输入要添加的数据", Toast.LENGTH_LONG).show(); } else//当输入框都有值时,再将输入框的值传入数据库 { long id=Integer.parseInt(idEditText.getText().toString()); people.name=nameEditText.getText().toString(); people.age=Integer.parseInt(ageEditText.getText().toString()); people.height=Integer.parseInt(heightEditText.getText().toString()); long colunm=dbOpenHelper.upData(id, people);//调用DBAdapter类的方法 if(colunm==-1){//根据更新记录的条数判断是否更新成功 resultTextView.setText("更新失败"); }else{ resultTextView.setText("修改"+String.valueOf(colunm)+"条记录成功"); } } Toast.makeText(SQLListDemoActivity.this, "你点击了ID更新按钮", Toast.LENGTH_LONG).show(); } }); qingChuXianShiButton.setOnClickListener(new View.OnClickListener() {//为清除按钮做事件监听 public void onClick(View v) { shuChuTextView.setText("");//清除shuChuTextView的数据记录 resultTextView.setText("清除成功"); Toast.makeText(SQLListDemoActivity.this, "清除成功", Toast.LENGTH_LONG).show(); } }); } } package bjedu.dky.mll; public class People_mll {//创建一个类,主要定义变量 public String name; public float height; public int age; public int id=-1; public String showAll(){//定义一个将变量都加到一个字符串方法,并将这个字符串的值返回 String all; all="ID:"+this.id+" 姓名:"+this.name+" 年龄:"+this.age+" 身高:"+this.height; return all; } }

2,209

社区成员

发帖
与我相关
我的任务
社区描述
其他数据库开发 其他数据库
社区管理员
  • 其他数据库社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧