<TextView
android:id=“@+id/id”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:ems=“10”
/>
<LinearLayout
android:layout_width=“match_parent”
android:layout_height=“wrap_content”
android:orientation=“horizontal”>
<TextView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:textSize=“15sp”
android:text=“昵称:” />
<EditText
android:id=“@+id/name”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:ems=“10”
android:inputType=“textPersonName”
/>
<LinearLayout
android:layout_width=“match_parent”
android:layout_height=“wrap_content”
android:orientation=“horizontal”>
<TextView
android:id=“@+id/textView2”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:textSize=“15sp”
android:text=“年龄:”
/>
<EditText
android:id=“@+id/age”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:ems=“10”
/>
<LinearLayout
android:layout_width=“match_parent”
android:layout_height=“wrap_content”
android:orientation=“horizontal”>
<TextView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:textSize=“15sp”
android:text=“地址:”
/>
<EditText
android:id=“@+id/address”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_weight=“1”
android:ems=“10”
android:inputType=“phone”
/>
<LinearLayout
android:layout_width=“match_parent”
android:layout_height=“wrap_content”
android:orientation=“horizontal”>
<Button
android:layout_marginTop=“50dp”
android:id=“@+id/button2”
android:layout_width=“match_parent”
android:layout_height=“wrap_content”
android:text=“提交”
android:onClick=“updatestudent”
/>
<Button
android:id=“@+id/button3”
android:layout_width=“match_parent”
android:layout_height=“wrap_content”
android:text=“重置” />
</androidx.constraintlayout.widget.ConstraintLayout>
2、在student_list.xml页面上的按钮上添加onClick
3、完善Student_List当中的update方法
public void update(View view){
LinearLayout linearLayout = (LinearLayout)(view.getParent().getParent());
TextView idEd = linearLayout.findViewById(R.id.id);
TextView nameEd = linearLayout.findViewById(R.id.name);
TextView ageEd = linearLayout.findViewById(R.id.age);
TextView addressEd = linearLayout.findViewById(R.id.address);
Intent intent=new Intent();
intent.putExtra(“id”, idEd.getText().toString());
intent.putExtra(“name”, nameEd.getText().toString());
intent.putExtra(“age”, ageEd.getText().toString());
intent.putExtra(“address”, addressEd.getText().toString());
intent.setClass(this, StudentUpdate.class);
startActivity(intent );
Toast.makeText(getApplicationContext(),“修改”,Toast.LENGTH_LONG).show();
}
4、StudentUpdate当中获取对应Intent 对象当中的值并放入到页面当中的修改框当中
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_student_update);
Intent intent = getIntent();
String id = intent.getStringExtra(“id”);
String name = intent.getStringExtra(“name”);
String age = intent.getStringExtra(“age”);
String address = intent.getStringExtra(“address”);
TextView idtv = findViewById(R.id.id);
EditText nameet = findViewById(R.id.name);
EditText ageet = findViewById(R.id.age);
EditText addresset = findViewById(R.id.address);
idtv.setText(id);
nameet.setText(name);
ageet.setText(age);
addresset.setText(address);
}
运行测试
(二)web端
1、创建更新学生信息的dao
public boolean update(Student stu){
String sql=“update student set name=?,age=?,address=? where id=?”;
Connection con = JDBCUtils.getConn();
try {
PreparedStatement pst=con.prepareStatement(sql);
pst.setString(1,stu.getName());
pst.setInt(2,stu.getAge());
pst.setString(3,stu.getAddress() );
pst.setInt(4,stu.getId() );
int value = pst.executeUpdate();
if(value>0){
return true;
}
} catch (SQLException throwables) {
throwables.printStackTrace();
}finally {
JDBCUtils.close(con);
}
return false;
}
2、创建对应更新学生信息的Servlet
完善StudentUpdateServlet
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
System.out.println(“-----------------”);
request.setCharacterEncoding(“utf-8”);
response.setCharacterEncoding(“UTF-8”);
int id = Integer.parseInt(request.getParameter(“id”));
String name = request.getParameter(“name”);
int age = Integer.parseInt(request.getParameter(“age”));
String address = request.getParameter(“address”);
Student student = new Student();
student.setId(id);
student.setName(name);
student.setAge(age);
student.setAddress(address);
String msg = “”;
StudentDao studentDao = new StudentDao();
boolean flag = studentDao.update(student);
if(flag){
msg = “成功”;
}else{
msg = “失败”;
}
PrintWriter out = response.getWriter();
out.println(msg);
out.flush();
out.close();
}
(三)安卓端
1、在StudentUpdate当中创建updatestudent实现向studentUpdateServlet发送更新信息的请求
package com.example.application01;
import androidx.appcompat.app.AppCompatActivity;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import com.example.application01.utils.PostUtil;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
public class StudentUpdate extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_student_update);
Intent intent = getIntent();
String id = intent.getStringExtra(“id”);
String name = intent.getStringExtra(“name”);
String age = intent.getStringExtra(“age”);
String address = intent.getStringExtra(“address”);
TextView idtv = findViewById(R.id.id);
EditText nameet = findViewById(R.id.name);
EditText ageet = findViewById(R.id.age);
EditText addresset = findViewById(R.id.address);
idtv.setText(id);
nameet.setText(name);
ageet.setText(age);
addresset.setText(address);
}
public void updatestudent(View view){
TextView idtv = findViewById(R.id.id);
EditText nameet = findViewById(R.id.name);
EditText ageet = findViewById(R.id.age);
EditText addresset = findViewById(R.id.address);
String id = idtv.getText().toString();
String name = nameet.getText().toString();
String age = ageet.getText().toString();
String address = addresset.getText().toString();
new Thread(){
@Override
public void run() {
String data=“”;
try {
data = “&id=”+ URLEncoder.encode(id, “UTF-8”)+
“&name=”+ URLEncoder.encode(name, “UTF-8”)+
“&age=”+ URLEncoder.encode(age, “UTF-8”)+
“&address=”+ URLEncoder.encode(address, “UTF-8”);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
String request = PostUtil.Post(“studentUpdateServlet”,data);
int msg = 0;
if(request.equals(“成功”)){
msg = 1;
}
hand.sendEmptyMessage(msg);
}
}.start();
}
Handler hand=new Handler(){
@Override
public void handleMessage(Message msg) {
if(msg.what == 1)
{
startActivity(new Intent( getApplicationContext(), Student_List.class ) );
//startActivity(new Intent( getApplicationContext(), StuInfoActivity.class ) );
}
else
{
Toast.makeText(getApplicationContext(),“更新失败”,Toast.LENGTH_LONG).show();
}
}
};
}
2、运行测试
读者福利
由于篇幅过长,就不展示所有面试题了,感兴趣的小伙伴
更多笔记分享
{
startActivity(new Intent( getApplicationContext(), Student_List.class ) );
//startActivity(new Intent( getApplicationContext(), StuInfoActivity.class ) );
}
else
{
Toast.makeText(getApplicationContext(),“更新失败”,Toast.LENGTH_LONG).show();
}
}
};
}
2、运行测试
读者福利
由于篇幅过长,就不展示所有面试题了,感兴趣的小伙伴
[外链图片转存中…(img-0rG6ZThD-1725981776625)]
[外链图片转存中…(img-zPRC2nRd-1725981776626)]
[外链图片转存中…(img-KUKxhzm2-1725981776626)]
更多笔记分享
[外链图片转存中…(img-BmDzNj6L-1725981776627)]