Spring MVC4+maven3+MyBatis3+Oracle11和mysql项目搭建

2024-08-24 23:38

本文主要是介绍Spring MVC4+maven3+MyBatis3+Oracle11和mysql项目搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

环境

MyEclipse 10、JDK 1.7、Tomcat 7.0

搭建

一、新建maven工程,步骤略,建好后目录结构如下图:


二、pom文件配置

[html]  view plain copy
  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  2.   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">  
  3.   <modelVersion>4.0.0</modelVersion>  
  4.   <groupId>com.alan</groupId>  
  5.   <artifactId>smis</artifactId>  
  6.   <packaging>war</packaging>  
  7.   <version>1.0-SNAPSHOT</version>  
  8.   <name>smis</name>  
  9.   <url>http://maven.apache.org</url>  
  10.     
  11.    <properties>  
  12.         <!-- spring版本号 -->  
  13.         <spring.version>4.0.6.RELEASE</spring.version>  
  14.         <!-- mybatis版本号 -->  
  15.         <mybatis.version>3.2.7</mybatis.version>  
  16.         <!-- log4j日志文件管理包版本 -->  
  17.         <slf4j.version>1.7.21</slf4j.version>  
  18.         <log4j.version>1.2.17</log4j.version>  
  19.         <sitemesh.version>3.0.0</sitemesh.version>  
  20.     </properties>  
  21.     
  22.   <dependencies>  
  23.         <!-- spring核心包 -->  
  24.         <dependency>  
  25.             <groupId>org.springframework</groupId>  
  26.             <artifactId>spring-core</artifactId>  
  27.             <version>${spring.version}</version>  
  28.         </dependency>  
  29.         <dependency>  
  30.             <groupId>org.springframework</groupId>  
  31.             <artifactId>spring-web</artifactId>  
  32.             <version>${spring.version}</version>  
  33.         </dependency>  
  34.         <dependency>  
  35.             <groupId>org.springframework</groupId>  
  36.             <artifactId>spring-oxm</artifactId>  
  37.             <version>${spring.version}</version>  
  38.         </dependency>  
  39.         <dependency>  
  40.             <groupId>org.springframework</groupId>  
  41.             <artifactId>spring-tx</artifactId>  
  42.             <version>${spring.version}</version>  
  43.         </dependency>  
  44.         <dependency>  
  45.             <groupId>org.springframework</groupId>  
  46.             <artifactId>spring-jdbc</artifactId>  
  47.             <version>${spring.version}</version>  
  48.         </dependency>  
  49.         <dependency>  
  50.             <groupId>org.springframework</groupId>  
  51.             <artifactId>spring-webmvc</artifactId>  
  52.             <version>${spring.version}</version>  
  53.         </dependency>  
  54.         <dependency>  
  55.             <groupId>org.springframework</groupId>  
  56.             <artifactId>spring-aop</artifactId>  
  57.             <version>${spring.version}</version>  
  58.         </dependency>  
  59.         <dependency>  
  60.             <groupId>org.springframework</groupId>  
  61.             <artifactId>spring-context-support</artifactId>  
  62.             <version>${spring.version}</version>  
  63.         </dependency>  
  64.         <dependency>  
  65.             <groupId>org.springframework</groupId>  
  66.             <artifactId>spring-test</artifactId>  
  67.             <version>${spring.version}</version>  
  68.         </dependency>  
  69.           
  70.         <!-- mybatis核心包 -->  
  71.         <dependency>  
  72.             <groupId>org.mybatis</groupId>  
  73.             <artifactId>mybatis</artifactId>  
  74.             <version>${mybatis.version}</version>  
  75.         </dependency>  
  76.         <!-- mybatis/spring包 -->  
  77.         <dependency>  
  78.             <groupId>org.mybatis</groupId>  
  79.             <artifactId>mybatis-spring</artifactId>  
  80.             <version>1.2.2</version>  
  81.         </dependency>  
  82.         <dependency>  
  83.             <groupId>commons-dbcp</groupId>  
  84.             <artifactId>commons-dbcp</artifactId>  
  85.             <version>1.4</version>  
  86.         </dependency>  
  87.         <!-- Oracle驱动包 -->  
  88.         <dependency>  
  89.             <groupId>com.oracle</groupId>  
  90.             <artifactId>ojdbc6</artifactId>  
  91.             <version>11.2.0.1.0</version>  
  92.         </dependency>  
  93.   
  94.         <!-- junit测试包 -->  
  95.         <dependency>  
  96.             <groupId>junit</groupId>  
  97.             <artifactId>junit</artifactId>  
  98.             <version>4.11</version>  
  99.             <scope>test</scope>  
  100.         </dependency>  
  101.           
  102.         <!-- 阿里巴巴数据源包 -->  
  103.         <dependency>  
  104.             <groupId>com.alibaba</groupId>  
  105.             <artifactId>druid</artifactId>  
  106.             <version>1.0.20</version>  
  107.         </dependency>  
  108.           
  109.         <!-- json数据 -->  
  110.         <dependency>  
  111.             <groupId>org.codehaus.jackson</groupId>  
  112.             <artifactId>jackson-mapper-asl</artifactId>  
  113.             <version>1.9.13</version>  
  114.         </dependency>  
  115.           
  116.         <!-- 上传下载 -->    
  117.         <dependency>    
  118.             <groupId>commons-fileupload</groupId>    
  119.             <artifactId>commons-fileupload</artifactId>    
  120.             <version>1.3.1</version>    
  121.         </dependency>    
  122.         <dependency>    
  123.             <groupId>commons-io</groupId>    
  124.             <artifactId>commons-io</artifactId>    
  125.             <version>2.4</version>    
  126.         </dependency>    
  127.         <dependency>    
  128.             <groupId>commons-codec</groupId>    
  129.             <artifactId>commons-codec</artifactId>    
  130.             <version>1.9</version>    
  131.         </dependency>    
  132.           
  133.         <!-- JSTL标签包开始 -->  
  134.         <dependency>  
  135.             <groupId>jstl</groupId>  
  136.             <artifactId>jstl</artifactId>  
  137.             <version>1.2</version>  
  138.         </dependency>  
  139.         <dependency>  
  140.             <groupId>taglibs</groupId>  
  141.             <artifactId>standard</artifactId>  
  142.             <version>1.1.2</version>  
  143.         </dependency>  
  144.           
  145.         <!-- 日志文件管理包 -->  
  146.         <dependency>  
  147.             <groupId>log4j</groupId>  
  148.             <artifactId>log4j</artifactId>  
  149.             <version>${log4j.version}</version>  
  150.         </dependency>  
  151.         <dependency>  
  152.             <groupId>org.slf4j</groupId>  
  153.             <artifactId>slf4j-api</artifactId>  
  154.             <version>${slf4j.version}</version>  
  155.         </dependency>  
  156.         <dependency>  
  157.             <groupId>org.slf4j</groupId>  
  158.             <artifactId>slf4j-log4j12</artifactId>  
  159.             <version>${slf4j.version}</version>  
  160.         </dependency>  
  161.           
  162.         <!-- sitemesh -->  
  163.         <dependency>   
  164.              <groupId>org.sitemesh</groupId>   
  165.              <artifactId>sitemesh</artifactId>   
  166.              <version>${sitemesh.version}</version>   
  167.         </dependency>  
  168.   </dependencies>  
  169.   <build>  
  170.     <finalName>smis</finalName>  
  171.   </build>  
  172. </project>  

