图书管理插入、修改、删除、查询

Book.java

package com.jdbc;

public class Book {

    private String id;

    private String name;

    private String author;

    private Double price;

    private String press;

    public String getId() {

       return id;

    }

    public void setId(String id) {

       this.id = id;

    }

    public String getName() {

       return name;

    }

    public void setName(String name) {

       this.name = name;

    }

    public String getAuthor() {

       return author;

    }

    public void setAuthor(String author) {

       this.author = author;

    }

    public Double getPrice() {

       return price;

    }

    public void setPrice(Double price) {

       this.price = price;

    }

    public String getPress() {

       return press;

    }

    public void setPress(String press) {

       this.press = press;

    }

   

    @Override

    public String toString() {

       return "Book [id=" + id + ", name=" + name + ", author=" + author + ", price=" + price + ", press=" + press

              + "]";

    }

}

BookDao.java

package com.jdbc;

import java.util.List;

public interface BookDao {

    /*update() 方法 */

    // 向数据库中增加图书

    public int addBook(Book b);

    // 更新数据库中的图书

    public int updateBook(Book b);

    // 删除数据库中的图书

    public int deleteBook (int id);

    /*query() 方法 */

    // 通过 id 查询图书信息

    public Book findBookById(int id);

    // 查询所有图书信息

    public List<Book> findAllBook();

}

BookDaoImpl.java

package com.jdbc;

import java.util.List;

import org.springframework.jdbc.core.BeanPropertyRowMapper;

import org.springframework.jdbc.core.JdbcTemplate;

import org.springframework.jdbc.core.RowMapper;

public class BookDaoImpl implements BookDao {

    private JdbcTemplate jdbcTemplate;

    public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {

       this.jdbcTemplate = jdbcTemplate;

    }

    // 增加图书

    @Override

    public int addBook(Book b) {

       // 定义SQL

       String sql = "insert into book(id, name, author, price, press) value(?, ?, ?, ?, ?)";

       // 定义数组来存储SQL语句中的参数

       Object obj[] = new Object[]{

              b.getId(),

              b.getName(),

              b.getAuthor(),

              b.getPrice(),

              b.getPress()

       };

       // 执行添加操作,返回的是受SQL语句影响的记录条数

       int num = this.jdbcTemplate.update(sql, obj);

       return num;

    }

    // 更新图书

    @Override

    public int updateBook(Book b) {

 

       // 定义SQL;

       String sql = "update book set name = ?, author = ?,price = ?, press = ? where id = ?";

       // 定义数组俩存储SQL语句中的参数

       Object params[] = new Object[]{

              b.getName(),

              b.getAuthor(),

              b.getPrice(),

              b.getPress(),

              b.getId()

       };

       // 执行更新操作,返回的受SQL语句影响的记录条数

       int num = this.jdbcTemplate.update(sql, params);

       return num;

    }

    // 删除图书

    @Override

    public int deleteBook(int id) {

       // 定义SQL

       String sql = "delete from book where id = ?";

       // 执行删除操作,返回的是受SQL语句影响的记录条数

       int num = this.jdbcTemplate.update(sql,id);

       return num;

    }

    /*query()方法 */

    // 通过id查询图书信息

    @Override

    public Book findBookById(int id) {

       // 定义SQL语句

       String sql = "select * from book where id = ?";

       // 创建一个新的 BeanPropertyRowMapper 对象

       RowMapper<Book> rowMapper =

               new BeanPropertyRowMapper<Book>(Book.class);

       // 将 id 绑定到 SQL 语句中,并通过 RowMapper 返回一个Object类型的单行记录

       return this.jdbcTemplate.queryForObject(sql, rowMapper, id);

    }

    // 查询所有图书信息

    @Override

    public List<Book> findAllBook() {

       // 定义 SQL 语句

       String sql = "select * from book";

       // 创建一个新的 BeanPropertyRowMapper 对象

       RowMapper<Book> rowMapper =

               new BeanPropertyRowMapper<Book>(Book.class);

       // 执行静态的 SQL 查询,并通过 RowMapper 返回结果

       return this.jdbcTemplate.query(sql, rowMapper);

    }

}

BookTest.java

package com.jdbc;

import java.util.List;

import org.junit.Test;

import org.springframework.context.ApplicationContext;

import

    org.springframework.context.support.ClassPathXmlApplicationContext;

import org.springframework.jdbc.core.JdbcTemplate;

public class BookTest {

       public static void main(String[] args) {

           @SuppressWarnings("resource")

           ApplicationContext applicationContext =

             new ClassPathXmlApplicationContext("abc.xml");

           JdbcTemplate jdTemplate =

                  (JdbcTemplate) applicationContext.getBean("jdbcTemplate");

           jdTemplate.execute("create table book(" +

                             "id int primary key auto_increment not null," +

                             "name varchar(50) ," +

                             "author varchar(20) ," +

                             "price float(10) ," +

                             "press varchar(30) )" );

           System.out.println("图书管理数据库book创建成功!");

       }

/*插入*/

    @Test

