Home Java javaTutorial Example explanation of how to implement BaseDao in Java

Example explanation of how to implement BaseDao in Java

Sep 08, 2017 am 09:37 AM
java Example

The following editor will bring you a simple BaseDao example using custom annotations and reflection in Java. The editor thinks it’s pretty good, so I’ll share it with you now and give it as a reference. Let’s follow the editor and take a look.

In common ORM frameworks, most of them provide annotation methods to achieve mapping between entities and databases. Here we simply use custom annotations and reflection to generate executable sql. statement.

This is the overall directory structure. It was originally a project created for reviewing annotations^.^

Okay, first let's determine the idea.

1. Customize the @Table @Column annotation,

We slightly imitate hibernate and let @Table act on the class to indicate the entity The mapping relationship between the class and the data table, and let the attribute value in @Table be mapped to the name of the data table tableName; let @Column act on the attribute (the set method is not implemented here) to indicate the mapping between the attribute and the data table field relationship, and let the attribute value in @Column be mapped to a columnName of a field in the data table.

2. We need to imitate a Dao layer.

At this time we first define an entity User with name and password attributes, and then define A UserDao. There is a save (User user) method in UserDao. When we instantiate a UserDao and User, we call the save method of UserDao, pass in our User object, and return a section of sql. For this sql, we simply set it Set as "insert into user (name,password) VALUES('cai','123456')", where user is the name of our data table, name,password are data table fields,'cai','123456' are User objects properties.

--------------------------------0.0 code dividing line-------- -------------------------------------

//Column .java


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

package com.shu.annotation;

import java.lang.annotation.Documented;

import java.lang.annotation.ElementType;

import java.lang.annotation.Inherited;

import java.lang.annotation.Retention;

import java.lang.annotation.RetentionPolicy;

import java.lang.annotation.Target;

 

@Target({ElementType.FIELD})

@Retention(RetentionPolicy.RUNTIME)

@Inherited

@Documented

public @interface Column {

 String value();

}

Copy after login

//Table.java


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

package com.shu.annotation;

import java.lang.annotation.Documented;

import java.lang.annotation.ElementType;

import java.lang.annotation.Inherited;

import java.lang.annotation.Retention;

import java.lang.annotation.RetentionPolicy;

import java.lang.annotation.Target;

 

@Target({ElementType.METHOD,ElementType.TYPE})

@Retention(RetentionPolicy.RUNTIME)

@Inherited

@Documented

public @interface Table {

 String value();

  

}

Copy after login

//User.java


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

package com.shu.entity;

import com.shu.annotation.Column;

import com.shu.annotation.Table;

 

@Table("t_user")

public class User {

  

 @Column("name")

 private String name;

 @Column("password")

 private String password;

  

 public String getName() {

  return name;

 }

 public String getPassword() {

  return password;

 }

 public void setName(String name) {

  this.name = name;

 }

 public void setPassword(String password) {

  this.password = password;

 }

  

}

Copy after login

//IBaseDao.java


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

package com.shu.dao;

import java.lang.reflect.Field;

 

import com.shu.annotation.Column;

import com.shu.annotation.Table;

 

public interface IBaseDao<T> {

  

 //最终目标:insert into user (NAME,password) VALUES(&#39;cai&#39;,&#39;123456&#39;);

 default String save(T entity) throws IllegalArgumentException, IllegalAccessException{

  //sql用于存放最终返回的sql语句

  StringBuilder sql = new StringBuilder("insert into ");

  //tableName用于存放sql语句中表名部分

  StringBuilder tableName;

  //columnName用于存放sql语句的字段部分

  StringBuilder columnName = new StringBuilder("(");

  //values用于存放sql语句中的赋值部分

  StringBuilder values = new StringBuilder("(");

  //获取对象user的class对象

  Class clazz = entity.getClass();

  //判断该User类是否有@Table注解

  boolean isTable = clazz.isAnnotationPresent(Table.class);

  if(isTable) {

   //获取User类@Table注解的值value,该值我们定义为User表的表名称

   Table t = (Table) clazz.getAnnotation(Table.class);

   tableName = new StringBuilder(t.value());

   //拼接表名

   sql.append(tableName+" ");

   //获取user对象的属性列表

   Field[] fieldList = clazz.getDeclaredFields();

   //遍历属性列表,分别拿出属性列表中被@Column注解的属性,并获取属性的值

   for(int i=0;i<fieldList.length;i++){

    Field f = fieldList[i];

    boolean isColumn = f.isAnnotationPresent(Column.class);

    if(!isColumn){

     continue;

    }

    Column column = f.getAnnotation(Column.class);

     f.setAccessible(true);

    Object columnValue = f.get(entity);

    if(i==fieldList.length-1){

     columnName.append(column.value()+") VALUES ");

     values.append("&#39;"+columnValue+"&#39;)");

     sql.append(columnName);

     sql.append(values);

     continue;

    }

    columnName.append(column.value()+", ");

    values.append("&#39;"+columnValue+"&#39;,");

   }

    

//   boolean isColumn = clazz.isAnnotationPresent(annotationClass);

  }

  return sql.toString();

 }

 

 

}

