navigation

[react] Hooks

[React from zero practice 01- background] code split [React from zero practice 02- background] permission control [React from zero practice 03- background] custom hooks [React from zero practice 04- background] docker-compose Deploy React + Egg +nginx+mysql [React From zero practice 05- background] Gitlab-CI using Docker automated deployment

[source code – Webpack01 – precompiler] AST abstract syntax tree [source code – Webpack02 – Precompiler] Tapable [source code – Webpack03] hand written webpack-compiler simple compilation process [source code] Redux React-redux01 [source] Axios [source] vuex [source -vue01] Data reactive and initialize render [source -vue02] Computed responsive – Initialize, access, Update Procedure [source -vue04] Watch Listening properties – Initialize and update [source -vue04] vue. set and vm.$set [source -vue05] vue.extend

[source -vue06] Vue. NextTick and VM.$nextTick [Deployment 01] Nginx [Deployment 02] Docker deployVUE project [Deployment 03] Gitlab-CI

[Data Structures and Algorithms 01] Binary search and sort

[Deep 01] Execution context [Deep 02] Prototype chain [Deep 03] Inheritance [Deep 04] Event loop [Deep 05] Curri Bias function [Deep 06] Function memory [Deep 07] Implicit conversions and operators [Deep 07] Browser caching mechanism (HTTP caching mechanism) [Deep 08] Front-end security [Deep 09] Deep copy [Deep 10] Debounce Throttle [Deep 10] Front-end routing [Deep 12] Front-end modularization [Deep 13] Observer mode Publish subscribe mode Bidirectional data binding [Deep 14] Canvas [Deep 15] webSocket Webpack HTTP and HTTPS CSS- Interview Handwriting Promise Data Structures and Algorithms – Binary Search and Sorting Js Design Patterns – Agents, policies, singletons

/ front-end learn java01 – SpringBoot combat environment configuration and the HelloWorld service [front-end learn java02 – SpringBoot combat] mybatis + mysql implementation song to add and delete [front-end learn java03 – SpringBoot combat] Lombok, log, Java04 -SpringBoot combat deployment [front-end science Java04 -SpringBoot combat] static resources + interceptor + front and back end file upload [front-end science Java05 -SpringBoot combat] common annotates + Redis implementation statistics function [front-end science Java06 -SpringBoot combat] inject Swagger2 3.0 + unit test JUnit5 IOC scanner + transaction + Jackson

(1) Pre-knowledge

(1) Some words

// @transactional decimal decimal // BigDecimal in Java corresponds to the Decimal type in the database. It is mainly used as a plug-in of amount Redundant rainbow Rainbow BRACKET rainbow bracketCopy the code

(2) Java type conversion

  • There are two types of cast in Java (automatic cast (implicit cast)) and cast (display cast)
  • The default type
    • The default value is int
    • Default floating-point double
  • Automatic type conversion
    • Small type to large type, automatically promoted to large type, the operation result is (Big type )
  • Cast
    • To manually convert a large type to a small type, the result is (Small type )
    • Transformation format
      • Small type variable name = (small type) big data type
@SpringBootTest public class OtherTest { @Test void test() { int a = 10; byte b = 20; int c = a+b; => byte + int = int byte d = (byte) (a+b); // Cast => double e = 3.14; // Cast => double e = 3.14; int f = (int) e; // double => int; // double => int; }}Copy the code





(3) The scope of the bean

  • Bean scope is divided into (Singleton scope) (Prototype scope) (Web application scope)
  • scope => singleton prototype
  • lazy-init= ><bean id="roleService" class="org.example.service.RoleService" lazy-init="true"></bean>

<? The XML version = "1.0" encoding = "utf-8"? > <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <! When the Spring IOC container is started, it instantiates all Bean objects in the Singleton scope. If set to true, it indicates lazy loading. When the container starts, the bean object is not instantiated. If it's set to false, it doesn't load lazily. If the container starts, it instantiates the default value false. - What's the benefit of false? (1) Configuration problems can be found when the container is started. (2) The bean object will be set in the (single-column cache pool) when the container is started, improving the efficiency of program running. - What objects are suitable for being single-column objects, i.e. objects in the IOC container, and which objects are suitable for being placed in IOC? (1) Not suitable for: stateless objects, that is, there are no member variables that change the state of the current object (2) suitable for: Controller Service Dao Mapper, etc. 3. Scope => Add singleton to cache pool Bean objects are not instantiated into the singleton cache pool --> <! -- singleton with lazy-init in scope --> <! --<bean id="roleServiceSingleton" class="org.example.service.RoleServiceSingleton" lazy-init="false"></bean>--> <! -- singleton scope, --> <bean id="roleServiceSingleton" class="org.example.service.RoleServiceSingleton" scope="singleton"></bean> <! -- prototype scope, ProxyBeanMethods =false--> <bean id="roleServicePrototype" class="org.example.service.RoleServicePrototype" scope="prototype"></bean> </beans>Copy the code


(4) The lifecycle of the bean

