2024年安卓最新实例教程六:创建数据库与完成数据添删改查--第一种写法,面试大厂应该注意哪些问题及答案

尾声

开发是需要一定的基础的,我是08年开始进入Android这行的,在这期间经历了Android的鼎盛时期,和所谓的Android”凉了“。中间当然也有着,不可说的心酸,看着身边朋友,同事一个个转前端,换行业,其实当时我的心也有过犹豫,但是我还是坚持下来了,这次的疫情就是一个好的机会,大浪淘沙,优胜劣汰。再等等,说不定下一个黄金浪潮就被你等到了。

  • 330页 PDF Android核心笔记

  • 几十套阿里 、字节跳动、腾讯、华为、美团等公司2020年的面试题

  • PDF和思维脑图,包含知识脉络 + 诸多细节

  • Android进阶系统学习视频

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

    }



    public void setPhone(String phone) {



            this.phone = phone;



    }        

}




package cn.itcast.service;

import android.content.Context;

import android.database.sqlite.SQLiteDatabase;

import android.database.sqlite.SQLiteOpenHelper;

public class DBOpenHelper extends SQLiteOpenHelper{

    private static final int VERSION = 2; //数据库版本

    

    public DBOpenHelper(Context context){

             super(context, "itcast.db", null, VERSION); //<包>/database/



    }



    @Override



    public void onCreate(SQLiteDatabase db) { //是在数据库第一次被创建的时候调用的



            db.execSQL("CREATE TABLE person(personId integer primary key autoincrement, " + "name varchar(20))");                

    }



    @Override



    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { //数据库版本号发生改变的时候调用的

             db.execSQL("ALTER TABLE person ADD phone VARCHAR(12) NULL");



    }

}




package cn.itcast.service;

import java.util.ArrayList;

import java.util.List;

import android.content.Context;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

import cn.itcast.domain.Person;

public class PersonService {

    private DBOpenHelper dbOpenHelper;      

    public PersonService(Context context){



            this.dbOpenHelper = new DBOpenHelper(context); 

    } 

    

    /\*\* 

     \* 添加记录 

     \* @param person 

     \*/



    public void save(Person person){



            SQLiteDatabase db \= dbOpenHelper.getWritableDatabase(); 

            db.execSQL("insert into person(name, phone) values(?, ?)",new Object\[\]{person.getName(), person.getPhone()});



            //如果只在一个类中使用db,则不需要关闭,提高性能

             //但是若是多处使用,则需要关闭

// db.close();

     } 

    

    /\*\*

      \* 删除记录 

     \* @param id 记录ID 

     \*/



    public void delete(Integer id){



            SQLiteDatabase db \= dbOpenHelper.getWritableDatabase(); 

            db.execSQL("delete from person where personId=?", new Object\[\]{id});



    }

    

    /\*\*

      \* 更新记录

      \* @param person

     \*/



    public void update(Person person){



            SQLiteDatabase db \= dbOpenHelper.getWritableDatabase();

             db.execSQL("update person set name=?, phone=? where personId=?",

                             new Object\[\]{person.getName(), person.getPhone(), person.getId()});



    }

     

    /\*\*

     \* 查询记录

      \* @param id 记录ID

      \* @return

      \*/



    public Person find(Integer id){



            SQLiteDatabase db \= dbOpenHelper.getReadableDatabase();

             Cursor cursor \= db.rawQuery("select \* from person where personId=?", new String\[\]{id.toString()});



            if(cursor.moveToFirst()){



                    int personId = cursor.getInt(cursor.getColumnIndex("personId")); 

                    String name \= cursor.getString(cursor.getColumnIndex("name")); 

                    String phone \= cursor.getString(cursor.getColumnIndex("phone")); 

                    return new Person(personId, name, phone); 

            }



            cursor.close();               

           return null; 

    }

     

    /\*\*

     \* 分布获取记录 

     \* @param offset 跳过前面 多少条记录 

     \* @param maxResult 每页获取多少条记录 

     \* @return 

     \*/



    public List<Person> getScrollData(int offset, int maxResult){



            List<Person> persons = new ArrayList<Person>();



            SQLiteDatabase db \= dbOpenHelper.getReadableDatabase();

            Cursor cursor \= db.rawQuery("select \* from person order by personId asc limit ?,?", 

                            new String\[\]{String.valueOf(offset), String.valueOf(maxResult)});



            while(cursor.moveToNext()){



                    int personId = cursor.getInt(cursor.getColumnIndex("personId"));

                    String name \= cursor.getString(cursor.getColumnIndex("name"));

                    String phone \= cursor.getString(cursor.getColumnIndex("phone")); 

                    persons.add(new Person(personId, name, phone));

            }



            cursor.close();

          return null;



    }



    

    /\*\*

      \* 获取记录总数

     \* @return  

     \*/



    public long getCount(){



            SQLiteDatabase db \= dbOpenHelper.getReadableDatabase(); 

            Cursor cursor \= db.rawQuery("select count(\*) from person", null);

            cursor.moveToFirst();

            long result = cursor.getLong(0);

            cursor.close(); 

            return result;

     }

}




package cn.itcast.test;

import java.util.List;

import cn.itcast.domain.Person;

import cn.itcast.service.DBOpenHelper;

import cn.itcast.service.PersonService;

import android.test.AndroidTestCase;

import android.util.Log;

public class PersonServiceTest extends AndroidTestCase{

    private static final String TAG = "PersonServiceTest";



    public void testCreateDB() throws Exception{



            DBOpenHelper dbOpenHelper \= new DBOpenHelper(getContext());

            dbOpenHelper.getWritableDatabase(); 

    }        



    public void testSave() throws Exception{



            PersonService service \= new PersonService(this.getContext()); 

            for(int i = 0; i < 20; i++){



                    Person person \= new Person("zhangsan", "123456");

                    service.save(person);

             }

     }



    public void testDelete() throws Exception{



            PersonService service \= new PersonService(this.getContext());

            service.delete(21);

     }



    public void testUpdate() throws Exception{



            PersonService service \= new PersonService(this.getContext());

            Person person \= service.find(1);

            person.setName("zhangxiaoxiao");

            service.update(person);

    }



    public void testFind() throws Exception{



            PersonService service \= new PersonService(this.getContext());

            Person person \= service.find(1);

            Log.i(TAG, person.toString());



    }



    public void testScrollData() throws Exception{



            PersonService service \= new PersonService(this.getContext());

            List<Person> persons = service.getScrollData(0, 5);

            for(Person person : persons){

                     Log.i(TAG, person.toString());

             } 

    }





    public void testCount() throws Exception{



            PersonService service \= new PersonService(this.getContext());

            long result = service.getCount();

             Log.i(TAG, result \+ "");

     }



    //除了execSQL()和rawQuery方法,还提供了对应于添加、删除、更新、查询的操作方法

总结

最后小编想说:不论以后选择什么方向发展,目前重要的是把Android方面的技术学好,毕竟其实对于程序员来说,要学习的知识内容、技术有太多太多,要想不被环境淘汰就只有不断提升自己,从来都是我们去适应环境,而不是环境来适应我们!

这里附上我整理的几十套腾讯、字节跳动,京东,小米,头条、阿里、美团等公司19年的Android面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

技术进阶之路很漫长,一起共勉吧~

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

适应环境,而不是环境来适应我们!**

这里附上我整理的几十套腾讯、字节跳动,京东,小米,头条、阿里、美团等公司19年的Android面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

[外链图片转存中…(img-rC7CaHjq-1715106103153)]

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

技术进阶之路很漫长,一起共勉吧~

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 27
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值