    public void add_Book(){

       // 加载配置文件

    ApplicationContext applicationContext =

              new ClassPathXmlApplicationContext("abc.xml");

       // 获取 BookDao 实例

       BookDao bookDao =

              (BookDao) applicationContext.getBean("bookDao");

       // 创建 Book 对象,并向 Account 对象中添加数据

       Book book = new Book();

       book.setId("042712");

       book.setName("aichijimoren");

       book.setAuthor("jushi");

       book.setPrice(688.00);

       book.setPress("yuanchubanshe");

       // 执行 addBook()方法,并获取返回结果

       int num = bookDao.addBook(book);

       if(num > 0){

           System.out.println("成功插入了" + num + "条数据!");

       }

       else{

           System.out.println("插入操作执行失败!");

       }

    }

   

 

 

/*更新*/  

    @Test

    public void update_Book(){

      

        // 加载配置文件

        ApplicationContext applicationContext =

              new ClassPathXmlApplicationContext("abc.xml");

        // 获取 BookDao 实例

           BookDao bookDao =

                  (BookDao) applicationContext.getBean("bookDao");

        // 创建 Book 对象,并向 Book 对象中添加数据

       Book book = new Book();

       book.setId("042709");

       book.setName("tuheise");

       book.setAuthor("shui0nan");

       book.setPrice(68.00);

       book.setPress("258chubanshe");

        // 执行 updateBook()方法,并返回结果

        int num = bookDao.updateBook(book);

        if(num > 0){

            System.out.println("成功修改了" + num + "条数据!");

        }

        else{

            System.out.println("修改操作执行失败!");

                   }

    }

 

   

/*删除*/  

 

    @Test

    public void delete_Book(){

      

       // 加载配置文件

       ApplicationContext applicationContext =

             new ClassPathXmlApplicationContext("abc.xml");

       // 获取 BookDao 实例

       BookDao bookDao =

              (BookDao) applicationContext.getBean("bookDao");

       // 执行 deleteBook()方法,并获取返回结果

       int num = bookDao.deleteBook(42711);

       if(num > 0){

           System.out.println("成功删除了" + num + "条数据!");

           }

       else{

           System.out.println("删除操作执行失败!");

       }

    }

 

 

/*使用query()方法进行条件查询   */

 

    @Test

    public void find_BookById(){      

       // 加载配置文件

       ApplicationContext applicationContext =

             new ClassPathXmlApplicationContext("abc.xml");

       // 获取 BookDao 实例

       BookDao bookDao =

              (BookDao) applicationContext.getBean("bookDao");

        // 执行 findBookById()方法

       Book book = bookDao.findBookById(42705);

       System.out.println("id\tname\tauthor\t\tprice\t\tpress");

       System.out.println(book.getId() + "\t" +book.getName() + "\t" + book.getAuthor() +

              "\t\t" + book.getPrice() + "\t\t" + book.getPress());

    }

 

   

/*使用query()方法查询所有图书信息 */

   

    @Test

    public void find_AllBook(){

      

       // 加载配置文件

       ApplicationContext applicationContext =

             new ClassPathXmlApplicationContext("abc.xml");

       // 获取 BookDao 实例

       BookDao bookDao =

              (BookDao) applicationContext.getBean("bookDao");

       // 执行 findAllAccountById()方法,获取Book对象集合

       List<Book> book = bookDao.findAllBook();

       // 循环输出集合中的对象

       System.out.println("id\tname\tauthor\t\tprice\t\tpress");

       for(Book b : book){

           System.out.println(b.getId() + "\t" + b.getName() + "\t" + b.getAuthor() + "\t\t" +

           b.getPrice() + "\t\t" + b.getPress());

       }

    }

}

abc.xml

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

    xsi:schemaLocation="http://www.springframework.org/schema/beans

    http://www.springframework.org/schema/beans/spring-beans-4.3.xsd">

    <!-- l 配置数据源 -->

    <bean id="dataSource" class=

    "org.springframework.jdbc.datasource.DriverManagerDataSource" >

        <!-- 数据库驱动 -->

        <property name="driverClassName" value="com.mysql.jdbc.Driver" />

        <!-- 连接数据库的 url -->

        <property name="url" value="jdbc:mysql://localhost/bookdata" />

        <!-- 连接数据库的用户名 -->

        <property name="username" value="root" />

        <!-- 连接数据库的密码 -->

        <property name="password" value="root" />

    </bean>

    <!-- 2 配置 JDBC 模板 -->

    <bean id="jdbcTemplate"

          class="org.springframework.jdbc.core.JdbcTemplate">  

        <!-- 默认必须使用数据源 -->

        <property name="dataSource" ref="dataSource" />

    </bean>

    <!-- 定义id为bookDao的Bean -->

    <bean id="bookDao" class="com.jdbc.BookDaoImpl">

        <!-- 将 jdbcTemplate 注入到 accountDao 实例中 -->

        <property name="jdbcTemplate" ref="jdbcTemplate" />

    </bean>

</beans>

截图:(2张)

 

 

posted @ 2020-04-27 12:05  星澄不向往大海  阅读(1400)  评论(0编辑  收藏  举报