当前位置: 首页 > news >正文

期货直播室网站建设全媒体运营师培训费用

期货直播室网站建设,全媒体运营师培训费用,网页广告设计收费,歌手投票网站怎么做CRUD 1.namespace namespace中的包名要和mapper接口的包名一致! 2.select 选择查询语句 id:就是对应的namespace中的方法名; resultType:Sql语句执行的返回值! parameterType:参数类型 增删改必须提交事务&…

CRUD

1.namespace

namespace中的包名要和mapper接口的包名一致!

2.select

选择查询语句

id:就是对应的namespace中的方法名;

resultType:Sql语句执行的返回值!

parameterType:参数类型

增删改必须提交事务:sqlSession.commit();

1.编写接口

List<User> getUserList();//根据id查询用户User getUserById(int id);//insert一个用户;int addUser(User user);//修改用户int updateUser(User user);//删除用户int deleteUser(int id);

2.编写对应的mapper中的Sql语句

<select id="getUserList" resultType="pojo.User">select * from mybatis.user</select><select id="getUserById" parameterType="int" resultType="pojo.User">select * from mybatis.user where id = #{id}</select><insert id="addUser" parameterType="pojo.User" >insert into mybatis.user (id,name,pwd) values (#{id},#{name},#{pwd});</insert><update id="updateUser" parameterType="pojo.User">update mybatis.user set name=#{name},pwd=#{pwd} where id = #{id};</update><delete id="deleteUser" parameterType="int">delete from mybatis.user where id= #{id};</delete>

3.测试

