数据库相关
- 一对一操作相当于特殊的一对多操作。1对多,一是父表,n是子表
- 内连接:查询所有符合条件的数据,并且要求结果在两张表内都有相对应的记录。
- 左外连接:查询左侧表中所有符合条件的数据,即使右侧表中没有的数据。
- 如果外键不能为空,多表查询优先使用内连接,外键为空,如果查询另一张表中存在的数据可以使用内连接,不存在的话使用外连接。
- 主键生成方式:
- 1.自增:运行效率低,开发效率高
- 2.自定义.程序员手动生成主键值,唯一非空,算法:hi/low,UUID:字符串,长度是32位。
- 3.共享主键
相关配置文件
mybatis.config
设置日志文件
别名
mapper包路径映射
配置数据连接和事务,spring继承mybatis相关
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
| <!-- 配置数据源 --> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"/> <property name="username" value="root"/> <property name="password" value="123456"/> <property name="url" value="jdbc:mysql://localhost:3306/crm2008?useSSL=false&useUnicode=true&characterEncoding=UTF-8"/> </bean> <!-- 配置SqlSessionFactory --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 必须注入属性dataSource --> <property name="dataSource" ref="dataSource"/> <!-- 如果mybatis没有特殊的配置(比如别名等),configLocation可以省去 ;否则,不能省略--> <property name="configLocation" value="classpath:mybatis-config.xml"/> </bean> <!-- mapper注解扫描器配置,扫描@MapperScan注解,自动生成代码对象 --> <bean id="mapperScanner" class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.zwj.crm.mapper"/> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/> </bean>
<!-- 配置事务管理器 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean>
<!-- 配置事务 --> <aop:config> <aop:pointcut expression="execution(* com.zwj.crm..service.*.*(..))" id="allMethodPointcut"/> <aop:advisor advice-ref="txAdvice" pointcut-ref="allMethodPointcut"/> </aop:config>
<tx:advice id="txAdvice" transaction-manager="transactionManager"> <tx:attributes> <tx:method name="add*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="save*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="edit*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="update*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="delete*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="do*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="*" propagation="REQUIRED" read-only="true"/> </tx:attributes> </tx:advice>
|
springMVC配置
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| <!-- dispatcherServlet截获所有URL请求 --> <mvc:default-servlet-handler /> <!-- spring mvc 扫描包下的controller --> <context:component-scan base-package="com.zwj.crm.web.controller"/> <!-- 配置注解驱动 --> <mvc:annotation-driven/> <!-- 配置视图解析器 --> <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/pages/"/> <property name="suffix" value=".jsp"/> </bean> <!-- 配置文件上传解析器 id:必须是multipartResolver--> <!--<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="#{1024*1024*80}"/> <property name="defaultEncoding" value="utf-8"/> </bean>-->
|
spring总的配置文件
1 2 3 4 5 6
| <!-- 加载系统配置文件 <context:property-placeholder location="classpath:*.properties" />--> <!-- 扫描注解 --> <context:component-scan base-package="com.zwj.crm.service" /> <!-- 导入数据相关配置 --> <import resource="applicationContext-datasource.xml" />
|
Web.xml配置
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
| <!-- spring监听器加载applicationContext.xml配置文件 --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!-- spring字符过滤器 --> <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>\
|
web应用根目录下的内容都是不安全的,外界可以通过url直接访问
所以,一般为了数据的安全,都会把页面放在WEB-INFO下面。