成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

談?wù)凷pring-Data的那些事兒

charles_paul / 1370人閱讀

摘要:什么是呢全稱,是提出的一個對象持久化規(guī)范,各應(yīng)用服務(wù)器自主選擇具體實現(xiàn)。僅僅只是一個規(guī)范,而不是產(chǎn)品使用本身是不能做到持久化的。只要提供了持久化類與表的映射關(guān)系,框架在運行時就能參照映射文件的信息,把對象持久化到數(shù)據(jù)庫中。

我們在進行事務(wù)處理往往需要和數(shù)據(jù)庫進行交互,這其中有關(guān)系型數(shù)據(jù)庫(MySql,Sql Server,Oracle)或者是非關(guān)系型數(shù)據(jù)庫(Redis,Hadhoop),常見的操縱數(shù)據(jù)庫的方式就有JDBC和Spring JdbcTemplate,而這兩種處理方式其實很繁瑣而且代碼復(fù)用率也比較低。另外使用這這種方式進行實際開發(fā)時效率也比較低,今天我們使用Spring Data進行開發(fā)。在進行開發(fā)之前我們首先介紹一下什么是Spring-Data,以及如何使用JDBC和Spring JDBCTemplate方式進行常用的CRUD功能的開發(fā)。

SpringData相關(guān)概念:
SpringData是Spring基于ORM框架、JPA規(guī)范封裝的一套JPA應(yīng)用框架,它提供了包括增刪改查在內(nèi)的常用功能,且易于擴展,可使開發(fā)者用極簡的代碼實現(xiàn)對數(shù)據(jù)庫的訪問和操作。
什么是JPA呢?
JPA全稱Java Persistence API,是sun提出的一個對象持久化規(guī)范,各JavaEE應(yīng)用服務(wù)器自主選擇具體實現(xiàn)。JPA僅僅只是一個規(guī)范,而不是產(chǎn)品;使用JPA本身是不能做到持久化的。所以,JPA只是一系列定義好的持久化操作的接口,在系統(tǒng)中使用時,需要真正的實現(xiàn)者。

JPA的設(shè)計者是Hibernate框架的作者,因此Hibernate EntityManager作為Jboss服務(wù)器中JPA的默認實現(xiàn);Oracle的Weblogic使用EclipseLink(以前叫TopLink)作為默認的JPA實現(xiàn);IBM的Websphere和Sun的Glassfish默認使用OpenJPA(Apache的一個開源項目)作為其默認的JPA實現(xiàn)。
JPA的底層實現(xiàn)是一些流行的開源ORM(對象關(guān)系映射)框架,因此JPA其實也就是java實體對象和關(guān)系型數(shù)據(jù)庫建立起映射關(guān)系,通過面向?qū)ο缶幊痰乃枷氩僮麝P(guān)系型數(shù)據(jù)庫的規(guī)范。

什么是ORM呢?
ORM,即Object-Relational Mapping(對象關(guān)系映射),它的作用是在關(guān)系型數(shù)據(jù)庫和業(yè)務(wù)實體對象之間作一個映射,這樣,我們在具體的操作業(yè)務(wù)對象的時候,就不需要再去和復(fù)雜的SQL語句打交道,只需簡單的操作對象的屬性和方法。只要提供了持久化類與表的映射關(guān)系,ORM框架在運行時就能參照映射文件的信息,把對象持久化到數(shù)據(jù)庫中。當前ORM框架主要有三種:Hibernate,iBATIS,EclipseLink。

SpringData提供的編程接口:

【1】Repository:最頂層接口,是一個空接口,目的是為了統(tǒng)一所有的Repository的類型,且能讓組件掃描的時候自動識別;
【2】CrudRepository:提供基礎(chǔ)的增刪改查操作;
【3】PagingAndSortingRepository:提供分頁和排序的操作;
【4】JpaRepository:增加了批量操作的功能;
【5】JpaSpecificationExecutor :組合查詢條件,提供原生SQL查詢。

