How does hibernate work and why?
Principle:
1. Read and parse the configuration file
2. Read and parse the ing information and create sessionfactory
3. Open sesssion
4. Create transaction Transation
5. Persistent operations
6. Submit the transaction
7. Disable session
8. Disable sesstionfactory
Why:
1. The code for JDBC database access is encapsulated, which greatly simplifies the tedious and repetitive code at the data access layer.
2. Hibernate is a mainstream persistence framework based on JDBC and an excellent ORM implementation. He greatly simplifies the coding of the DaO layer.
3. hibernate uses the Java reflection mechanism instead of the bytecode enhancement program to achieve transparency.
4. hibernate has excellent performance because it is a lightweight framework. The flexibility of ing is excellent. It supports various relational databases, from one-to-one to many-to-many complex relationships.
2. How does hibernate delay loading?
1. Implementation of hibernate2 delayed loading: a) object B) Collection)
2. hibernate3 provides the property's delayed Loading Function
When hibernate queries data, the data does not exist in the memory. When the program actually operates on the data, the object exists in the memory, and the loading is delayed, it saves the server memory overhead and improves the server performance.
3. How does one implement the relationship between classes in hibernate? (For example, one-to-many and many-to-many relationships)
The relationship between classes is mainly reflected in the relationship between tables. They operate on objects in a city. In our program, all tables and classes are mapped together, they are used in the configuration file named "allow-to-one", "one-to-allow", "allow-to-allow,
4. Talk about the cache mechanism of Hibernate
1. The internal cache exists in hibernate, which is also called a level-1 cache, which belongs to the application thing-level cache.
2. Secondary cache:
A) Application and Cache
B) distributed cache
Condition: the data is not modified by a third party, the data size is within the acceptable range, the data update frequency is low, the same data is frequently used by the system, non-critical data
C) third-party cache implementation
5. Hibernate query method
SQL, criteria, object comptosition
Hql:
1. query attributes
2. parameter query and name parameter query
3. join query
4. Paging Query
5. Statistical functions
6. How to optimize hibernate?
1. Use bidirectional one-to-Multiple Association instead of unidirectional one-to-Multiple Association
2. flexible use of one-to-multiple associations
3. Replace multiple-to-one instead of one-to-one
4. Configure the object cache without using the set Cache
5. Use bag for one-to-multiple sets and set for multiple-to-multiple sets
6. Use explicit polymorphism for inheritance classes
7. Fewer table fields, no more table Association, and secondary cache support
7. How does struts work? Why use struts?
Working mechanism:
Struts workflow:
When the web application starts, the initialization actionservlet will be loaded, and the actionservlet will
Read configuration information in the struts-config.xml file and store them to various configuration objects
When the actionservlet receives a customer request, it will execute the following process.
-(1) retrieve the actionmapping instance that matches the user request. If it does not exist, the system returns invalid information about the request path;
-(2) if the actionform instance does not exist, create an actionform object and save the form data submitted by the customer to the actionform object;
-(3) determine whether form verification is required based on the configuration information. If form verification is required, call the validate () method of actionform;
-(4) if the validate () method of actionform returns NULL or an actuiberrors object that does not contain actionmessage is returned, the form verification is successful;
-(5) The actionservlet determines the action to which the request is forwarded based on the actioning information contained in the actionmapping. If the corresponding action instance does not exist, create the instance first, and then call the action's execute () method;
-(6) The execute () method of action returns an actionforward object. The actionservlet is forwarding the client request to the JSP component pointed to by the actionforward object;
-(7) The actionforward object directs to the JSP component to generate a dynamic webpage and return it to the customer;
Why:
The emergence of JSP, Servlet, and JavaBean technologies makes it possible for us to build a powerful enterprise application system. However, systems built with these technologies are very messy. Therefore, we need a rule and a rule to organize these technologies. This is the framework, and Struts came into being.
Struts-based applications are composed of three types of components: controller components, model components, and view components.
8. How is the struts validate framework verified?
Configure the specific error message in the struts configuration file, and then call the validate () method in formbean.
9. Let's talk about the struts design model.
MVC mode: When a web application starts, it loads and initializes actionservler. When a user submits a form, a configured actionform object is created and filled with the corresponding data in the form. actionservler determines whether form verification is required based on the settings configured in the Struts-config.xml file, if you need to call the validate () Verification of actionform, select the action to which the request is sent. If the action does not exist, actionservlet will first create this object and then call the action's execute () method. Execute () obtains data from the actionform object, completes the business logic, returns an actionforward object, and the actionservlet then forwards the customer request to the JSP component specified by the actionforward object, the JSP specified by the actionforward object generates a dynamic webpage and returns it to the customer.
10. Why does spring work?
1. Spring MVC requests all requests to be submitted to dispatcherservlet. It will entrust other modules of the application system to handle the requests in real time.
2. The dispatcherservlet queries one or more handlermapping and finds the Controller that processes the request.
3. Submit the dispatcherservlet request to the target controller.
4. After the controller processes the business logic, a modelandview is returned.
5. The dispathcher queries one or more viewresolver view Resolvers and finds the view object specified by the modelandview object.
6. view objects are rendered and returned to the client.
Why:
{AOP allows developers to create non-behavioral concerns, known as cross-cutting concerns, and insert them into application code. With AOP, public services (such as logs, persistence, and transactions) can be decomposed into aspects and applied to domain objects without increasing the complexity of the Object Model of domain objects.
IOC allows you to create an application environment that can construct objects and then pass their collaboration objects to these objects. As the word inversion indicates, IOC is like the reversed JNDI. Instead of using a bunch of abstract factories, service locators, Singleton, and straight construction, each object is constructed with its collaborative object. Therefore, collaborator is managed by containers ).
Even an AOP framework, spring is also an IOC container. The best thing about spring is that it helps you replace objects. With Spring, you only need to add dependencies (collaboration objects) with the JavaBean attribute and configuration file ). Then, you can easily replace the collaboration object with similar interfaces as needed .}
The Spring framework is a layered architecture consisting of seven well-defined modules. The spring module is built on the core container. The core container defines how to create, configure, and manage beans, as shown in figure 1.
Each module (or component) that makes up the Spring framework can exist independently or be implemented together with one or more modules. The functions of each module are as follows:
☆Core container: the Core container provides the basic functions of the Spring framework. The main component of the core container is beanfactory, which is the implementation of the factory mode. Beanfactory uses the control reversal (IOC) mode to separate application configuration and dependency specifications from actual application code.
☆Spring context: Spring context is a configuration file that provides context information to the Spring framework. Spring context includes enterprise services, such as JNDI, EJB, email, internationalization, checksum and scheduling.
☆Spring AOP: Through the configuration management feature, the Spring AOP module directly integrates Aspect-oriented programming functions into the spring framework. Therefore, any objects managed by the Spring framework can easily support AOP. The Spring AOP module provides transaction management services for objects in spring-based applications. By using Spring AOP, You can integrate declarative transaction management into applications without relying on EJB components.
☆Spring Dao: The JDBC Dao abstraction layer provides a meaningful exception hierarchy for managing Exception Handling and error messages thrown by different database vendors. The exception hierarchy simplifies error handling and greatly reduces the number of Exception Code to be written (for example, opening and closing connections ). JDBC-oriented exceptions of spring Dao follow the common Dao exception hierarchy.
☆Spring ORM: The Spring framework inserts several ORM frameworks to provide ORM Object Relational tools, including JDO, hibernate, and ibatis SQL map. All of these comply with the general transactions and Dao exception hierarchies of spring.
☆Spring web module: The Web context module is built on the application context module and provides context for Web-based applications. Therefore, the Spring framework supports integration with Jakarta Struts. The web module also simplifies processing multiple requests and Binding Request Parameters to domain objects.
☆Spring MVC framework: the MVC Framework is a full-featured MVC implementation for Building Web applications. Through the policy interface, the MVC framework becomes highly configurable. MVC supports a large number of view technologies, including JSP, velocity, tiles, itext, and poi.
The functions of the Spring framework can be used on any J2EE server. Most of the functions are also applicable to unmanaged environments. Spring supports reusable services and data access objects that are not bound to a specific J2EE service. There is no doubt that such objects can be reused between different J2EE environments (web or EJB), independent applications, and test environments.
IOC and AOP
The basic concept of the inversion mode (also known as dependency intervention) is to describe how to create objects without creating them. The Code does not directly connect to objects and services, but describes which component needs which service in the configuration file. Containers (IOC containers in the Spring framework) are responsible for connecting these together.
In a typical IOC scenario, the container creates all objects and sets the necessary properties to connect them together to determine the time to call the method. The following table lists an implementation mode of IOC.
The IOC container of the Spring framework is implemented by Type 2 and Type 3.
Aspect-Oriented Programming
Aspect-oriented programming (AOP) is a programming technology that allows programmers to modularize the behavior of cross-concern or cross-common division of duties (such as log and transaction management. The core structure of AOP is aspect, which encapsulates the behaviors that affect multiple classes into reusable modules.
AOP and IOC are complementary technologies that use modular methods to solve complex problems in enterprise application development. In a typical object-oriented development method, you may need to place the logging statement in all methods and Java classes to implement the logging function. In the AOP mode, the log service can be modularized in turn and applied to the components that require logs in declarative mode. Of course, the advantage is that the Java class does not need to know the existence of the log service or consider the relevant code. Therefore, application code written with Spring AOP is loosely coupled.
The functions of AOP are fully integrated into the context of Spring transaction management, logs, and other features.
IOC container
The core of spring design is the org. springframework. Beans package, which is designed to be used with the JavaBean Component. This package is usually not directly used by users, but is used by the server as the underlying intermediary for most other functions. The next highest level abstraction is the beanfactory interface, which is an implementation of the factory design pattern and allows the creation and retrieval of objects by name. Beanfactory can also manage relationships between objects.
Beanfactory supports two object models.
□The single-State model provides shared instances for objects with specific names, which can be searched during query. Singleton is the default and most commonly used object model. It is ideal for stateless service objects.
□The prototype model ensures that a separate object is created for each retrieval. When each user needs their own objects, the prototype model is the most suitable.
The concept of Bean Factory is that spring serves as the basis of IOC containers. IOC transfers the responsibility for handling tasks from application code to the framework. As I will demonstrate in the next example, the Spring framework uses the JavaBean attribute and configuration data to indicate the dependencies that must be set.
Beanfactory Interface
Because org. springframework. Beans. Factory. beanfactory is a simple interface, it can be implemented for various underlying storage methods. The most common beanfactory definition is xmlbeanfactory, which loads beans according to the definition in the XML file, as shown in Listing 1.
Listing 1. xmlbeanfactory
Beanfactory factory = new xmlbeanfactory (New fileinputsteam ("mybean. xml "));
The bean defined in the XML file is passively loaded, which means that the bean itself will not be initialized before the bean is needed. To retrieve beans from beanfactory, you only need to call the getbean () method and input the name of the bean to be retrieved, as shown in Listing 2.
Listing 2. getbean ()
Mybean = (mybean) Factory. getbean ("mybean ");
The definition of each bean can be pojo (defined by class name and JavaBean initialization attribute) or factorybean. The factorybean interface adds an indirect level to applications built using the Spring framework.
IOC example
The simplest way to understand control reversal is to look at its practical application. I used an example to summarize Part 1 of the three-part Spring Series, demonstrate how to inject application dependencies through the Spring IoC container (instead of building them in ).
I started with an online credit account use case. To enable a credit account, you must interact with the following services:
☆Credit level evaluation service, which queries users' credit history information.
☆Remote Information Link Service, insert customer information, connect customer information with credit card and bank information for automatic debit (if needed ).
☆Email Service sends an email about the credit card status to the user.
Three Interfaces
For this example, I assume that the service already exists. Ideally, they are integrated in a loosely coupled manner. The following list shows the application interfaces of the three services.
Listing 3. creditratinginterface
Public interface creditratinginterface {
Public Boolean getusercredithistoryinformation (icustomer );
}
The credit level evaluation interface shown in listing 3 provides credit history information. It requires a customer object containing customer information. The implementation of this interface is provided by the creditrating class.
Listing 4. creditlinkinginterface
Public interface creditlinkinginterface {
Public String geturl ();
Public void seturl (string URL );
Public void linkcreditbankaccount () throws exception;
}
The credit Link interface connects the credit history information with the bank information (if needed) and inserts the user's credit card information. The credit Link interface is a remote service and its query is carried out through the geturl () method. The URL is set by the bean configuration mechanism of the Spring framework. I will discuss it later. The implementation of this interface is provided by the creditlinking class.
Listing 5. emailinterface
Public interface emailinterface {
Public void sendemail (icustomer );
Public String getfromemail ();
Public void setfromemail (string fromemail );
Public String GetPassword ();
Public void setpassword (string password );
Public String getsmtphost ();
Public void setsmtphost (string smtphost );
Public String getuserid ();
Public void setuserid (string userid );