📄 user_operation.java
字号:
package user;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
import util.stringUtil;
import db.dbconn;
/**
* @author 邓子云
* 用户类
*/
public class user_operation {
/**
* 功能:判断自动生成的角色是否已经生成用户
* 输入:foreign_id为教师表或学生表中的ID号,sysuser_role为用户角色
* 输出:返回0表未生成,返回1表已生成,返回3表未知
* 说明:只要有sysuser表中可查到记录,即表示已经生成
*/
public int isAutoGenOK(long foreign_id,int sysuser_role){
if(foreign_id==0||sysuser_role==0||sysuser_role==1||sysuser_role==2)
//用户角色为1表系统管理员,为2表教务人员,这两种角色手工生成,所以不为自动生成
return 3;
String sqlString=null;//SQL语句字符串
ResultSet rs=null;//结果记录集
dbconn dbconnOBject=new dbconn();//数据库连接对象
Connection dbconn=dbconnOBject.getDBConn();//得到数据库连接
if(dbconn==null) return 3;//连接失败
sqlString="select * from sysuser where foreign_id=? and sysuser_role=?";
try{
PreparedStatement preSQLSelect=dbconn.prepareStatement(sqlString);
preSQLSelect.setLong(1,foreign_id);
preSQLSelect.setInt(2,sysuser_role);
rs=preSQLSelect.executeQuery();
if(rs.next()) return 1;
else return 0;
}catch(Exception e){
System.out.print(e);
return 3;
}
}
public int isAdminGenOK(long foreign_id,int sysuser_role){
if(foreign_id==0||sysuser_role==0)
return 3;
String sqlString=null;//SQL语句字符串
ResultSet rs=null;//结果记录集
dbconn dbconnOBject=new dbconn();//数据库连接对象
Connection dbconn=dbconnOBject.getDBConn();//得到数据库连接
if(dbconn==null) return 3;//连接失败
sqlString="select * from sysuser where foreign_id=? and sysuser_role=?";
try{
PreparedStatement preSQLSelect=dbconn.prepareStatement(sqlString);
preSQLSelect.setLong(1,foreign_id);
preSQLSelect.setInt(2,sysuser_role);
rs=preSQLSelect.executeQuery();
if(rs.next()) return 1;
else return 0;
}catch(Exception e){
System.out.print(e);
return 3;
}
}
/**
* 功能:生成老师用户
*/
public String genTeacherUser(String teacher_id[]){
String returnString=new String("");
String sqlString=null;//SQL语句字符串
ResultSet rs=null;//结果记录集
ResultSet rs1=null;//另一结果记录集
Statement sql=null;//SQL语句对象
dbconn dbconnOBject=new dbconn();//数据库连接对象
Connection dbconn=dbconnOBject.getDBConn();//得到数据库连接
if(dbconn==null) return returnString;//连接失败
try{
sqlString="select * from teacher";
System.out.println(teacher_id.length);
int j=0;//加长SQL语句的次数
if(teacher_id.length!=0){//生成部分教师用户
for(int i=0;i<teacher_id.length;i++)
if(teacher_id[i]!=null&&teacher_id[i].length()!=0&&!teacher_id[i].equalsIgnoreCase("null")){
if(j==0)
{sqlString=sqlString+" where teacher_id="+teacher_id[i];j++;}
else
sqlString=sqlString+" or teacher_id="+teacher_id[i];
}
}
sql=dbconn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY);
rs=sql.executeQuery(sqlString);
while(rs.next()){
sqlString="select * from sysuser where foreign_id=" +
rs.getLong("teacher_id")+" and sysuser_role=3";
sql=dbconn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY);
rs1=sql.executeQuery(sqlString);
if(!rs1.next()){//不存在插入,存在则不做事
sqlString="insert into sysuser(sysuser_name,sysuser_password,sysuser_role" +
",foreign_id) values(?,?,3,?)";
PreparedStatement preSQLUpdate=dbconn.prepareStatement(sqlString);
preSQLUpdate.setString(1,rs.getString("teacher_name"));
preSQLUpdate.setString(2,"111111");
preSQLUpdate.setLong(3,rs.getLong("teacher_id"));
preSQLUpdate.executeUpdate();
returnString=returnString+"生成教师"+rs.getString("teacher_name")+"用户成功!<BR>";
}else
returnString=returnString+"教师"+rs.getString("teacher_name")+"用户已经生成,不必再生成!<BR>";
rs1.close();
}
}catch(Exception e){
System.out.print(e);
}
return returnString;
}
/**
* 功能:生成学生用户
*/
public String genStudentUser(String student_id[]){
String returnString=new String("");
String sqlString=null;//SQL语句字符串
ResultSet rs=null;//结果记录集
ResultSet rs1=null;//另一结果记录集
Statement sql=null;//SQL语句对象
dbconn dbconnOBject=new dbconn();//数据库连接对象
Connection dbconn=dbconnOBject.getDBConn();//得到数据库连接
if(dbconn==null) return returnString;//连接失败
try{
sqlString="select * from student";
System.out.println(student_id.length);
int j=0;//加长SQL语句的次数
if(student_id.length!=0){//生成部分教师用户
for(int i=0;i<student_id.length;i++)
if(student_id[i]!=null&&student_id[i].length()!=0&&!student_id[i].equalsIgnoreCase("null")){
if(j==0)
{sqlString=sqlString+" where student_id="+student_id[i];j++;}
else
sqlString=sqlString+" or student_id="+student_id[i];
}
}
sql=dbconn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY);
rs=sql.executeQuery(sqlString);
while(rs.next()){
sqlString="select * from sysuser where foreign_id=" +
rs.getLong("student_id")+" and sysuser_role=4";
sql=dbconn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY);
rs1=sql.executeQuery(sqlString);
if(!rs1.next()){//不存在插入,存在则不做事
sqlString="insert into sysuser(sysuser_name,sysuser_password,sysuser_role" +
",foreign_id) values(?,?,4,?)";
PreparedStatement preSQLUpdate=dbconn.prepareStatement(sqlString);
preSQLUpdate.setString(1,rs.getString("student_name"));
preSQLUpdate.setString(2,"111111");
preSQLUpdate.setLong(3,rs.getLong("student_id"));
preSQLUpdate.executeUpdate();
returnString=returnString+"生成学生"+rs.getString("student_name")+"用户成功!<BR>";
}else
returnString=returnString+"学生"+rs.getString("student_name")+"用户已经生成,不必再生成!<BR>";
rs1.close();
}
}catch(Exception e){
System.out.print(e);
}
return returnString;
}
/**
* 得到管理用户记录集,系统管理员和教务管理员是管理用户
*/
public ResultSet getAdminUsers(){
String sqlString=null;//SQL语句字符串
Statement sql=null;//SQL语句对象
ResultSet rs=null;//结果记录集
dbconn dbconnOBject=new dbconn();//数据库连接对象
Connection dbconn=dbconnOBject.getDBConn();//得到数据库连接
if(dbconn==null) return null;//连接失败
try{
//-------查询出数据------------
sqlString="select * from sysuser where sysuser_role=1 or sysuser_role=2";
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -