大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 SSM增刪改查實例

SSM增刪改查實例

更新時間:2022-07-08 10:22:19 來源:動力節點 瀏覽1541次

動力節點小編來給大家舉例介紹一下最基本的增刪改查。

web.xml,主要用于配置Filter,Servlet,Lisenter等

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns="http://xmlns.jcp.org/xml/ns/javaee"
    xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
    version="3.1">
    <display-name>usermanage</display-name>
    <!-- 配置spring容器初始化監聽器 -->
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:spring/applicationContext*.xml</param-value>
    </context-param>
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    <!-- 配置編碼的過濾器 -->
    <filter>
        <filter-name>encoding</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>utf8</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>encoding</filter-name>
        <!--攔截路徑 -->
        <url-pattern>/*</url-pattern>
    </filter-mapping>
    <!-- 配置DispatcherServlet -->
<servlet>
<servlet-name>usermanage</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/usermanage-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>usermanage</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
    <welcome-file-list>
        <welcome-file>index.html</welcome-file>
        <welcome-file>index.htm</welcome-file>
        <welcome-file>index.jsp</welcome-file>
        <welcome-file>default.html</welcome-file>
        <welcome-file>default.htm</welcome-file>
        <welcome-file>default.jsp</welcome-file>
    </welcome-file-list>
</web-app>

usermanage-servlet.xml,對應于Controller

主要步驟:配置注解驅動;開啟注解掃描;解決靜態資源的攔截問題;配置視圖解析器

<?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:p="http://www.springframework.org/schema/p"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
    <mvc:view-controller path="/user/users" view-name="users"/>
    <mvc:view-controller path="/user/page/add" view-name="user-add"/>
    <mvc:view-controller path="/user/page/edit" view-name="user-edit"/>
    <!-- 配置注解驅動:替代推薦使用的注解映射器和適配器,提供對json的支持 -->
    <mvc:annotation-driven />    
    <!-- 開啟注解掃描,和spring是一樣的 -->
    <context:component-scan base-package="com.cn.usermanage.controller" />    
    <!-- 解決靜態資源被攔截的問題 -->
    <mvc:default-servlet-handler/>        
    <!-- 配置視圖解析器 -->
    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/views/"></property>
        <property name="suffix" value=".jsp"></property>
    </bean>        
</beans>

applicationContext.xml 中需要配置(省略數據庫的配置文件)

<!-- 注解掃描 -->
    <context:component-scan base-package="com.cn.usermanage.service"/>
    <!-- 加載資源文件 -->
    <context:property-placeholder location="classpath:jdbc.properties"/>
    <!-- 配置數據源 -->
    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="user" value="${jdbc.user}" />
        <property name="password" value="${jdbc.password}" />
        <property name="jdbcUrl" value="${jdbc.url}" />
        <property name="driverClass" value="${jdbc.driver}" />    
    </bean>

applicationContext-mybatis.xml中需要配置,和利用mybatis操作數據庫相關

步驟:需要初始化SqlsessionFactory對象;配置Mapper接口的包掃描

<!-- spring初始化bean的方式: 1.無參構造 2.靜態工廠方法 3.實例化工廠 4.工廠bean -->
    <bean id="sqlSessionFactory"
        class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 指定數據源 -->
        <property name="dataSource" ref="dataSource" />
        <!-- 指定全局配置文件 -->
        <property name="configLocation"
            value="classpath:mybatis/mybatis-config.xml"></property>
        <!-- 指定映射文件(不需要mybatis-config.xml中映射),利用通配符匹配任意目錄任意xml配置 -->
                <property name="mapperLocations" value="classpath:mybatis/mappers/**/*.xml"></property>
        <!-- 開啟別名掃描 -->
        <property name="typeAliasesPackage"
            value="com.cn.usermanage.pojo"></property>
    </bean>
                <!-- 配置mapper接口的包掃描 -->
     <mybatis-spring:scan
        base-package="com.cn.usermanage.mapper" />

mybatis-config.xml只需要配置行為參數即可

<settings>
        <setting name="mapUnderscoreToCamelCase" value="true" />
    </settings>

實體類對象User可以通過注解的方式對屬性進行數據校驗,常用的注解如:

@Null 驗證對象是否為 null

@NotNull 驗證對象是否不為 null

@Size(min,max) 驗證對象長度是否在給定的范圍內

@Past 驗證 Date 和 Calendar 對象是否在當前時間之前

