}
public TUser(Integer id, String username, String password, String name,
String sex) {
super();
this.id = id;
this.username = username;
this.password = password;
this.name = name;
this.sex = sex;
}
public TUser() {
super();
}
}
DbOpenHelper.java链接数据库,创建数据库类
package com.example.androiddemo01.dao;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class DbOpenHelper extends SQLiteOpenHelper {
private static final String DBNAME = “data.db”;
private static int version = 1;
//content容器,name链接数据库名字,version版本号,factory游标工厂
public DbOpenHelper(Context context) {
super(context, DBNAME, null, version);
}
//运行DbOpenHelper时执行,建立表和数据库,没有数据库则建立,只有第一次运行执行
@Override
public void onCreate(SQLiteDatabase db) {
String sql = “create table t_user(”+
“id integer primary key autoincrement not null,”+
“username text(10),”+
“password text(10),”+
“name text(10),”+
“sex text(2))”;
//执行SQL语句
db.execSQL(sql);
sql = “insert into t_user (‘username’, ‘password’, ‘name’, ‘sex’) values(‘admin’,‘admin’, ‘张三’, ‘男’)”;
db.execSQL(sql);
}
//更新,版本升级
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
TUserDAO.java数据库操作类,增删改查。
package com.example.androiddemo01.dao;
import java.util.ArrayList;
import java.util.List;
import com.example.androiddemo01.model.TUser;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
//持久层类,对数据库的操作
public class TUserDAO {
private SQLiteDatabase db;
//content容器,上下文
public TUserDAO(Context context){
super();
DbOpenHelper helper = new DbOpenHelper(context);
db = helper.getWritableDatabase();
}
//登录验证
public TUser findUserNameAndPassword(String str, String str1) {
String sql = “select * from t_user where username = ? and password = ?”;
Cursor cursor = db.rawQuery(sql, new String[] {str, str1});
TUser user = null;
//cursor.moveToNext判断下一个是否有值
if(cursor.moveToNext()){
user = new TUser(cursor.getInt(0), cursor.getString(1), cursor.getString(2), cursor.getString(3), cursor.getString(4));
}
return user;
}
//查找表中所有数据
public List findAll(){
String sql = “select * from t_user”;
Cursor cursor = db.rawQuery(sql, null);
List list = new ArrayList();
if(cursor.moveToNext()){
TUser user = new TUser(cursor.getInt(0), cursor.getString(1), cursor.getString(2), cursor.getString(3), cursor.getString(4));
list.add(user);
}
return list;
}
//根据姓名模糊查找
public List searchByName(String key){
List list = new ArrayList();
key = “%”+key+“%”;
Cursor cursor = db.rawQuery(“select * from t_user where name like ?”, new String[]{key});
while(cursor.moveToNext()){
TUser user = new TUser(cursor.getInt(0), cursor.getString(1), cursor.getString(2), cursor.getString(3), cursor.getString(4));
list.add(user);
}
return list;
}
//添加
public void insert(TUser t){
db.execSQL(“insert into t_user(username, password, name, sex) values(?, ?, ?, ?)”, new Object[] {t.getUsername(), t.getPassword(), t.getName(), t.getSex()});
System.out.println(“添加数据成功!”);
}
//修改
public void update (TUser user){
db.execSQL(“update t_user set name=?, sex = ?, password = ?, username = ? where id = ?”,
new Object[] {user.getName(), user.getSex(), user.getPassword(), user.getUsername(), user.getId()});
}
//根据id删除
public void delete(int id){
Integer i = new Integer(id);
db.execSQL(“delete from student where id = ?”, new Object[]{i});
}
}
MainActivity.java登录处理类
package com.example.androiddemo01;
import com.example.androiddemo01.dao.TUserDAO;
import com.example.androiddemo01.model.TUser;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends Activity implements OnClickListener {
private TextView username;
private TextView password;
private Button submit;
private Button register;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
username = (TextView) findViewById(R.id.username);
password = (TextView) findViewById(R.id.password);
submit = (Button) findViewById(R.id.submit);
register = (Button) findViewById(R.id.register);
submit.setOnClickListener(this);
register.setOnClickListener(this);
}
@Override
public void onClick(View v) {
TUserDAO user = new TUserDAO(this);
//创建intent对象
Intent intent = new Intent();
switch (v.getId()) {
case R.id.submit:
String str = username.getText().toString();
String str1 = password.getText().toString();
if(str.equals(“”) || str1.equals(“”)){
//弹框提示
Toast.makeText(MainActivity.this, “账号密码不能为空”, Toast.LENGTH_SHORT).show();
}else{
TUser t_user = user.findUserNameAndPassword(str, str1);
if(t_user == null){
Toast.makeText(MainActivity.this, “账号或密码输入错误”, Toast.LENGTH_SHORT).show();
}else{
//跳转指定的Activity
intent.setClass(MainActivity.this, IndexActivity.class);
//传递参数
intent.putExtra(“name”, t_user.getName());
//执行方法
startActivityForResult(intent, 2);
}
}
break;
default:
break;
}
}
}
IndexActivity.java登录成功显示姓名。最后一个类了_
package com.example.androiddemo01;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.TextView;
public class IndexActivity extends Activity {
private TextView text;
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
最后
其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。
上面分享的腾讯、头条、阿里、美团、字节跳动等公司2019-2021年的高频面试题,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。
【Android学习PDF+学习视频+面试文档+知识点笔记】
【Android思维脑图(技能树)】
知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。
【Android高级架构视频学习资源】
注Android)**
[外链图片转存中…(img-znb22Two-1710816582504)]
最后
其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。
上面分享的腾讯、头条、阿里、美团、字节跳动等公司2019-2021年的高频面试题,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,上面只是以图片的形式给大家展示一部分。
【Android学习PDF+学习视频+面试文档+知识点笔记】
【Android思维脑图(技能树)】
知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。
[外链图片转存中…(img-zm34SvV2-1710816582504)]
【Android高级架构视频学习资源】
**Android部分精讲视频领取学习后更加是如虎添翼!**进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水,赶快领取吧!
还没有评论,来说两句吧...