  • Bean object definition, initialization, use, destroy
  • Bean definition
    • Define the beans in the configuration file
    • The corresponding bean object is defined through the bean tag
  • Bean initialization= >Init -method="init"= >And implement the method in the class
    • When the IOC container starts, the bean object is automatically instantiated
    • 1. Run the init-method attribute in the configuration file
    • 2. Implement org. Springframework. Beans. Factory. InitializingBean interface
  • Using the beans
    • 1. Use the BeanFactory object
    • 2. Use ApplicationContext
  • The destruction of the bean= >-method="destroy"= >And implement the method in the class
    • 1. Through AbstractApplicationContext object, call the close method implementation bean destruction process
    • 2. Specify destory-method in the configuration file


(5) BigDecimal

  • In Java (flot precision is 6-7 significant digits) and (double precision is 15-16 significant digits)
  • BigDecimal(String) => Precision loss does not occur and is recommended
  • BigDecimal is Immutable, that is, Immutable. Each step of the computation produces a new object, so it is necessary to store the value of the operation when doing the computation
  • dividemethods
    • java.math.BigDecimal.divide(BigDecimal divisor, int scale, int roundingMode)
    • parameter
      • Divisor is divisor
      • Scale keeps a number of decimal places
      • RoundingMode indicates a mode, such as rounding BigDecimal.ROUND_HALF_UP
    • Returns a BigDecimal
  • The constructor
The constructor describes how BigDecimal(int) creates an object with the integer value specified by the argument. BigDecimal(double) creates an object with the double value specified by the argument. BigDecimal(Long) creates an object with a long integer value specified by the argument. BigDecimal(String) creates an object with a String value specified by the argument. ----------------- is recommended, without loss of accuracyCopy the code
  • function
The add(BigDecimal) method describes adding the values in a BigDecimal object and then returning the object. ----------- + subtract(BigDecimal) The value in the BigDecimal object, and then return the object. ----------- - multiply(BigDecimal) Multiply the values in a BigDecimal object and then return the object. ----------- * divide(BigDecimal) The values in the BigDecimal object and return the object. ----------- / toString() converts the numeric value of a BigDecimal object to a string. DoubleValue () returns the value in a BigDecimal object as a double. FloatValue () returns the value in the BigDecimal object as a single precision number. LongValue () returns the value in a BigDecimal object as a long integer. IntValue () returns the value in the BigDecimal object as an integer.Copy the code
  • Test test test test test test test test test test
@SpringBootTest @Slf4j public class BigDecimalTest { @Autowired BigDecimalUtil bigDecimalUtil; @test void Test () {double a = 0.1; Double b = 0.2; double c = a + b; System.out.println(c); // add BigDecimal aa = new BigDecimal("1.11"); BigDecimal BB = new BigDecimal("2.22"); BigDecimal cc = aa.add(bb); Log.info ("BigDecimal instance add() method, BigDecimal(String) does not show precision loss => test 1.11+2.22={}", cc); // divide BigDecimal dd = new BigDecimal("30"); BigDecimal ee = new BigDecimal("7"); BigDecimal ff = dd.divide(ee, 2, BigDecimal.ROUND_HALF_UP); Log. Info ("BigDecimal instance. Divide (BigDecimal divisor, int scale, int roundingMode) => 30/7={}", ff); Log.info ("(divisor: divisor), (scale: reserved decimal number), (roundingMode: reserved mode, such as rounding)"); // util BigDecimal divideUtilRes = bigDecimalUtil.div(30, 7, 2, BigDecimal.ROUND_HALF_UP); log.info("divideUtil{}", divideUtilRes); }}Copy the code



(6) IDEA commonly used plug-in

  • Codota code completion plug-in
  • GsonFormat formats JSON data into bean objects (using the shortcut: Alt + S)

(2) Spring IOC scanner