使用JDBC進行開發(fā):
首先說明例子所設(shè)計的數(shù)據(jù)庫,如下圖:
![圖片描述][1]   
1.JDBC工具類
public class JDBCUtil {    
    /*
     * 獲取connection
     * @return 所獲得的JDBC的Connection
     */
    public static Connection getConnection() throws ClassNotFoundException, SQLException, IOException
    {
        /*String url = "jdbc:mysql://localhost:3306/spring_data";
        String user = "root";
        String password = "123456";
        String driverClass = "com.mysql.jdbc.Driver";*/
        
        /*
         * 通過讀取配置文件獲取數(shù)據(jù)庫連接所需參數(shù)
         */
        InputStream inputStream = JDBCUtil.class.getClassLoader().getResourceAsStream("database.properties");
        Properties properties = new Properties();
        properties.load(inputStream);
        
        String url = properties.getProperty("jdbc.url");
        String user = properties.getProperty("jdbc.user");
        String password = properties.getProperty("jdbc.password");
        String driverClass = properties.getProperty("jdbc.driverClass");
        Class.forName(driverClass);
        Connection connection =  DriverManager.getConnection(url, user, password);    
        return connection;    
    }    
    /*
     * 釋放資源
     */
    public static void release(ResultSet resultSet,Statement statement,Connection connection)
    {
        /*
         * 釋放resultset
         */
        if(resultSet!=null)
        {
            try {
                resultSet.close();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        if(resultSet!=null)
        {
            try {
                resultSet.close();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        /*
         * 釋放statement
         */
        if(statement!=null)
        {
            try {
                statement.close();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        /*
         * 釋放connection
         */
        if(connection!=null)
        {
            try {
                connection.close();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    }
}

附: JDBC數(shù)據(jù)源配置文件:

jdbc.url = jdbc:mysql://localhost:3306/spring_data
jdbc.user = root
jdbc.password = 123456
jdbc.driverClass =com.mysql.jdbc.Driver
2.定義項目中設(shè)計的實體類
   /**
 * @author 熊濤
 *Student Entity Class
 */
public class Student {

    private int id;
    private String name;
    private int age;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
}
3.Dao層接口的實現(xiàn)
public interface StudentDAO {
    /*
     * 查詢所有學生
     * @return所有學生
     */
    public List query();
    
    /*
     * 添加學生接口
     */
    public void save(Student student);
}
4.Dao層接口的實現(xiàn)類
  /**
 * @author 熊濤
 *StudentDAO接口的實現(xiàn)類,通過最原始的JDBC的方式操作
 */
public class StudetnDAOImpl implements StudentDAO {    
    public List query() {
        
        List students = new ArrayList();
        
        Connection connection = null;
        PreparedStatement preparedStatement = null;
        ResultSet resultSet = null;
        String sql = "select id,name,age from student";
        try {
            connection = JDBCUtil.getConnection();
            preparedStatement=connection.prepareStatement(sql);
            resultSet = preparedStatement.executeQuery();
            
            Student student = null;
            while(resultSet.next()){
                int id = resultSet.getInt("id");
                String name = resultSet.getString("name");
                int age = resultSet.getInt("age");
                
                student = new Student();
                student.setId(id);
                student.setName(name);
                student.setAge(age);
                
                students.add(student);
            }
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }finally{
            JDBCUtil.release(resultSet, preparedStatement, connection);
        }
        
        return students;
    }

    public void save(Student student) {
        
        Connection connection = null;
        PreparedStatement preparedStatement = null;
        ResultSet resultSet = null;
        String sql = "insert into student(name,age) values(?,?)";
        try {
            connection = JDBCUtil.getConnection();
            preparedStatement=connection.prepareStatement(sql);
            preparedStatement.setString(1, student.getName());
            preparedStatement.setInt(2, student.getAge());
            preparedStatement.executeUpdate();
    }catch(Exception e){
        e.printStackTrace();
    }finally{
        JDBCUtil.release(resultSet, preparedStatement, connection);
    }
    }
}


2.使用Spring JDBCTemplate進行開發(fā)

1.創(chuàng)建使用Spring-JDBCTemplate所需的配置文件beans.xml目的是將datasource和JDBCTemplate注入進來




    
        
        
        
        
    

    
        
    
    
    
            
    

2.在Dao層實現(xiàn)類中實現(xiàn)JDBCTemplate

/**
 * @author 熊濤
 *StudentDAo接口的實現(xiàn)類,通過Spring-JDBC的方式操作
 */
public class StudentDAOSpringJdbcImpl implements StudentDAO {

    //通過set方法注入JdbcTemplate
    private JdbcTemplate jdbcTemplate;
    
    public List query() {
        
        final List students = new ArrayList();
        String sql = "select id,name,age from student";
        jdbcTemplate.query(sql,new RowCallbackHandler(){

            public void processRow(ResultSet rs) throws SQLException {
                int id = rs.getInt("id");
                String name = rs.getString("name");
                int age = rs.getInt("age");
                
                Student student = new Student();
                student.setId(id);
                student.setName(name);
                student.setAge(age);                    
                students.add(student);                    
            }               
        });
        return students;
    }

    public void save(Student student) {
        String sql = "insert into student(name,age) values(?,?)";
        jdbcTemplate.update(sql,new Object[]{student.getName(),student.getAge()});
    }
    
    public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }

}  

3.使用Spring-Data方式進行開發(fā)

【1】創(chuàng)建使用Spring-Data所需的Spring配置文件      
         


    
    
        
        
        
        
    

    
    
        
        
            
        
        

        
            
                org.hibernate.cfg.ImprovedNamingStrategy
                org.hibernate.dialect.MySQL5InnoDBDialect
                true
                true
                update
            
        
            
    
    
        
    
    
    
    
            
           

      

【2】創(chuàng)建項目中所涉及到的實體類

    /**
 * @author 熊濤
 *雇員實體類
 *先開發(fā)實體類,然后生成對應(yīng)的數(shù)據(jù)表
 */
@Entity
@Table(name="test_employee")
public class Employee {

    private Integer id;
    private String name;
    private Integer age;
    
    @GeneratedValue
    @Id
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    @Column(length=20)
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
    @Override
    public String toString() {
        return "Employee [id=" + id + ", name=" + name + ", age=" + age + "]";
    }    
}

【3】創(chuàng)建項目中設(shè)計的接口類


 public interface EmployeeRepository extends Repository{

    public Employee findByName(String name);
    public List findByNameStartingWithAndAgeLessThan(String name,Integer age);
    public List findByNameEndingWithAndAgeLessThan(String name,Integer age);
    public List findByNameInOrAgeLessThan(List names,Integer age);
    public List findByNameInAndAgeLessThan(List names,Integer age);
        
    @Query("select o from Employee o where id=(select max(id) from Employee t1)")
    public Employee getEmployeeByMaxId();    
    @Query("select o from Employee o where o.name=?1 and o.age=?2")
    public List queryParams1(String name,Integer age);
    @Query("select o from Employee o where o.name=:name and o.age=:age")
    public List queryParams2(@Param("name")String name,@Param("age")Integer age);
    @Query("select o from Employee o where o.name like %?1%")
    public List queryLike1(String name);
    @Query("select o from Employee o where o.name like %:name%")
    public List queryLike2(@Param("name")String name);    
    @Query(nativeQuery = true,value = "select count(1) from employee")
    public long getCount();
    
    @Modifying
    @Query("update Employee o set o.age = :age where o.id = :id")
    public void update(@Param("id")Integer id,@Param("age")Integer age);
}

最后附上例子源碼,源碼中還有對于以上代碼功能的測試,測試代碼均位于test包下。
項目源碼:
鏈接:https://pan.baidu.com/s/1pLcGCUR 密碼:welh

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/61908.html

相關(guān)文章

  • 談?wù)?/em>Spring-Data那些事兒

    摘要:什么是呢全稱,是提出的一個對象持久化規(guī)范,各應(yīng)用服務(wù)器自主選擇具體實現(xiàn)。僅僅只是一個規(guī)范,而不是產(chǎn)品使用本身是不能做到持久化的。只要提供了持久化類與表的映射關(guān)系,框架在運行時就能參照映射文件的信息,把對象持久化到數(shù)據(jù)庫中。 我們在進行事務(wù)處理往往需要和數(shù)據(jù)庫進行交互,這其中有關(guān)系型數(shù)據(jù)庫(MySql,Sql Server,Oracle)或者是非關(guān)系型數(shù)據(jù)庫(Redis,Hadhoop)...

    chinafgj 評論0 收藏0
  • 你該知道ES6那些事兒

    摘要:最近重構(gòu)了一個項目,引入了部分用法,最大的感受是讓這門語言變得更加嚴謹,更加方便。通過該方法獲得位置后還得比較一次才能判斷是否存在。再來看看的寫法使用數(shù)組來初始化一個,構(gòu)造器能確保不重復(fù)地使用這些值。下面提供鏈接,供有興趣的朋友參考。 最近重構(gòu)了一個SPA項目,引入了部分ES6用法,最大的感受是ES6讓javascript這門語言變得更加嚴謹,更加方便。本篇將結(jié)合實戰(zhàn)經(jīng)驗,對最常用的部...

    CoffeX 評論0 收藏0
  • 跨域那些事兒

    摘要:什么是跨域我們先看下以下場景開啟兩個本地服務(wù)器,頁面為,其中嵌套了,頁面想使用頁面的數(shù)據(jù),例如調(diào)用它的方法,會報以下錯誤如圖所示,,,譯為協(xié)議主機和端口號必須符合,否則,就是跨域??缬虻膸追N常見方案同源策略的限制范圍有以下幾種和無法讀取。 什么是跨域 我們先看下以下場景:開啟兩個本地服務(wù)器,頁面A為localhost:9800,其中嵌套了iframeB localhost:9000,頁...

    nevermind 評論0 收藏0
  • spring-data jpa 查詢部分屬性

    摘要:一準備有表結(jié)構(gòu)如何生成相應(yīng)的對象為省略二問題現(xiàn)在有一查詢對象原先我是先查詢出所有的對象,然后再循環(huán)賦值。經(jīng)過一番嘗試由于對象我不想改變,只能先差對象再循環(huán)賦值了。 一 準備 1.有表結(jié)構(gòu)如何 CREATE TABLE `bbs_topic` ( `id` int(11) NOT NULL AUTO_INCREMENT, `user_id` int(11) NOT NULL DE...

    whataa 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<