首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在Android中创建本地数据库?

如何在Android中创建本地数据库?
EN

Stack Overflow用户
提问于 2016-01-12 06:29:09
回答 1查看 512关注 0票数 1

当我试图创建一个数据库时,我面临着一个问题.我想我在android中创建DB的过程中做错了什么。我也搜索网页,但没有找到任何好的线索。这是我的代码:

代码语言:javascript
运行
复制
     package com.example.raqib.database;

        import android.database.Cursor;
        import android.database.sqlite.SQLiteDatabase;
        import android.os.Bundle;
        import android.support.design.widget.FloatingActionButton;
        import android.support.design.widget.Snackbar;
        import android.support.v7.app.AppCompatActivity;
        import android.support.v7.widget.Toolbar;
        import android.util.Log;
        import android.view.Gravity;
        import android.view.View;
        import android.widget.Button;
        import android.widget.EditText;
        import android.widget.Toast;

        public class MainActivity extends AppCompatActivity  implements View.OnClickListener {

            static EditText stName;
            static EditText stRollNo;
            static EditText stSem;
            Button enterDB;
            private Object context;


            // creating database



            @Override
            protected void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.activity_main);
                Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
                setSupportActionBar(toolbar);


                getIntent();


                FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
                fab.setOnClickListener(new View.OnClickListener() {
                    @Override
                    public void onClick(View view) {
                        Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                                .setAction("Action", null).show();
                    }
                });
            }


            public void enterDetails(View view) {

                stName = (EditText) findViewById(R.id.stName);

                stRollNo = (EditText) findViewById(R.id.stRollNo);

                stSem = (EditText) findViewById(R.id.stSem);

                enterDB = (Button) findViewById(R.id.enterDB);
                enterDB.setOnClickListener(this);

            }

            public void onClick(View v){

                String st_Name = stName.getText().toString();
                int st_RollNo = Integer.parseInt(stRollNo.getText().toString());
                String st_sem = stSem.getText().toString();




               SQLiteDatabase db = openOrCreateDatabase("database", MODE_PRIVATE, null);
               db.execSQL("create table if not exists student (name varchar, roll_no int(4), semester varchar);");
            //   db.execSQL("insert into student( name , roll_no , semester )" + "values"+" ('"+ st_Name + "'," + st_RollNo + ",'" +st_sem + "');");


ContentValues values = new ContentValues();
values.put("name", st_Name); 
values.put("roll_no", st_RollNo); values.put("semester", st_sem); db.insert("student", null, values);



                Cursor cursor = db.rawQuery("select * from student", null);
                cursor.moveToFirst();
                Log.e("Name : ", cursor.getString(cursor.getColumnIndex("name")));

                Toast toast = Toast.makeText(MainActivity.this, " WOW! Successfully entered data in Database", Toast.LENGTH_LONG);
                toast.setGravity(Gravity.CENTER,0, 0);
                toast.show();


               // student registeredData = new student(st_Name,st_RollNo,st_sem);
            }



        }

**我面临的错误是:它显示的是st_Name,而不是它的值:

代码语言:javascript
运行
复制
Log.e("Name : ", cursor.getString(cursor.getColumnIndex("name")));

**

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-01-12 06:32:58

你应该读一些关于SQLiteOpenHelper的东西。在安卓系统中使用SQLite数据库是一种更好的方法。

但是对于您的情况,您忘记了用'包装文本值。

代码语言:javascript
运行
复制
db.execSQL("insert into student( name , roll_no , semester )" + " values "+
"('"+ st_Name + "'," + st_RollNo + ",'" +st_sem + "');");

避免此类问题的android方法是将值设置为在ContentValues对象中插入并使用数据库的插入函数:

代码语言:javascript
运行
复制
ContentValues values = new ContentValues();
values.put("name", st_Name);
values.put("roll_no", st_RollNo);
values.put("semester", st_sem);
db.insert("student", null, values);

或者你可以使用预先准备好的陈述:

代码语言:javascript
运行
复制
SQLiteStatement stmt = db.compileStatement("insert into student( name , roll_no , semester ) values (?,?,?);");
stmt.bindString(1, st_Name);
stmt.bindInt(1, st_RollNo);
stmt.bindString(1, st_sem);
stmt.execute();

Insert函数以及使用准备好的语句是插入数据的更安全的方法。他们将采取转义字符串,并将其以正确的格式。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34736938

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档