三、web.xml配置

[html]  view plain copy
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  3.     xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"  
  4.     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"  
  5.     id="WebApp_ID" version="2.5">  
  6.     <display-name>smis</display-name>  
  7.   
  8.     <!-- 读取spring配置文件 -->  
  9.     <context-param>  
  10.         <param-name>contextConfigLocation</param-name>  
  11.         <param-value>  
  12.             classpath:application/spring-mybatis.xml  
  13.         </param-value>  
  14.     </context-param>  
  15.   
  16.     <!-- Spring字符集过滤器 -->  
  17.     <filter>  
  18.         <filter-name>SpringEncodingFilter</filter-name>  
  19.         <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>  
  20.         <init-param>  
  21.             <param-name>encoding</param-name>  
  22.             <param-value>UTF-8</param-value>  
  23.         </init-param>  
  24.         <init-param>  
  25.             <param-name>forceEncoding</param-name>  
  26.             <param-value>true</param-value>  
  27.         </init-param>  
  28.     </filter>  
  29.     <filter-mapping>  
  30.         <filter-name>SpringEncodingFilter</filter-name>  
  31.         <url-pattern>/*</url-pattern>  
  32.     </filter-mapping>  
  33.   
  34.     <!-- 日志记录 -->  
  35.     <context-param>  
  36.         <!-- 日志配置文件路径 -->  
  37.         <param-name>log4jConfigLocation</param-name>  
  38.         <param-value>classpath:properties/log4j.properties</param-value>  
  39.     </context-param>  
  40.     <context-param>  
  41.         <!-- 日志页面的刷新间隔 -->  
  42.         <param-name>log4jRefreshInterval</param-name>  
  43.         <param-value>6000</param-value>  
  44.     </context-param>  
  45.     <listener>  
  46.         <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>  
  47.     </listener>  
  48.   
  49.     <listener>  
  50.         <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
  51.     </listener>  
  52.   
  53.     <!-- springMVC核心配置 -->  
  54.     <servlet>  
  55.         <servlet-name>spring</servlet-name>  
  56.         <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
  57.         <init-param>  
  58.             <param-name>contextConfigLocation</param-name>  
  59.             <param-value>classpath:application/spring-mvc.xml</param-value>  
  60.         </init-param>  
  61.         <load-on-startup>1</load-on-startup>  
  62.     </servlet>  
  63.     <servlet-mapping>  
  64.         <servlet-name>spring</servlet-name>  
  65.         <url-pattern>*.do</url-pattern>  
  66.     </servlet-mapping>  
  67.   
  68.     <welcome-file-list>  
  69.         <welcome-file>index.jsp</welcome-file>  
  70.     </welcome-file-list>  
  71.   
  72.     <!-- 错误跳转页面 -->  
  73.     <error-page>  
  74.         <!-- 路径不正确 -->  
  75.         <error-code>404</error-code>  
  76.         <location>/WEB-INF/error/404.jsp</location>  
  77.     </error-page>  
  78.     <error-page>  
  79.         <!-- 没有访问权限,访问被禁止 -->  
  80.         <error-code>405</error-code>  
  81.         <location>/WEB-INF/error/405.jsp</location>  
  82.     </error-page>  
  83.     <error-page>  
  84.         <!-- 内部错误 -->  
  85.         <error-code>500</error-code>  
  86.         <location>/WEB-INF/error/500.jsp</location>  
  87.     </error-page>  
  88. </web-app>  

四、spring-mvc.xml配置

[html]  view plain copy
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.   xmlns:p="http://www.springframework.org/schema/p"  
  4.   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  5.   xmlns:context="http://www.springframework.org/schema/context"  
  6.   xmlns:mvc="http://www.springframework.org/schema/mvc"  
  7.   xmlns:websocket="http://www.springframework.org/schema/websocket"  
  8.   xsi:schemaLocation="  
  9.     http://www.springframework.org/schema/beans   
  10.     http://www.springframework.org/schema/beans/spring-beans-4.0.xsd  
  11.     http://www.springframework.org/schema/context  
  12.     http://www.springframework.org/schema/context/spring-context-4.0.xsd  
  13.     http://www.springframework.org/schema/mvc  
  14.     http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">  
  15.       
  16.     <!-- 添加注解驱动 -->   
  17.    <mvc:annotation-driven />  
  18.     <!-- 扫描controller(controller层注入) -->  
  19.    <context:component-scan base-package="com.alan.smis.controller"/>  
  20.      
  21.    <!-- 避免IE在ajax请求时,返回json出现下载 -->  
  22.    <bean id="jacksonMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">       
  23.         <property name="supportedMediaTypes">  
  24.             <list>  
  25.                 <value>text/html;charset=UTF-8</value>  
  26.             </list>  
  27.         </property>  
  28.     </bean>  
  29.       
  30.     <!-- 配置国际化拦截器 -->   
  31.     <!-- 拦截参数 -->  
  32.     <bean id="messageSource"  
  33.         class="org.springframework.context.support.ReloadableResourceBundleMessageSource">  
  34.         <property name="basename" value="classpath:/messages/messages" />  
  35.         <property name="defaultEncoding" value="UTF-8" />  
  36.     </bean>  
  37.     <bean id="localeChangeInterceptor"  
  38.         class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor">  
  39.         <property name="paramName" value="lang" />  
  40.     </bean>  
  41.     <bean id="localeResolver"  
  42.         class="org.springframework.web.servlet.i18n.CookieLocaleResolver" />  
  43.     <bean id="requestMappingHandlerMapping"  
  44.         class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping" />  
  45.       
  46.    <!-- 对模型视图添加前后缀 -->  
  47.     <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">     
  48.         <property name="order" value="1" />  
  49.         <property name="viewClass"  
  50.             value="org.springframework.web.servlet.view.JstlView" />  
  51.         <property name="prefix" value="/WEB-INF/jsp/" />    
  52.         <property name="suffix" value=".jsp" />    
  53.     </bean>    
  54.       
  55.     <!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 -->    
  56.     <bean id="multipartResolver"      
  57.         class="org.springframework.web.multipart.commons.CommonsMultipartResolver">      
  58.         <!-- 默认编码 -->    
  59.         <property name="defaultEncoding" value="utf-8" />      
  60.         <!-- 文件大小最大值 -->    
  61.         <property name="maxUploadSize" value="10485760000" />      
  62.         <!-- 内存中的最大值 -->    
  63.         <property name="maxInMemorySize" value="40960" />      
  64.     </bean>  
  65. </beans>  

五、spring-mybatis.xml配置

[html]  view plain copy
  1. <?xml version="1.0" encoding="UTF-8"?>    
  2. <beans xmlns="http://www.springframework.org/schema/beans"    
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"    
  4.     xmlns:context="http://www.springframework.org/schema/context"    
  5.     xmlns:mvc="http://www.springframework.org/schema/mvc"    
  6.     xsi:schemaLocation="http://www.springframework.org/schema/beans      
  7.                         http://www.springframework.org/schema/beans/spring-beans-4.0.xsd      
  8.                         http://www.springframework.org/schema/context      
  9.                         http://www.springframework.org/schema/context/spring-context-4.0.xsd      
  10.                         http://www.springframework.org/schema/mvc      
  11.                         http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">   
  12.       
  13.     <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"    
  14.          destroy-method="close">    
  15.          <property name="driverClassName" value="${jdbc.driver}" />    
  16.          <property name="url" value="${jdbc.url}" />    
  17.          <property name="username" value="${jdbc.username}" />    
  18.          <property name="password" value="${jdbc.password}" />    
  19.          <!-- 初始化连接大小 -->    
  20.          <property name="initialSize" value="${jdbc.initialSize}"></property>    
  21.          <!-- 连接池最大数量 -->    
  22.          <property name="maxActive" value="${jdbc.maxActive}"></property>    
  23.          <!-- 连接池最大空闲 -->    
  24.          <property name="maxIdle" value="${jdbc.maxIdle}"></property>    
  25.          <!-- 连接池最小空闲 -->    
  26.          <property name="minIdle" value="${jdbc.minIdle}"></property>    
  27.          <!-- 获取连接最大等待时间 -->    
  28.          <property name="maxWait" value="${jdbc.maxWait}"></property>    
  29.          <!-- 连接属性 -->  
  30.         <property name="connectionProperties">  
  31.           <value>clientEncoding=UTF-8</value>  
  32.         </property>  
  33.      </bean>  
  34.        
  35.      <!-- 加载jdbc -->  
  36.      <context:property-placeholder location="classpath:properties/jdbc.properties"/>  
  37.         
  38.      <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->    
  39.      <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">    
  40.          <property name="dataSource" ref="dataSource" />    
  41.          <!-- 自动扫描mapping.xml文件 -->    
  42.          <property name="mapperLocations" value="classpath:mapper/*Mapper.xml"></property>  
  43.      </bean>  
  44.          
  45.     <!-- DAO接口所在包名,Spring会自动查找其下的类 -->    
  46.     <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">    
  47.         <property name="basePackage" value="com.alan.smis.mapper" />    
  48.         <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>    
  49.     </bean>    
  50.     
  51.     <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->    
  52.     <bean id="transactionManager"    
  53.         class="org.springframework.jdbc.datasource.DataSourceTransactionManager">    
  54.         <property name="dataSource" ref="dataSource" />    
  55.     </bean>    
  56. </beans>  

六、jdbc配置

[html]  view plain copy
  1. jdbc.driver=oracle.jdbc.driver.OracleDriver  
  2. jdbc.url=jdbc:oracle:thin:@192.168.1.236:1521:greendb  
  3. jdbc.username=alan  
  4. jdbc.password=alan123  
  5. jdbc.initialSize=0   
  6. jdbc.maxActive=100   
  7. jdbc.maxIdle=20  
  8. jdbc.minIdle=1  
  9. jdbc.maxWait=60000  

七、log4j配置

[html]  view plain copy
  1.  log4j.rootLogger=INFO,Console,File    
  2. #\u5B9A\u4E49\u65E5\u5FD7\u8F93\u51FA\u76EE\u7684\u5730\u4E3A\u63A7\u5236\u53F0    
  3. log4j.appender.Console=org.apache.log4j.ConsoleAppender    
  4. log4j.appender.Console.Target=System.out    
  5. #\u53EF\u4EE5\u7075\u6D3B\u5730\u6307\u5B9A\u65E5\u5FD7\u8F93\u51FA\u683C\u5F0F\uFF0C\u4E0B\u9762\u4E00\u884C\u662F\u6307\u5B9A\u5177\u4F53\u7684\u683C\u5F0F    
  6. log4j.appender.Console.layout = org.apache.log4j.PatternLayout    
  7. log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n    
  8.     
  9. #\u6587\u4EF6\u5927\u5C0F\u5230\u8FBE\u6307\u5B9A\u5C3A\u5BF8\u7684\u65F6\u5019\u4EA7\u751F\u4E00\u4E2A\u65B0\u7684\u6587\u4EF6    
  10. log4j.appender.File = org.apache.log4j.RollingFileAppender    
  11. #\u6307\u5B9A\u8F93\u51FA\u76EE\u5F55    
  12. log4j.appender.File.File = logs/ssm.log    
  13. #\u5B9A\u4E49\u6587\u4EF6\u6700\u5927\u5927\u5C0F    
  14. log4j.appender.File.MaxFileSize = 10MB    
  15. # \u8F93\u51FA\u6240\u4EE5\u65E5\u5FD7\uFF0C\u5982\u679C\u6362\u6210DEBUG\u8868\u793A\u8F93\u51FADEBUG\u4EE5\u4E0A\u7EA7\u522B\u65E5\u5FD7    
  16. log4j.appender.File.Threshold = ALL    
  17. log4j.appender.File.layout = org.apache.log4j.PatternLayout    
  18. log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n  


mysql数据库:

jdbc配置

driver=com.mysql.jdbc.Driver  
url=jdbc:mysql://10.221.10.111:8080/db_zsl  
username=demao  
password=demao  
#定义初始连接数  
initialSize=0  
#定义最大连接数  
maxActive=20  
#定义最大空闲  
maxIdle=20  
#定义最小空闲  
minIdle=1  
#定义最长等待时间  
maxWait=60000





pom配置

    <!-- mysql --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.31</version></dependency>



至此基本的框架已完毕,当然使用中会有很多的需求需要我们去扩展与完善。仅以此文作为基础继续研究。

这篇关于Spring MVC4+maven3+MyBatis3+Oracle11和mysql项目搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1103939

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template