Copy after login

//UserDao.java


##

1

2

3

4

5

6

7

package com.shu.dao;

 

import com.shu.entity.User;

 

public class UserDao implements IBaseDao<User> {

 

}

Copy after login

//UserService.java


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

package com.shu.service;

import com.shu.dao.UserDao;

import com.shu.entity.User;

 

public class UserService {

  

 public static void main(String[] args) {

  // TODO Auto-generated constructor stub

 

  UserDao userDao = new UserDao();

  User user = new User();

  user.setName("cai");

  user.setPassword("123456");

  try {

   System.out.println(userDao.save(user));

  } catch (IllegalArgumentException e) {

   // TODO Auto-generated catch block

   e.printStackTrace();

  } catch (IllegalAccessException e) {

   // TODO Auto-generated catch block

   e.printStackTrace();

  }

 }

  

}

Copy after login
--------------------------------0.0 code dividing line-------- ---------------------------------------------

Here we finally define A Service layer, let it call the dao layer and generate the corresponding sql statement. You can customize other Entities, such as Order in my directory, and then define an OrderDao to implement the IBaseDao interface, and define an OrderService to call the save method of OrderDao. Similarly SQL statements corresponding to the order table can be generated.

Here is a summary of the shortcomings:

1. Hibernate annotations can be used without assignment, so I think it is necessary to directly obtain the name of the table without assignment. Or the name of the field can be obtained using reflection.

2. Only the save method is used here, and the SQL statement is dynamically generated without interacting with the database. A factory can be packaged to provide a persistence method to execute the SQL statement.

3. The splicing of sql here is relatively rough. You can think about whether there are other more efficient methods.

The above is the detailed content of Example explanation of how to implement BaseDao in Java. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Perfect Number in Java Perfect Number in Java Aug 30, 2024 pm 04:28 PM

Guide to Perfect Number in Java. Here we discuss the Definition, How to check Perfect number in Java?, examples with code implementation.

Weka in Java Weka in Java Aug 30, 2024 pm 04:28 PM

Guide to Weka in Java. Here we discuss the Introduction, how to use weka java, the type of platform, and advantages with examples.

Smith Number in Java Smith Number in Java Aug 30, 2024 pm 04:28 PM

Guide to Smith Number in Java. Here we discuss the Definition, How to check smith number in Java? example with code implementation.

Java Spring Interview Questions Java Spring Interview Questions Aug 30, 2024 pm 04:29 PM

In this article, we have kept the most asked Java Spring Interview Questions with their detailed answers. So that you can crack the interview.

Break or return from Java 8 stream forEach? Break or return from Java 8 stream forEach? Feb 07, 2025 pm 12:09 PM

Java 8 introduces the Stream API, providing a powerful and expressive way to process data collections. However, a common question when using Stream is: How to break or return from a forEach operation? Traditional loops allow for early interruption or return, but Stream's forEach method does not directly support this method. This article will explain the reasons and explore alternative methods for implementing premature termination in Stream processing systems. Further reading: Java Stream API improvements Understand Stream forEach The forEach method is a terminal operation that performs one operation on each element in the Stream. Its design intention is

TimeStamp to Date in Java TimeStamp to Date in Java Aug 30, 2024 pm 04:28 PM

Guide to TimeStamp to Date in Java. Here we also discuss the introduction and how to convert timestamp to date in java along with examples.

Java Program to Find the Volume of Capsule Java Program to Find the Volume of Capsule Feb 07, 2025 am 11:37 AM

Capsules are three-dimensional geometric figures, composed of a cylinder and a hemisphere at both ends. The volume of the capsule can be calculated by adding the volume of the cylinder and the volume of the hemisphere at both ends. This tutorial will discuss how to calculate the volume of a given capsule in Java using different methods. Capsule volume formula The formula for capsule volume is as follows: Capsule volume = Cylindrical volume Volume Two hemisphere volume in, r: The radius of the hemisphere. h: The height of the cylinder (excluding the hemisphere). Example 1 enter Radius = 5 units Height = 10 units Output Volume = 1570.8 cubic units explain Calculate volume using formula: Volume = π × r2 × h (4

Create the Future: Java Programming for Absolute Beginners Create the Future: Java Programming for Absolute Beginners Oct 13, 2024 pm 01:32 PM

Java is a popular programming language that can be learned by both beginners and experienced developers. This tutorial starts with basic concepts and progresses through advanced topics. After installing the Java Development Kit, you can practice programming by creating a simple "Hello, World!" program. After you understand the code, use the command prompt to compile and run the program, and "Hello, World!" will be output on the console. Learning Java starts your programming journey, and as your mastery deepens, you can create more complex applications.

See all articles