  • The function of the scanner: the same management of bean objects, simplify development configuration, improve development efficiency
  • steps
    • Set the scope of the automated scan (because not all Javabeans need to be deinstantiated)
    • Use the specified annotation
      • Dao layer — — — — — — — — — — — — — — @ the Repository
      • Service layer — — — — — — — — — — @ Service
      • The Controller layer – — — — — — – the @ Controller
      • Any kind of — — — — — — — — — — — — — @ Component
  • Spring IOC scanner configuration
(1) Spring IOC scanner configuration SRC/main/resources/bean bean. The XML -- -- -- -- -- -- -- <? The XML version = "1.0" encoding = "utf-8"? > <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <! -- Manual injection --> <! -- id: specifies the name of the component in the container. -- class: represents the full path of the bean object --> <! -- property: represents a property in the bean object --> <! -- name: indicates the specific attribute name --> <! -- ref: indicates the name of the component in the container, that is, the id attribute in the bean label --> <! --<bean id="userService" class="org.example.UserService">--> <! --property name="userBean" ref="userBean"/>--> <! --</bean>--> <! --<bean id="userBean" class="org.example.UserBean"></bean>--> <! -- Automatic injection --> <! - 1. Automatic injection allocation need to add the beans = > XMLNS: context = "http://www.springframework.org/schema/context" > <! --2. Add beans => xSI :schemaLocation also adds something, as above --> <! --3. Auto-injection configuration requires adding <context:annotation-config/> <! --4. Note that there is another difference between automatic injection and manual injection of XML configuration in addition to 123: To use userBeans in UserService, automatic injection does not need to use property --> <! -- <context:annotation-config/>--> <! -- <bean id="userService" class="org.example.UserService"></bean>--> <! -- <bean id="userBean" class="org.example.UserBean"></bean>--> <! -- <bean id="userImplements" class="org.example.UserImplements"></bean>--> <! -- <bean id="userImplements2" class="org.example.UserImplements2"></bean>--> <! -- <bean id="autowiredBean2" class="org.example.AutowiredBean"></bean>--> <! -- Spring IOC scanner --> <! -- Spring IOC scanner 1. Role: The same management of bean objects, simplify development configuration 2. 1. Set the scope of the automatic scan in the XML with the Context: Component-scan base-package tag. - If the bean object is not in the scope of the scan, it will not be instantiated even if the annotation is declared. Adds the specified annotation to the class that needs to be instantiated, For example, @repository @service @controller @Component - DAO @repository - Service @service-controller @controller - any class The (ID) of the @Component 3. bean object defaults to (lowercase class name) --> <! <context:component-scan base-package="org.example"/> </beans>Copy the code
  • Test (2) (3) — — — — — — —@Repository
    • @Repository:To indicate that the class is used to perform database-related operations (that is, DAO objects) and to support automatic handling of exceptions arising from database operations
(2) the statement dao SRC/main/Java/org. Example/dao/TypeDao Java -- -- -- -- -- -- -- @ Repository public class TypeDao {public void test () { System.out.println("IOC scanner configuration "); System. The out. Println (" @ Repository test "); }}Copy the code
(3) using the dao SRC/main/Java/org. Example/App. Java -- -- -- -- -- -- -- the public class App {public static void main (String [] args) { System.out.println("Hello World!" ); ApplicationContext ac = new ClassPathXmlApplicationContext("bean/bean.xml"); TypeDao typeDao = (TypeDao) ac.getBean("typeDao"); typeDao.test(); }}Copy the code
  • (4) ——- @service + @resource (@autowired)
@Service public class TypeService { @Resource TypeDao typeDao; Public void test() {system.out.println (" @service test + @resource test "); typeDao.test(); }}Copy the code


(3) Transaction

  • Transactions are typically handled at the Service layer because services are logically related to mapper
  • Java stored in theThe amount ofType withBigDecimaltype
  • Database (rollback) concept
    • In the process of transaction running, some fault occurs, the transaction can not continue to execute, the system will be in the transaction of all completed operations on the database, rolling back to the state at the beginning of the transaction

(1) How to use, use case

(1-1) @Transactional transaction annotation, typically used in the Service layer

  • 1. First of all, on the main class add @ EnableTransactionManagement SpringBoot said open transactions
  • 2. In the service layer to add @ Transactional = > can add on the class, also can add on the class of methods, is not the same as the scope, even on loading interface
  • 3.What happens if you put @Transactional on the class and on the methods of the class?
    • Method transactions override class transactions
    • Adding transactions to an Interface is not recommended
  • 3.@Transactional is a Spring annotation, not a SpringBoot annotation
// The main program class, The master configuration class @ SpringBootApplication @ EnableTransactionManagement / / open SpringBoot transaction support public class Application {... }Copy the code
@Service public class TransactionService{ @Autowired TransactionMapper transactionMapper; }}}}}}}}}}}}}}}}}}}}} But the data would be inserted into the database of public int addGoods (Map body) {int res = transactionMapper. InsertGoods (body); int i = 1/0; // Return error; }}Copy the code

(2) Some concepts of transactions

(2-1) Four characteristics of transactions