public  void test(){//1.获得SqlSession对象SqlSession sqlSession = MybatisUtils.getSqlSession();//2.执行Sql--方式一:getMapperUserMapper userDao = sqlSession.getMapper(UserMapper.class);List<User> userList = userDao.getUserList();for (User user : userList) {System.out.println(user);}//关闭SqlSessionsqlSession.close();}
public void getUserById(){SqlSession sqlSession1 = MybatisUtils.getSqlSession();UserMapper mapper = sqlSession1.getMapper(UserMapper.class);User user = mapper.getUserById(1);System.out.println(user);sqlSession1.close();}

3.Insert

public void addUser(){SqlSession sqlSession = MybatisUtils.getSqlSession();UserMapper mapper = sqlSession.getMapper(UserMapper.class);mapper.addUser(new User(5,"jim","123123"));//提交事务sqlSession.commit();sqlSession.close();}

4.Update

public void updateUser(){SqlSession sqlSession = MybatisUtils.getSqlSession();UserMapper mapper = sqlSession.getMapper(UserMapper.class);mapper.updateUser(new User(5,"jack2","123456"));sqlSession.commit();sqlSession.close();}

5.Delete

public  void deleteUser(){SqlSession sqlSession = MybatisUtils.getSqlSession();UserMapper mapper = sqlSession.getMapper(UserMapper.class);mapper.deleteUser(5);sqlSession.commit();sqlSession.close();}

万能的Map

假设我们的实体类或者数据库中的表,字段或者参数过多,我们应当考虑使用Map!

int addUser2(Map<String,Object>map);
<insert id="addUser2" parameterType="map" >insert into mybatis.user (id,name,pwd) values (#{userid},#{username},#{userpwd});</insert>
public void addUser2(){SqlSession sqlSession = MybatisUtils.getSqlSession();UserMapper mapper = sqlSession.getMapper(UserMapper.class);Map<String, Object> map = new HashMap<String, Object>();map.put("userid",5);map.put("username","jack3");map.put("userpwd","123123");mapper.addUser2(map);sqlSession.commit();sqlSession.close();}

模糊查询

1.在Java代码执行的时候,传递通配符%%

List<User> userList = userDao.getUserList2("%李%");
select * from mybatis.user where name like #{values};

2.在sql拼接中使用通配符

select * from mybatis.user where name like "%"#{values}"%";
List<User> userList = userDao.getUserList2("李");

配置解析

mybatis-config.xml

mybatis的配置文件包含了会深深影响MyBatis行为的设置和属性信息

configuration(配置)
properties(属性)
settings(设置)
typeAliases(类型别名)
typeHandlers(类型处理器)
objectFactory(对象工厂)
plugins(插件)
environments(环境配置)
environment(环境变量)
transactionManager(事务管理器)
dataSource(数据源)
databaseIdProvider(数据库厂商标识)
mappers(映射器)

db.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?serverTimezone=Asia/Shanghai&useSSL=false&useUnicode=true&characterEncoding=UTF-8
username=root
password=123456

可以直接引入外部文件

可以在其中增加一些属性配置

如果两个文件有同一个字段,优先使用外部配置文件的!

类型别名(typeAliases)

<!--可以给实体类起别名--><typeAliases><typeAlias type="pojo.User" alias="user"/></typeAliases>

扫描实体类的包,它的默认别名就是这个类的类名,首字母小写

<typeAliases><package name="pojo"/>
</typeAliases>

实体类比较少的时候,使用第一种

实体类多的时候,使用第二种

第一种可以DIY别名,第二种不可以(可以使用注解@alias)

映射器

<mappers><mapper resource="dao/UserMapper.xml"/></mappers>

作用域和生命周期

SqlSessionFactoryBuilder:一旦创建SqlSession就不在需要,一般设置为局部变量

SqlSessionFactory:可以理解为数据库连接池,一旦被创建就一直存在

SqlSession:可以理解为连接池中的请求,实例是不安全的线程,不能被共享,使用完毕就关闭。

属性名和字段名不一致问题

解决办法:起别名

<select id="getUserById" parameterType="int" resultType="user">select id,name, pwd as password from mybatis.user where id =#{id}</select>

resultMap结果集映射

<resultMap id="UserMap" type="user"><result column="id" property="id"/><result column="name" property="name"/><result column="pwd" property="password"/></resultMap>
<select id="getUserById" resultMap="UserMap">select * from mybatis.user where id = #{id}</select>
http://www.yidumall.com/news/51270.html

相关文章:

  • php网站模板开源女排联赛最新排行榜
  • 长沙做网站备案企业微信营销系统
  • 淄博网站建设有实力百度搜索排名优化哪家好
  • 宝山网站建设服务企业查询网
  • 网站收录问题seo优化知识
  • 浙江建设信息网港西安seo阳建
  • 百度招聘 网站开发阿里巴巴官网首页
  • 郑州主动营销网站2023年9月疫情又开始了吗
  • 做微信公众号的网站有哪些内容广州最新消息
  • 罗湖网站建设价格网站建设介绍ppt
  • robots网站地图黄页引流推广网站入口
  • 做淘宝推广开网站合适柏乡seo快排优化
  • 企业展厅设计效果图seo教程seo教程
  • 做网站反链无锡百度正规公司
  • 网站独享ip哪有卖的成功营销案例100例
  • 找做外墙油漆网站百度竞价优缺点
  • 信阳做网站 汉狮网络信息流推广渠道有哪些
  • 中国文明网联盟网站建设最近一周热点新闻
  • 建筑材料市场信息价网百色seo快速排名
  • 自己做网站教学视频新闻发布会稿件
  • 合伙做网站怎么分配股权百度推广seo自学
  • 网站留言表格怎么做深圳品牌策划公司
  • 邯郸推广网站建设哪个好专业网站建设公司
  • 做内容网站赚钱吗免费域名注册官网
  • 宣传册设计与制作模板免费东莞网络优化服务商
  • 做网站ssl证书必须要吗电话营销销售系统
  • 怎么设置网站支付功能网站建设设计
  • 青岛做企业网站的公司2022磁力链接搜索引擎推荐
  • 做排名出租网站问卷调查网站
  • seo每日工作内容培训机构seo