MyBatis 增、删、改、查的基本实现---面向接口

MyBatis 增、删、改、查的基本实现---面向接口
1、建数据库
    CREATE TABLE `user` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `userName` varchar(64) DEFAULT NULL,
      `userPass` varchar(64) DEFAULT NULL,
      PRIMARY KEY (`id`)
    )
2、建model类
    public class User implements Serializable{
        private Integer id;
        private String userName;
        private String userPass;
        
        public User() {
            super();
        }
        public User(Integer id, String userName, String userPass) {
            this.id = id;
            this.userName = userName;
            this.userPass = userPass;
        }
        public Integer getId() {
            return id;
        }
        public void setId(Integer id) {
            this.id = id;
        }
        public String getUserName() {
            return userName;
        }
        public void setUserName(String userName) {
            this.userName = userName;
        }
        public String getUserPass() {
            return userPass;
        }
        public void setUserPass(String userPass) {
            this.userPass = userPass;
        }
    }
    
3、基于接口
    1)、mpper 文件
    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE mapper
      PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
      "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
         <!-- namespace 对应接口名称 -->
         <mapper namespace="models.IUser">
             <!-- id 对应接口方法名 -->
             <insert id="insert" parameterType="models.User">
                 INSERT INTO User(userName,userPass) VALUES(#{userName},#{userPass})
             </insert>
             <delete id="delete" parameterType="models.User">
                 DELETE FROM User WHERE id=#{id}
             </delete>
             <update id="update" parameterType="models.User">
                 UPDATE User u SET u.userName=#{userName} WHERE u.id=#{id}
             </update>
             <select id="selectUser" parameterType="integer" resultType="User">
                 select * from User u where u.id=#{id}
             </select>
             <select id="selectList" resultType="User">
                 select * from User u
             </select>
         </mapper>
    2)、测试
        package rest;
        public class SSs {
            static SqlSessionFactory sqlSessionFactory;
            static{
                String resource = "mybaties.xml";
                InputStream inputStream;
                try {
                    inputStream = Resources.getResourceAsStream(resource);
                    sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
            
            //添加
                private void insertForImpl(){
                    SqlSession session = sqlSessionFactory.openSession();
                    IUser iUser = session.getMapper(IUser.class);
                    
                    User user =new User();
                    user.setUserName("adadfadasdfasdf");
                    user.setUserPass("asdfasdfasd");
                    iUser.insert(user);
                    session.commit();
                }
                
                private void deleteForImpl(){
                    SqlSession session = sqlSessionFactory.openSession();
                    IUser iUser = session.getMapper(IUser.class);
                    User user =new User();
                    user.setId(89);
                    iUser.delete(user);
                    session.commit();
                }
                
                private void selectOneForImpl(){
                    SqlSession session = sqlSessionFactory.openSession();
                    User user2 = session.selectOne("models.User.sel",1);
                    System.out.println(user2.getUserName());
                }
                
                private void selectListForImpl(){
                    SqlSession session = sqlSessionFactory.openSession();
                    IUser iUser = session.getMapper(IUser.class);
                    List<User> user = iUser.selectList();
                    for (User user2 : user) {
                        System.out.println(user2.getUserName());
                    }
                    session.commit();
                }
                
                public void updateForImpl(){
                    SqlSession session = sqlSessionFactory.openSession();
                    IUser iUser = session.getMapper(IUser.class);
                    User user = iUser.selectUser(90);
                    System.out.println(user.getUserName());
                    session.commit();
                }
            
        
            public static void main(String[] args) {
                
                try {
                    SqlSession session = sqlSessionFactory.openSession();
                    IUser iUser = session.getMapper(IUser.class);
                    List<User> user = iUser.selectList();
                    for (User user2 : user) {
                        System.out.println(user2.getUserName());
                    }
                    
                    session.commit();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }
    
4、改进配置文件
    <update id="update" parameterType="models.User">
                 UPDATE User u SET u.userName=#{userName} WHERE u.id=#{id}
    </update>
    1)、 parameterType="models.User" 值为类全路径
    2)、在config文件加上
        <typeAliases>
              <typeAlias alias="User" type="models.User"/>
        </typeAliases>
    3)、 parameterType="models.User" 改为  parameterType="User"

时间: 2024-10-05 17:42:17

MyBatis 增、删、改、查的基本实现---面向接口的相关文章

Python---MySQL数据库之四大操作(增 删 改 查)

一.对数据库,表,记录---四大操作(增 删 改 查) 1.操作数据库 (1)对数据库(文件夹):进行增加操作 Create  database  库名; 例:  Create  database  db7 ; 查询库: show  databases; 结果: +-----------------------------+ | Database                   | +----------------------------+ | information_schema | |

ADO.NET 增 删 改 查

ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访问技术的基础 连接数据库基本格式:需要两个类1.数据库连接类 SqlConnection2.数据库操作类 SqlCommand 1.连接数据库写连接字符串,立马就要想到有4点要写完,1.连接哪台服务器,2.连接哪个数据库,3.连接用户名,4.密码string sql = "server=.(服务器i

MyBatis的配置与使用(增,删,改,查)

---恢复内容开始--- Mybatis入门介绍 一.MyBatis介绍 什么是MyBtis? MyBatis 是一个简化和实现了 Java 数据持久化层(persistence layer)的开源框架,它抽象了大量的 JDBC 冗余代 码,并提供了一个简单易用的 API 和数据库交互. MyBatis 的前身是 iBATIS,iBATIS 于 2002 年由 Clinton Begin 创建.MyBatis 3 是 iBATIS 的全新设计,支持 注解和 Mapper. MyBatis 流行的

oracle 11g 建库 建表 增 删 改 查 约束

一.建库 1.(点击左上角带绿色+号的按钮) 2.(进入这个界面,passowrd为密码.填写完后点击下面一排的Test按钮进行测试,无异常就点击Connect) 二.建表 1-1. create table 表名1( Tid number(4) --primary key 列级约束(主键), Tname varchar(10) --ont null  非空约束,只能定义在列级约束, Tsex varchar2(2)--check (tsex='男'  or  tsex='女') 检查约束, T

数据库基础学习4--表格的 增 删 改 查(简单查询与高级查询)

一.增 C:create 增加,创建,向数据库里面添加数据. insert into Fruit values('K009','苹果',3.0,'高青',90,'') insert into Fruit(Ids,Name,Price,Source,Numbers) values('K010','苹果',3.0,'高青',90) 二.改 U:update修改,从数据库表里面修改数据. update Fruit set Source='烟台' where Ids='K001' 三.删 D:delet

SQL 增/删/改/查 (总结)

1.增 INSERT  INTO  表名  VALUES (" "," ") ; INSERT INTO 表名(字段)  VALUES(" "); 2. 删 DELETE   FROM 表名  WHERE  ... 3.改 UPDATE  表名 SET   ... WHERE  ... 4.查 SELECT × FROM  表名 ORDER BY ...

1-24.list的增,删,改,查

增: 1.append(通过元素增加,默认加在最后print(a.append('hgf'))) 2.extend( 迭代的去增,就是把字符串的字符逐个去给这个列表加上去) 3.insert((按照索引去增加,前为索引,后为增加的字) 删: 1,pop(通过位置索引去删除) 2.del (通过索引,切片删除) 3.clear(清空列表) 4.remove(通过元素去删除) #返回值是什么意思? 改: a[]='i' print() 查: for i in a: print(a) 其他列表 1.s

php基础:数据库的含义和基本操作 增 删 改 查

//数据库是帮我们管理数据的一个软件,我们将数据给他,放进数据库里.他能很稳妥的帮我们管理起来,且效率很高.//php的大部分工作就是  php->连接数据库->写入数据->查出数据->格式化数据->显示出来,//数据库管理数据是以表的形式组成的,多行多列,表头声明好了,一个表创建好了,剩下的就是往里面添加数据 多张表放在一个文件夹里面就形成了库  mysql服务器帮我们管理多个库C:\wamp\bin\mysql\mysql5.6.12\data   数据库中的数据放在这个

Android 增,删,改,查 通讯录中的联系人

一.权限 操作通讯录必须在AndroidManifest.xml中先添加2个权限, <uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission> <uses-permission android:name="android.permission.WRITE_CONTACTS"></uses-permission>

js数组的管理[增,删,改,查]

今天在设计表单的时候遇到对数组的一些处理的问题,比如说怎么创建一个数组,然后牵扯到数组的增删改查的方法.请看API FF: Firefox, N: Netscape, IE: Internet Explorer 方法 描述 FF N IE concat() 连接两个或更多的数组,并返回结果. 1 4 4 join() 把数组的所有元素放入一个字符串.元素通过指定的分隔符进行分隔. 1 3 4 pop() 删除并返回数组的最后一个元素 1 4 5.5 push() 向数组的末尾添加一个或更多元素,