@Future 驗證 Date 和 Calendar 對象是否在當前時間之后

@Pattern 驗證 String 對象是否符合正則表達式的規則

@NotBlank 檢查字符串是不是 Null,被 Trim 的長度是否大于0,只對字符串,且會去掉前后空格

@URL 驗證是否是合法的 url

@Email 驗證是否是合法的郵箱

User.java

public class User {
    private Long id;
    // 用戶名
    @NotNull
    @Length(min=6, max=20, message="用戶名長度不合法")
    private String userName;
    // 密碼
    @JsonIgnore
    @NotNull
    @Length(min=6, max=20, message="用戶名長度不合法")
    private String password;
    // 姓名
    @NotNull
    private String name;
    // 年齡
    @NotNull
    private Integer age;
    // 性別,1男性,2女性
    @NotNull
    private Integer sex;
    // 出生日期
    @NotNull
    @DateTimeFormat(pattern="yyyy-MM-dd")
    @Past(message="生日必須是過去式")
    private Date birthday;
    // 創建時間
    private Date created;
    // 更新時間
    private Date updated;}

UserController.java

@Controller
@RequestMapping("user")
public class UserController {
    @Autowired
    private UserService userService;
    @RequestMapping("users")
    public String toUsers() {
        return "users";
    }
    @RequestMapping("list")
    @ResponseBody
    public Map<String, Object> queryUserAll() {
        Map<String, Object> map = new HashMap<>();
        // 查詢總條數
        Long total = this.userService.queryTotal();
        map.put("total", total);
        List<User> users = this.userService.queryUserAll();
        map.put("rows", users);
        return map;
    }
        
    @RequestMapping("save")
    @ResponseBody
    public Map<String, String>  saveUser(@Valid User user,BindingResult result)
    {
        Map<String,String> map=new HashMap<>();
        if(result.hasErrors())
        {
            //輸出到控制臺
            System.out.println(result.getAllErrors());            //status用于前端校驗是否執行成功
            map.put("status", "500");
            return map;           
        }
        //調用Service方法新增用戶信息
        Boolean flag=this.userService.saveUser(user);
        if(flag)
            map.put("status", "200");
        else 
            map.put("status", "500");
        return map;
    }       
    //修改    
    @RequestMapping("edit")
    @ResponseBody
    public Map<String, String>  editUser(@Valid User user)
    {
        Map<String,String> map=new HashMap<>();
        //調用Service方法新增用戶信息
        Boolean flag=this.userService.editUser(user);
        if(flag)
            map.put("status", "200");
        else 
            map.put("status", "500");
        return map;
    }        
    //刪除        
    @RequestMapping("delete")
    @ResponseBody
    public Map<String, String>  deleteUser(@RequestParam("ids")List<Long> ids )
    {
        Map<String,String> map=new HashMap<>();
        //調用Service方法新增用戶信息
        Boolean flag=this.userService.deleteUserByIds(ids);
        if(flag)
            map.put("status", "200");
        else 
            map.put("status", "500");
        return map;
    }
}

 

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 99夜色| 99视频国产热精品视频 | 久久99热精品免费观看无卡顿 | 精品国产一区二区三区久久影院 | 日日摸夜夜添夜夜添人人爽 | 国产成人亚洲综合a∨婷婷 国产成人亚洲综合欧美一部 | 一级特黄a视频 | 欧美老妇69交 | 亚洲欧美日韩国产综合专区 | 亚洲中字在线 | 国产成人精品cao在线 | 欧美日韩亚洲一区二区三区 | 天天射天天草 | 国产精品88 | 日日干夜夜草 | 国产精品99久久久久久小说 | 九九这里只有精品 | 四虎免费在线 | 久久综合九色综合97伊人麻豆 | 亚洲综合日韩在线亚洲欧美专区 | 久久精品国产国产 | 亚洲99在线的 | 99热视热频这里只有精品 | 免费一级片在线 | 久操视频在线免费观看 | 欧美大成色www永久网站 | 国产一区二区高清 | 四虎国产精品永久在线播放 | 亚洲国产欧美一区二区欧美 | 日韩一级特黄毛片在线看 | aⅴ免费在线观看 | 久久99精品一级毛片 | 99久热在线精品视频播 | 性欧美处| 国产一级视频在线观看 | 久久精品资源 | 欧美男女啪啪 | 欧美在线视频在线观看 | 日本久久黄色 | 国产精品美女一区二区三区 | 国产成人精品免费视 |