1.目录结构:

  util---JDBCUtil.java(工具包,整合建立链接和释放资源的方法)

  dao---UserDao.java(接口,定义方法)

    impl---UserDaoImpl.java(实现方法)

  test---TestUserDaoImpl.java(单元测试,测试 执行具体增删改查的方法)

2. 代码说明:

util包和之前一样没变化

Dao模式其实就是使用接口和实现来操作数据库

test 里面也不用写具体的方法,直接调用方法

3. ##Statement安全问题

  1. 1). Statement执行 ,其实是拼接sql语句的。  先拼接sql语句,然后在一起执行。
       
  2.  
  3.      String sql = "select * from t_user where username='"+ username +"' and password='"+ password +"'";
  4.  
  5. UserDao dao = new UserDaoImpl();
  6. dao.login("admin", "100234khsdf88' or '1=1");
  7.  
  8. SELECT * FROM t_user WHERE username='admin' AND PASSWORD='100234khsdf88' or '1=1'
  9.  
  10. 前面先拼接sql语句, 如果变量里面带有了 数据库的关键字,那么一并认为是关键字。 不认为是普通的字符串。
  11. rs = st.executeQuery(sql);
  1. 2)## PrepareStatement
  2.  
  3. > 该对象就是替换前面的statement对象。
    1. 相比较以前的statement 预先处理给定的sql语句,对其执行语法检查。 sql语句里面使用 ? 占位符来替代后续要传递进来的变量。 后面进来的变量值,将会被看成是字符串,不会产生任何的关键字。
            
  4.  
  5.         String sql = "insert into t_user values(null , ? , ?)";
  6. ps = conn.prepareStatement(sql);
  7.  
  8. //给占位符赋值 从左到右数过来,1 代表第一个问号, 永远你是1开始。
  9. ps.setString(1, userName);
  10. ps.setString(2, password);

  

4.最终代码实现

  1. 1. interface中:
  2.  
  3. void findAll();
  4. void login(String username , String password);
  5. void insert(String userName , String password);
  6.  
  7. 2.实现方法中:
  8. /*
  9. faindAll没变
  10. login 使用PreparedStatement预先对sql进行处理,解决安全问题(login也属于查询语句)
  11. 查询语句:ResultSet rs = ps.executeQuery();
  12. 增删改:int result = ps.executeUpdate();
  13.  
  14. 最终 所有语句都使用使用PreparedStatement预先对sql进行处理,解决安全问题
  15. */
  16.      @Override
  17. public void findAll() {
  18. Connection conn = null;
  19. Statement st = null;
  20. ResultSet rs = null;
  21. try {
  22. //1. 获取连接对象
  23. conn = JDBCUtil.getConn();
  24. //2. 创建statement对象
  25. st = conn.createStatement();
  26. String sql = "select * from t_user";
  27. rs = st.executeQuery(sql);
  28.  
  29. while(rs.next()){
  30. String userName = rs.getString("username");
  31. String password = rs.getString("password");
  32.  
  33. System.out.println(userName+"="+password);
  34. }
  35.  
  36. } catch (Exception e) {
  37. e.printStackTrace();
  38. }finally {
  39. JDBCUtil.release(conn, st, rs);
  40. }
  41. }
  42.  
  43.      @Override
  44. public void login(String username, String password) {
  45.  
  46. Connection conn = null;
  47. Statement st = null;
  48. ResultSet rs = null;
  49. try {
  50. //1. 获取连接对象
  51. conn = JDBCUtil.getConn();
  52. //2. 创建statement对象
  53. String sql = "select * from t_user where username=? and password=?";
  54.  
  55. //预先对sql语句执行语法的校验, ? 对应的内容,后面不管传递什么进来,都把它看成是字符串。 or select
  56. PreparedStatement ps = conn.prepareStatement(sql);
  57. //? 对应的索引从 1 开始。
  58. ps.setString(1, username);
  59. ps.setString(2, password);
  60.  
  61. rs = ps.executeQuery();
  62. if(rs.next()){
  63. System.out.println("登录成功");
  64. }else{
  65. System.out.println("登录失败");
  66. }
  67.  
  68. } catch (Exception e) {
  69. e.printStackTrace();
  70. }finally {
  71. JDBCUtil.release(conn, st, rs);
  72. }
  73. }
  74.  
  75.      @Override
  76. public void insert(String userName, String password) {
  77. Connection conn = null;
  78. PreparedStatement ps = null;
  79.  
  80. try {
  81. conn = JDBCUtil.getConn();
  82. String sql = "insert into t_user values(null , ? , ?)";
  83. ps = conn.prepareStatement(sql);
  84.  
  85. //给占位符赋值 从左到右数过来,1 代表第一个问号, 永远你是1开始。
  86. ps.setString(1, userName);
  87. ps.setString(2, password);
  88.  
  89. int result = ps.executeUpdate();
  90. if(result>0){
  91. System.out.println("添加成功");
  92. }else{
  93. System.out.println("添加失败");
  94. }
  95. } catch (SQLException e) {
  96. e.printStackTrace();
  97. }finally{
  98. JDBCUtil.release(conn, ps);
  99. }
  100. }

  

