【附】相关架构及资料
源码、笔记、视频。高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter全方面的Android进阶实践技术,和技术大牛一起讨论交流解决问题。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
###### []( )然后在Activity中实例化一下OpenHelper和SQLiteDatabase
OpenHelper openHelper= new OpenHelper(SQActivity.this);
SQLiteDatabase db = openHelper.getWritableDatabase();
这样子可以说准备工作就做完了,可以开始功能的实现了。
##### []( )功能实现:增
首先实例化一下ContentValues,然后用put的方式以key-value(键对值)的形式传入数据,最后SQLiteDatabase的insert方法插入数据库。
private void setSQ(String id, String name, String age) { //增
ContentValues cv=new ContentValues();
cv.put("id", id);
cv.put("name", name);
cv.put("age", age);
//分别插入id name age三个数据,然后调用insert方法进行插入
db.insert("tbname", null, cv);
}
##### []( )功能实现:删
删除就一行代码~SQLiteDatabase的delete的方法实现,这里只演示根据id来删除对应的数据。
private void getDel(String str_del) { //删
//这里仅演示根据ID删除某条数据
db.delete("tbname", "id=?", new String[]{str_del});
}
##### []( )功能实现:查
首先创建一个Cursor 游标,然后遍历所有数据,这里由于我是用的ListView来展示数据,所以在while循环里面直接把数据传入到List中,cursor.getString(0)这个就是获取你每条数据的第一个数据的意思,也就是我传入的id。
private void getSQ() { //查
//创建游标 cursor 并用游标遍历所有数据
Cursor cursor = db.query("tbname", null, null, null, null, null, null);
while (cursor.moveToNext()) {
bean = new SQBean(cursor.getString(0), cursor.getString(1), cursor.getString(2));
list.add(bean);
}
cursor.close();//关闭游标(cursor)释放资源
}
##### []( )功能实现:改
更改数据库中的内容的话,你需要再实例化一个ContentValues,然后添加一个数据到里面,最后利用SQLiteDatabase的update方法实现新旧数据的更新。(我这里是对name来进行更新)
private void getUpData() {//改
ContentValues cv_Updata=new ContentValues();
cv_Updata.put("name",editUpdatastr.getText().toString());
db.update("tbname", cv_Updata, "name=?", new String[]{editUpdataid.getText().toString()});
}
如果还有什么不懂的可以下方评论区留言讨论!
##### []( )最后贴上完整的代码:(ListView的Adapter和Bean就不贴了)
SQActivity.java
public class SQActivity extends AppCompatActivity implements View.OnClickListener {
private EditText e1;
private EditText e2;
private EditText e3;
private Button btn;
private ListView lv;
private EditText editDel;
private Button buttonDel;
private EditText editUpdataid;
private EditText editUpdatastr;
private Button buttonUpdata;
private Button buttonRead;
private OpenHelper openHelper;
private SQLiteDatabase db;
private SQBean bean;
private SQAdapter adapter;
private List<SQBean> list = new ArrayList<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sq);
initView();
openHelper= new OpenHelper(SQActivity.this);
db = openHelper.getWritableDatabase();
adapter = new SQAdapter(SQActivity.this, list);
lv.setAdapter(adapter);
}
private void setSQ(String id, String name, String age) { //增
ContentValues cv=new ContentValues();
cv.put("id", id);
cv.put("name", name);
cv.put("age", age);
//分别插入id name age三歌数据,然后调用insert方法进行插入
db.insert("tbname", null, cv);
}
private void getDel(String str_del) { //删
//这里仅演示根据ID删除某条数据
db.delete("tbname", "id=?", new String[]{str_del});
}
private void getSQ() { //查
//创建游标 cursor 并用游标遍历所有数据
Cursor cursor = db.query("tbname", null, null, null, null, null, null);
while (cursor.moveToNext()) {
bean = new SQBean(cursor.getString(0), cursor.getString(1), cursor.getString(2));
list.add(bean);
}
cursor.close();//关闭游标(cursor)释放资源
}
private void getUpData() {//改
ContentValues cv_Updata=new ContentValues();
cv_Updata.put("name",editUpdatastr.getText().toString());
db.update("tbname", cv_Updata, "name=?", new String[]{editUpdataid.getText().toString()});
}
private void initView() {
e1 = (EditText) findViewById(R.id.e1);
e2 = (EditText) findViewById(R.id.e2);
e3 = (EditText) findViewById(R.id.e3);
btn = (Button) findViewById(R.id.btn);
lv = (ListView) findViewById(R.id.lv);
editDel = (EditText) findViewById(R.id.edit_del);
buttonDel = (Button) findViewById(R.id.button_del);
editUpdataid = (EditText) findViewById(R.id.edit_updataid);
editUpdatastr = (EditText) findViewById(R.id.edit_updatastr);
buttonUpdata = (Button) findViewById(R.id.button_updata);
buttonRead = (Button) findViewById(R.id.button_read);
btn.setOnClickListener(this);
buttonUpdata.setOnClickListener(this);
buttonRead.setOnClickListener(this);
buttonDel.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.btn: //增
setSQ(e1.getText().toString(), e2.getText().toString(), e3.getText().toString());
Toast.makeText(this, "插入数据成功", Toast.LENGTH_SHORT).show();
break;
case R.id.button_del: //删
getDel(editDel.getText().toString());
Toast.makeText(this, "删除成功", Toast.LENGTH_SHORT).show();
break;
case R.id.button_read: //查
list.clear();//先清空旧数据防止重叠
getSQ();
adapter.notifyDataSetChanged();//更新List列表
Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();
break;
case R.id.button_updata: //改
getUpData();
Toast.makeText(this, "更改成功", Toast.LENGTH_SHORT).show();
break;
}
}
}
activity\_sq.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
总结
学习技术是一条慢长而艰苦的道路,不能靠一时激情,也不是熬几天几夜就能学好的,必须养成平时努力学习的习惯。所以:贵在坚持!
最后如何才能让我们在面试中对答如流呢?
答案当然是平时在工作或者学习中多提升自身实力的啦,那如何才能正确的学习,有方向的学习呢?有没有免费资料可以借鉴?为此我整理了一份Android学习资料路线:
这里是一部分我工作以来以及参与过的大大小小的面试收集总结出来的一套BAT大厂面试资料专题包,主要还是希望大家在如今大环境不好的情况下面试能够顺利一点,希望可以帮助到大家。
好了,今天的分享就到这里,如果你对在面试中遇到的问题,或者刚毕业及工作几年迷茫不知道该如何准备面试并突破现状提升自己,对于自己的未来还不够了解不知道给如何规划。来看看同行们都是如何突破现状,怎么学习的,来吸收他们的面试以及工作经验完善自己的之后的面试计划及职业规划。
最后,祝愿即将跳槽和已经开始求职的大家都能找到一份好的工作!
这些只是整理出来的部分面试题,后续会持续更新,希望通过这些高级面试题能够降低面试Android岗位的门槛,让更多的Android工程师理解Android系统,掌握Android系统。喜欢的话麻烦点击一个喜欢再关注一下~
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
看看同行们都是如何突破现状,怎么学习的,来吸收他们的面试以及工作经验完善自己的之后的面试计划及职业规划。
最后,祝愿即将跳槽和已经开始求职的大家都能找到一份好的工作!
这些只是整理出来的部分面试题,后续会持续更新,希望通过这些高级面试题能够降低面试Android岗位的门槛,让更多的Android工程师理解Android系统,掌握Android系统。喜欢的话麻烦点击一个喜欢再关注一下~
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!