  • atomic Atomicity
    • Live or die, all or nothing
  • consistency Consistency
    • Data in the database must be consistent before and after transaction execution
    • There is only (pre-submission state) and (post-submission state), there can be no intermediate state
  • Isolation, Isolation
    • Transactions should be executed in isolation from each other
    • When multiple users are concurrently, each transaction is isolated
    • Divided into
      • Read uncommitted
      • Reading has been submitted
      • Repeatable read
      • serialization
  • Persistence Durability



(四) jackson

  • Compare fastJSON, Gson and Jackson

(1) Jackson installation

  • It’s usually used in SpringBootspring-boot-starter-webScene initiator, which is already includedjackson
  • If you don’t usespring-boot-starter-webThen install it yourselfspring-boot-starter-json
<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-json</artifactId>
</dependency>
Copy the code

(2) Jackson used

  • @JsonFormat()
  • @JsonPropertyOrder()
  • @JsonProperty()
  • @JsonInclude()
  • @JsonIgnore

(2-1) @JsonFormat()

  • Date formatting configuration (property @jsonFormat annotation in bean object > Global Configuration)
  • Priority: Bean configuration > Global Configuration
  • @JsonFormat(pattern = "YYYY-MM-DD HH:dd:ss", timezone = "GMT+8")
Yml ------- spring: Jackson: date-format: YYYY-mm-dd HH= MM =ss # Date-format: yyyy-mm-dd HH= MM =ss # GMT + 8 time zone (2) the date format bean configured in SRC/main/Java/com. The example. The demo/bean/MusicTestBean Java -- -- -- -- -- -- -- @ Data @ AllArgsConstructor Public class MusicTestBean {@apiModelProperty (name = "name", name = "name"); Value = "swagger ") private String name; // @jsonFormat (pattern = "YYYY-MM-DD HH: DD :ss", timezone = "GMT+8") private String endTime; }Copy the code

(2-2) @JsonPropertyOrder()

  • @jsonpropertyOrder (value = {“singer”, “name”}) adjusts the properties of the property so that singer is ranked before name
@Data @JsonPropertyOrder(value = {"singer", "name"}) public class MusicTestBean { private String name; // Private String album; // private String singer; // singer private Integer id; @JsonFormat(pattern = "YYYY-MM-DD HH:dd:ss", timezone = "GMT+8") private Date startTime; private String endTime; {"id": 1, "name": "Drift 112233", "album":" Qilixiang 112233", "Singer ":" Chou 112233", "startTime": "2021-02-02 23:48:34", "endTime": "2021-02-13 23:48:41"}, "Jay Chou, 112233," / / -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- 1 "name" : "112233" drift, / / -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- 2 "album" : Qi li xiang "112233", "id" : 1, "startTime" : "3 23:02:34 2021-02-3", "endTime" : "the 2021-02-13 23:48:41"},Copy the code

(2-3) @ JsonProperty ()

  • @jsonProperty (“musicName”) // Jackson’s annotation to change the name of the property, note: this does not affect @jsonpropertyOrder
// note: // 1. If (parameter constructor) is added, (must add no parameter constructor) // 2. Only add (no constructor), @data @allargsconstructor @noargsconstructor @ApiModel(" song ") // Swagger annotation @jsonPropertyOrder (value = {"singer", "name"}) Public class MusicTestBean {@apiModelProperty (name = "name", value = "name") @jsonPropertyOrder private String Name; @jsonPropertyOrder private String Name; @jsonPropertyOrder private String Name; @apiModelProperty (name = "album", value = "album") private String album; @apiModelProperty (name = "singer", value = "singer") private String singer; // singer private Integer id; @jsonFormat (pattern = "YYYY-MM-DD HH: DD :ss", timezone = "GMT+8") private Date startTime; private String endTime; }Copy the code

(2-4) @JsonInclude()

  • @jsoninclude (jsoninclude.include.non_null) If it is null, the field is not returned
@jsoninclude (jsoninclude.include.non_null) @jsoninclude (jsoninclude.include.non_null)Copy the code

(2-5) @JsonIgnore

The @jsonignore Jackson annotation ignores the property, that is, does not return the field

@jsonignore // Jackson's annotation, which ignores the property, that is, does not return the field private Integer ID;Copy the code





Program source code

  • Program source code
  • Online access to address – song additions and deletes to check

data

@ the Repository and the difference of the @ Mapper www.jianshu.com/p/3942f6b4f… Jackson www.jianshu.com/p/b804874b7…