中阶 d03.5 (正篇)完整的Dao 操作数据库的更多相关文章

  1. 在MVC3中使用code first生成数据局库并操作数据库

    1.建立Users和UserInfos两个实体类 对应的是数据库中的表 public class User { //类名+Id(User+Id)组成的字符串在数据库表中会设置该字段是主键且是按1的增量 ...

  2. 基于Python的接口自动化实战-基础篇之pymysql模块操作数据库

    引言 在进行功能或者接口测试时常常需要通过连接数据库,操作和查看相关的数据表数据,用于构建测试数据.核对功能.验证数据一致性,接口的数据库操作是否正确等.因此,在进行接口自动化测试时,我们一样绕不开接 ...

  3. 中阶d03.2 JDBC联合properties使用,通过读取本地配置文件为代码传递参数

    * 使用properties读取本地配置文件为代码传递参数 * url.用户名.密码.驱动地址等配置可以在配置文件中使用 main package zj_1_JDBC.properties; impo ...

  4. 中阶d03 JDBC 使用

    1.首先在数据库中创建表 2.安装mysql驱动 java开发环境中导入jdbc连接mysql的jar包 mysql-connector-java-5.1.7-bin.jar 下载地址:https:/ ...

  5. 中阶d03.4 JDBC_DAO

    1.环境准备(单项目下用,在大jdbc项目下只用配置一次) jdbc的驱动(mysqlxxjdbc.jar).util工具(包装释放资源.建立连接.访问properties文件等方法) 2.dao的概 ...

  6. 中阶d03.3 JDBC_CURD_Util --- 使用 junit执行单元测试(增删改查)

    1.单元测试环境准备 https://www.cnblogs.com/longesang/p/11399010.html 2.测试 3.结果返回 4.代码 新建一个test目录统一存放测试案例 查: ...

  7. 中阶d03.1 JDBCDemo

    1. jdbc使用查看驱动的doc文档<connector-j.html> 2.代码实现:1. 注册驱动---2. 建立连接---3. 创建statement ,跟数据库打交道--- -- ...

  8. 转:关于Python中的lambda,这篇阅读量10万+的文章可能是你见过的最完整的讲解

    lambda是Python编程语言中使用频率较高的一个关键字.那么,什么是lambda?它有哪些用法?网上的文章汗牛充栋,可是把这个讲透的文章却不多.这里,我们通过阅读各方资料,总结了关于Python ...

  9. javascript中外部js文件取得自身完整路径得办法

    原文:javascript中外部js文件取得自身完整路径得办法 有时候我们需要引入一个外部js文件,这个js文件又需要用到自己的路径或者是所在的目录,别问怎么又这么变态的需求,开发做久了各种奇葩需求也 ...

随机推荐

  1. 使用Jmeter进行压力测试结果偏差较大原因分析

    Apache软件基金会(ASF)是一家总部位于美国的非营利性慈善组织.ASF的所有产品都通过公共论坛的在线协作开发,并从美国境内的中央服务器分发.Jmeter是ASF的一款开源免费软件 ,在国内被很多 ...

  2. java-根据用户输入的成绩来判断等级(新手)

    //创建的一个包名. package qige; //导入的一个包.import java.util.Scanner; //定义一个类.public class Zy2 { //公共静态的主方法. p ...

  3. Python程序设计试验报告一: 熟悉IDLE和在线编程平台

    安徽工程大学 Python程序设计 实验报告                                                                  班级   物流192   ...

  4. hdu3368 dfs 下棋

    两颗黑子之间的白子可以翻装成黑子,两颗白子之间的黑子可以翻转成白子,对于一个给定位置,有八个方向有翻转其他颜色的子的可能.规则之一是下棋的位置一定要能翻转对方的子. 求最优情况:黑子能翻转的白子个数的 ...

  5. Linux上安装配置Keepalived

    Linux上安装配置Keepalived 1.下载 自行去Keepalived官网进行下载,也可以通过如下链接进行下载2.0.18版本(目前的稳定版) 链接:https://pan.baidu.com ...

  6. Contest 152

    2019-09-01 20:59:55 总体感受:最近几次参加contest发现自己的水平还是严重的不够,尤其是在处理一些异常情况的时候,遇到TLE,MLE如何有效的进行Debug是需要去锻炼的. 注 ...

  7. PYTHON数据类型(进阶)

    PYTHON数据类型(进阶) 一.字符串.列表.字典.元祖.集合的补充 str #captalize 首字母大写,其余小写 s1.capitalize() #swapcase 大小写翻转 s1.swa ...

  8. coding++:kafka问题:zookeeper is not a recognized option zookeeper参数不支持

    – zookeeper is not a recognized option主要原因是 Kafka 版本过高,命令不存在. 使用新版本: ./bin/kafka-console-consumer.sh ...

  9. 线程安全,syncronized 用法

    1,为什么有线程安全问题? 当多个线程同时共享同一个全局变量或静态变量,做写的操作时,可能会发生数据冲突问题,也就是线程安全问题.但是做读操作是不会发生数据冲突问题. public class Tra ...

  10. 使用tensorflow的softmax进行mnist识别

    tensorflow真是方便,看来深度学习需要怎么使用框架.如何建模- ''' softmax classifier for mnist created on 2019.9.28 author: vi ...