MVC模式

本文介绍了Java中实现用户登录验证的方法及从数据库查询单条或多条记录的具体步骤,并通过示例代码展示了如何处理查询结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、理解:

顾客

服务员===servlet层

可以把sevice那个接口,理解为,服务员可以看到的,厨师可以做的哪些菜,或者叫菜单。

厨师===service或者理解为ServiceImpl层

采购员===dao层

菜市场===数据库层

2、

针对输出为单值(0-1)

public User login_user( String account , String password ) {
		User user = null;
		try {
			//1、建立连接
			this.getConnection();
			//2、设置指令
			String sql = "select * from sys_user where account = ? and password = ?";
			//3、获取执行SQL语句对象
			this.ps = this.conn.prepareStatement(sql);
			this.ps.setString(1, account);
			this.ps.setString(2, password);

			this.rs = this.ps.executeQuery();
			if (this.rs.next()) {
				user = new User();
				user.setUserId(this.rs.getInt("user_id"));
				user.setAccount(this.rs.getString("account"));
				user.setPassword(this.rs.getString("password"));
				user.setStatus(this.rs.getInt("status"));
			}
			return user;
		} catch (Exception ex) {
			ex.printStackTrace();//给开发人员使用
			throw new RuntimeException("查询用户信息失败");
		} finally {
			this.close(this.conn, this.ps, this.rs);
		}
	}

这是整个 查询出来的rs,包括上面的字段名这一行,如果rs.next()存在,意思就是游标往下挪一行,不空,则挨个输出。

针对输出为多值(0-多) 

public List<User> getUserList() {
		List<User> userList = null;
		try {
			//1、建立连接
			this.getConnection();
			//2、设置指令
			String sql = "select * from sys_user";
			//3、获取执行SQL语句对象
			this.ps = this.conn.prepareStatement(sql);
			//4、获取结果集
			this.rs = this.ps.executeQuery();
			if (this.rs.next()) {//5、判断结果集是否为空
				userList = new ArrayList<>();
				this.rs.previous();
				while (this.rs.next()) {
					User user = new User();
					user.setUserId(this.rs.getInt("user_id"));
					user.setAccount(this.rs.getString("account"));
					user.setPassword(this.rs.getString("password"));
					user.setStatus(this.rs.getInt("status"));

					userList.add(user);
				}
			}
			return userList;
		} catch (Exception ex) {
			ex.printStackTrace();//给开发人员使用
			throw new RuntimeException("getUserList()查询用户列表失败");
		} finally {
			this.close(this.conn, this.ps, this.rs);
		}
	}

这是整个 查询出来的rs,包括上面的字段名这一行,如果rs.next()存在,意思就是游标往下挪一行,然后游标往上走,这是为什么呢,因为,这是由于,下面while语句还会用游标进行判定,如果不把游标往上移动,就会缺少一行数据。

 3、

//1.解决POST请求的中文乱码问题
request.setCharacterEncoding("UTF-8");

 

基于数据挖掘的音乐推荐系统设计与实现 需要一个代码说明,不需要论文 采用python语言,django框架,mysql数据库开发 编程环境:pycharm,mysql8.0 系统分为前台+后台模式开发 网站前台: 用户注册, 登录 搜索音乐,音乐欣赏(可以在线进行播放) 用户登陆时选择相关感兴趣的音乐风格 音乐收藏 音乐推荐算法:(重点) 本课题需要大量用户行为(如播放记录、收藏列表)、音乐特征(如音频特征、歌曲元数据)等数据 (1)根据用户之间相似性或关联性,给一个用户推荐与其相似或有关联的其他用户所感兴趣的音乐; (2)根据音乐之间的相似性或关联性,给一个用户推荐与其感兴趣的音乐相似或有关联的其他音乐。 基于用户的推荐和基于物品的推荐 其中基于用户的推荐是基于用户的相似度找出相似相似用户,然后向目标用户推荐其相似用户喜欢的东西(和你类似的人也喜欢**东西); 而基于物品的推荐是基于物品的相似度找出相似的物品做推荐(喜欢该音乐的人还喜欢了**音乐); 管理员 管理员信息管理 注册用户管理,审核 音乐爬虫(爬虫方式爬取网站音乐数据) 音乐信息管理(上传歌曲MP3,以便前台播放) 音乐收藏管理 用户 用户资料修改 我的音乐收藏 完整前后端源码,部署后可正常运行! 环境说明 开发语言:python后端 python版本:3.7 数据库:mysql 5.7+ 数据库工具:Navicat11+ 开发软件:pycharm
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值