中阶 d03.5 (正篇)完整的Dao 操作数据库
1.目录结构:
util---JDBCUtil.java(工具包,整合建立链接和释放资源的方法)
dao---UserDao.java(接口,定义方法)
impl---UserDaoImpl.java(实现方法)
test---TestUserDaoImpl.java(单元测试,测试 执行具体增删改查的方法)
2. 代码说明:
util包和之前一样没变化
Dao模式其实就是使用接口和实现来操作数据库
test 里面也不用写具体的方法,直接调用方法
3. ##Statement安全问题
- 1). Statement执行 ,其实是拼接sql语句的。 先拼接sql语句,然后在一起执行。
- String sql = "select * from t_user where username='"+ username +"' and password='"+ password +"'";
- UserDao dao = new UserDaoImpl();
- dao.login("admin", "100234khsdf88' or '1=1");
- SELECT * FROM t_user WHERE username='admin' AND PASSWORD='100234khsdf88' or '1=1'
- 前面先拼接sql语句, 如果变量里面带有了 数据库的关键字,那么一并认为是关键字。 不认为是普通的字符串。
- rs = st.executeQuery(sql);
- 2)## PrepareStatement
- > 该对象就是替换前面的statement对象。
1. 相比较以前的statement, 预先处理给定的sql语句,对其执行语法检查。 在sql语句里面使用 ? 占位符来替代后续要传递进来的变量。 后面进来的变量值,将会被看成是字符串,不会产生任何的关键字。
- String sql = "insert into t_user values(null , ? , ?)";
- ps = conn.prepareStatement(sql);
- //给占位符赋值 从左到右数过来,1 代表第一个问号, 永远你是1开始。
- ps.setString(1, userName);
- ps.setString(2, password);
4.最终代码实现
- 1. interface中:
- void findAll();
- void login(String username , String password);
- void insert(String userName , String password);
- 2.实现方法中:
- /*
- faindAll没变
- login 使用PreparedStatement预先对sql进行处理,解决安全问题(login也属于查询语句)
- 查询语句:ResultSet rs = ps.executeQuery();
- 增删改:int result = ps.executeUpdate();
- 最终 所有语句都使用使用PreparedStatement预先对sql进行处理,解决安全问题
- */
- @Override
- public void findAll() {
- Connection conn = null;
- Statement st = null;
- ResultSet rs = null;
- try {
- //1. 获取连接对象
- conn = JDBCUtil.getConn();
- //2. 创建statement对象
- st = conn.createStatement();
- String sql = "select * from t_user";
- rs = st.executeQuery(sql);
- while(rs.next()){
- String userName = rs.getString("username");
- String password = rs.getString("password");
- System.out.println(userName+"="+password);
- }
- } catch (Exception e) {
- e.printStackTrace();
- }finally {
- JDBCUtil.release(conn, st, rs);
- }
- }
- @Override
- public void login(String username, String password) {
- Connection conn = null;
- Statement st = null;
- ResultSet rs = null;
- try {
- //1. 获取连接对象
- conn = JDBCUtil.getConn();
- //2. 创建statement对象
- String sql = "select * from t_user where username=? and password=?";
- //预先对sql语句执行语法的校验, ? 对应的内容,后面不管传递什么进来,都把它看成是字符串。 or select
- PreparedStatement ps = conn.prepareStatement(sql);
- //? 对应的索引从 1 开始。
- ps.setString(1, username);
- ps.setString(2, password);
- rs = ps.executeQuery();
- if(rs.next()){
- System.out.println("登录成功");
- }else{
- System.out.println("登录失败");
- }
- } catch (Exception e) {
- e.printStackTrace();
- }finally {
- JDBCUtil.release(conn, st, rs);
- }
- }
- @Override
- public void insert(String userName, String password) {
- Connection conn = null;
- PreparedStatement ps = null;
- try {
- conn = JDBCUtil.getConn();
- String sql = "insert into t_user values(null , ? , ?)";
- ps = conn.prepareStatement(sql);
- //给占位符赋值 从左到右数过来,1 代表第一个问号, 永远你是1开始。
- ps.setString(1, userName);
- ps.setString(2, password);
- int result = ps.executeUpdate();
- if(result>0){
- System.out.println("添加成功");
- }else{
- System.out.println("添加失败");
- }
- } catch (SQLException e) {
- e.printStackTrace();
- }finally{
- JDBCUtil.release(conn, ps);
- }
- }
中阶 d03.5 (正篇)完整的Dao 操作数据库的更多相关文章
- 在MVC3中使用code first生成数据局库并操作数据库
1.建立Users和UserInfos两个实体类 对应的是数据库中的表 public class User { //类名+Id(User+Id)组成的字符串在数据库表中会设置该字段是主键且是按1的增量 ...
- 基于Python的接口自动化实战-基础篇之pymysql模块操作数据库
引言 在进行功能或者接口测试时常常需要通过连接数据库,操作和查看相关的数据表数据,用于构建测试数据.核对功能.验证数据一致性,接口的数据库操作是否正确等.因此,在进行接口自动化测试时,我们一样绕不开接 ...
- 中阶d03.2 JDBC联合properties使用,通过读取本地配置文件为代码传递参数
* 使用properties读取本地配置文件为代码传递参数 * url.用户名.密码.驱动地址等配置可以在配置文件中使用 main package zj_1_JDBC.properties; impo ...
- 中阶d03 JDBC 使用
1.首先在数据库中创建表 2.安装mysql驱动 java开发环境中导入jdbc连接mysql的jar包 mysql-connector-java-5.1.7-bin.jar 下载地址:https:/ ...
- 中阶d03.4 JDBC_DAO
1.环境准备(单项目下用,在大jdbc项目下只用配置一次) jdbc的驱动(mysqlxxjdbc.jar).util工具(包装释放资源.建立连接.访问properties文件等方法) 2.dao的概 ...
- 中阶d03.3 JDBC_CURD_Util --- 使用 junit执行单元测试(增删改查)
1.单元测试环境准备 https://www.cnblogs.com/longesang/p/11399010.html 2.测试 3.结果返回 4.代码 新建一个test目录统一存放测试案例 查: ...
- 中阶d03.1 JDBCDemo
1. jdbc使用查看驱动的doc文档<connector-j.html> 2.代码实现:1. 注册驱动---2. 建立连接---3. 创建statement ,跟数据库打交道--- -- ...
- 转:关于Python中的lambda,这篇阅读量10万+的文章可能是你见过的最完整的讲解
lambda是Python编程语言中使用频率较高的一个关键字.那么,什么是lambda?它有哪些用法?网上的文章汗牛充栋,可是把这个讲透的文章却不多.这里,我们通过阅读各方资料,总结了关于Python ...
- javascript中外部js文件取得自身完整路径得办法
原文:javascript中外部js文件取得自身完整路径得办法 有时候我们需要引入一个外部js文件,这个js文件又需要用到自己的路径或者是所在的目录,别问怎么又这么变态的需求,开发做久了各种奇葩需求也 ...
随机推荐
- 使用Jmeter进行压力测试结果偏差较大原因分析
Apache软件基金会(ASF)是一家总部位于美国的非营利性慈善组织.ASF的所有产品都通过公共论坛的在线协作开发,并从美国境内的中央服务器分发.Jmeter是ASF的一款开源免费软件 ,在国内被很多 ...
- java-根据用户输入的成绩来判断等级(新手)
//创建的一个包名. package qige; //导入的一个包.import java.util.Scanner; //定义一个类.public class Zy2 { //公共静态的主方法. p ...
- Python程序设计试验报告一: 熟悉IDLE和在线编程平台
安徽工程大学 Python程序设计 实验报告 班级 物流192 ...
- hdu3368 dfs 下棋
两颗黑子之间的白子可以翻装成黑子,两颗白子之间的黑子可以翻转成白子,对于一个给定位置,有八个方向有翻转其他颜色的子的可能.规则之一是下棋的位置一定要能翻转对方的子. 求最优情况:黑子能翻转的白子个数的 ...
- Linux上安装配置Keepalived
Linux上安装配置Keepalived 1.下载 自行去Keepalived官网进行下载,也可以通过如下链接进行下载2.0.18版本(目前的稳定版) 链接:https://pan.baidu.com ...
- Contest 152
2019-09-01 20:59:55 总体感受:最近几次参加contest发现自己的水平还是严重的不够,尤其是在处理一些异常情况的时候,遇到TLE,MLE如何有效的进行Debug是需要去锻炼的. 注 ...
- PYTHON数据类型(进阶)
PYTHON数据类型(进阶) 一.字符串.列表.字典.元祖.集合的补充 str #captalize 首字母大写,其余小写 s1.capitalize() #swapcase 大小写翻转 s1.swa ...
- coding++:kafka问题:zookeeper is not a recognized option zookeeper参数不支持
– zookeeper is not a recognized option主要原因是 Kafka 版本过高,命令不存在. 使用新版本: ./bin/kafka-console-consumer.sh ...
- 线程安全,syncronized 用法
1,为什么有线程安全问题? 当多个线程同时共享同一个全局变量或静态变量,做写的操作时,可能会发生数据冲突问题,也就是线程安全问题.但是做读操作是不会发生数据冲突问题. public class Tra ...
- 使用tensorflow的softmax进行mnist识别
tensorflow真是方便,看来深度学习需要怎么使用框架.如何建模- ''' softmax classifier for mnist created on 2019.9.28 author: vi ...