国产亚洲精品福利在线无卡一,国产精久久一区二区三区,亚洲精品无码国模,精品久久久久久无码专区不卡

當前位置: 首頁 > news >正文

教我做網(wǎng)站立即優(yōu)化在哪里

教我做網(wǎng)站,立即優(yōu)化在哪里,怎樣修改wordpress模板,給企業(yè)做網(wǎng)站如何定價目錄 前言 MyBatis的具體使用 一些小工具:MyBatisX 常見問題: 1.表中字段名和實體屬性名不一致 2.按條件查詢(單條件)時的,查詢條件怎么編寫 3.按條件查詢(多條件) 4.多條件查詢時&…

目錄

前言

MyBatis的具體使用

一些小工具:MyBatisX

常見問題:

1.表中字段名和實體屬性名不一致

2.按條件查詢(單條件)時的,查詢條件怎么編寫

3.按條件查詢(多條件)

4.多條件查詢時,用戶不把所有條件填完

5.單條件查詢時,不知道用戶到底選了哪一個

6.添加用戶怎么寫接口和mapper.xml

7.添加信息時,如果要主鍵增長呢

8.修改信息

9.刪除一行數(shù)據(jù)

10.批量刪除☆☆☆

MyBatis注解



前言

為什么要有MyBatis呢?

當然是因為JDBC代碼太繁瑣啦~

上圖標1的代碼有很多字符串,而這些是連接數(shù)據(jù)庫的四個基本信息,以后如果要將Mysql數(shù)據(jù)庫換成其他的關系型數(shù)據(jù)庫的話,這四個地方都需要修改,如果放在此處就意味著要修改我們的源代碼。

上圖標2的代碼。如果表結構發(fā)生變化,SQL語句就要進行更改。這也不方便后期的維護。

操作很繁瑣

使用MyBatis就可以解決這些問題

MyBatis的具體使用

1.創(chuàng)建一個表。

2.導入依賴坐標

3.在項目的resources 目錄下創(chuàng)建mybatis的配置文件 mybatis-config.xml?

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><!--  配置別名  --><!-- 這樣的話,就在UserMapper中可以不用設置成這樣了   --><!--    <select id="selectAll" resultType="org.example.pojo.User">--><!--    因為在mybatis中配置了別名,所以可以不用謝前面的包名了    -->
<!--    <select id="selectAll" resultType="User">--><typeAliases><package name="org.example.pojo"/></typeAliases><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><!--   這一段代碼是連接信息             --><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql:///mybatis?useSSL=false"/><property name="username" value="root"/><property name="password" value="1234"/></dataSource></environment></environments><!-- 指定sql映射的路徑   -->
<!--  因為在resource目錄上有和src目錄下的下相同目錄,所以直接可以使用package包的方式  --><mappers>
<!--        <mapper resource="org/example/mapper/UserMapper.xml"/>--><package name="org.example.mapper"/></mappers>
</configuration>

4.創(chuàng)建實體類User

public class User {private int id;private String username;private String password;private String gender;private String addr;//省略了 setter 和 getter
}

5.在模塊的 resources 目錄下創(chuàng)建映射配置文件 UserMapper.xml

SQL語句就是在**Mapper.xml文件中編寫的

<?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">
<mapper namespace="test"><select id="selectAll" resultType="com.itheima.pojo.User">select * from tb_user;</select>
</mapper>

需要滿足這樣的目錄層級

6.定義UserMapper接口代碼

public interface UserMapper {List<User> selectAll();
}

注意層級和名稱一致問題

7.定義一個測試類進行測試

/*** Mybatis 代理開發(fā)*/
public class MyBatisDemo2 {public static void main(String[] args) throws IOException {//1. 加載mybatis的核心配置文件,獲取 SqlSessionFactoryString resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);//2. 獲取SqlSession對象,用它來執(zhí)行sqlSqlSession sqlSession = sqlSessionFactory.openSession();//3. 執(zhí)行sql//3.1 獲取UserMapper接口的代理對象UserMapper userMapper = sqlSession.getMapper(UserMapper.class);List<User> users = userMapper.selectAll();System.out.println(users);//4. 釋放資源sqlSession.close();}
}

一些小工具:MyBatisX

MyBatisX 插件

  • XML映射配置文件 和 接口方法 間相互跳轉

  • 根據(jù)接口方法生成 statement

如下圖操作就可以完成,生成Mapper.xml文件中的statement

常見問題:

1.表中字段名和實體屬性名不一致

使用Mybatis時,可能會出現(xiàn)數(shù)據(jù)庫表的字段名稱和實體類的屬性名稱不一樣的問題,這樣的話就不能自動封裝數(shù)據(jù)了。

可以resultMap

具體來說:就是在 **Mapper.xml中添加下圖紅框框住的<resultMap></resultMap>部分,對字段進行映射,下圖中前面的字段是數(shù)據(jù)庫中的命名,后面是實體類的屬性名。

然后將resultType換成resultMap

2.按條件查詢(單條件)時的,查詢條件怎么編寫

在 **Mapper中這樣寫,如下圖查詢條件是id? 就這樣寫#{id}

對于有參數(shù)的Mapper接口方法

3.按條件查詢(多條件)

可以使用以下三種方法

mapper.xml的編寫

在測試類中的調(diào)用

4.多條件查詢時,用戶不把所有條件填完

這個時候就要使用到動態(tài)SQL

使用<where></where>標簽 和 <if></if>標簽

5.單條件查詢時,不知道用戶到底選了哪一個

這種需求需要使用到 choose(when,otherwise)標簽 實現(xiàn), 而 choose 標簽類似于Java 中的switch語句。

6.添加用戶怎么寫接口和mapper.xml

定義接口

寫mapper,使用的是<insert></insert>

封裝對象,執(zhí)行方法

7.添加信息時,如果要主鍵增長呢

添加?

useGeneratedKeys, keyProperty 關鍵字

8.修改信息

定義接口

編寫mapper.xml

執(zhí)行方法

9.刪除一行數(shù)據(jù)

10.批量刪除☆☆☆

編寫SQL時需要遍歷數(shù)組來拼接SQL語句。Mybatis 提供了 foreach 標簽供我們使用

MyBatis注解

注解是用來替換映射配置文件方式配置的,所以使用了注解,就不需要再映射配置文件中書寫對應的 statement。

使用注解開發(fā)會比配置文件開發(fā)更加方便。如下就是使用注解進行開發(fā)。

但是對于復雜的SQL語句還是建議使用配置文件的方法。

public interface UserMapper {@Insert("INSERT INTO users(username, age) VALUES(#{username}, #{age})")int insertUser(User user);
}

public interface UserMapper {@Delete("DELETE FROM users WHERE id = #{id}")int deleteUserById(@Param("id") int id);
}

public interface UserMapper {@Update("UPDATE users SET username = #{username}, age = #{age} WHERE id = #{id}")int updateUser(User user);
}

public interface UserMapper {@Select("SELECT * FROM users WHERE id = #{id}")User selectUserById(@Param("id") int id);// 查詢所有用戶@Select("SELECT * FROM users")List<User> selectAllUsers();
}

http://m.aloenet.com.cn/news/31711.html

相關文章:

  • 電影網(wǎng)站vps服務器廣告加盟
  • 互助盤網(wǎng)站開發(fā)萬網(wǎng)域名查詢接口
  • wordpress更新文章長沙官網(wǎng)seo服務
  • 中國六冶的網(wǎng)站誰做的今日的頭條新聞
  • 多語言網(wǎng)站建設推廣青島網(wǎng)站建設運營推廣
  • 外貿(mào)推廣網(wǎng)站公司網(wǎng)站seo綜合查詢
  • 做競價要會做網(wǎng)站嗎優(yōu)化排名推廣技術網(wǎng)站
  • 做自媒體小視屏哪個網(wǎng)站好企業(yè)推廣文案
  • 哪些網(wǎng)站上可以做租車平臺推廣費用一般是多少
  • 分銷微信小程序開發(fā)免費seo工具
  • 網(wǎng)絡營銷模式課seo網(wǎng)站推廣可以自己搞嗎
  • 做亞馬遜網(wǎng)站一般發(fā)什么快遞海外推廣解決方案
  • 深圳微商城網(wǎng)站設計價格西安seo
  • 企業(yè)網(wǎng)站導航優(yōu)化成都做整站優(yōu)化
  • 高新區(qū)做網(wǎng)站讓顧客進店的100條方法
  • 園洲做網(wǎng)站公司怎么做網(wǎng)站平臺
  • 邯鄲做網(wǎng)站的地方網(wǎng)絡設計
  • 可以做設計兼職的網(wǎng)站有哪些工作室搜外seo
  • 百姓網(wǎng)租房seo的定義是什么
  • 東勝網(wǎng)站建設網(wǎng)絡營銷策劃書的結構
  • 用php寫的網(wǎng)站有哪些友情鏈接是免費的嗎
  • 企業(yè)網(wǎng)站建設的困難和問題長春seo技術
  • 網(wǎng)站關鍵詞選擇軟文推廣文案
  • 哪個旅游網(wǎng)站做的比較好免費平臺推廣
  • p2p網(wǎng)站建設制作免費發(fā)帖的網(wǎng)站
  • 專業(yè)網(wǎng)站建設首選公司沈陽seo網(wǎng)站關鍵詞優(yōu)化
  • wordpress怎么可以出現(xiàn)表格seo接單平臺
  • dedecms網(wǎng)站開發(fā)百度明星搜索量排行榜
  • 創(chuàng)做網(wǎng)站百度下載軟件
  • 兵團建設環(huán)保局網(wǎng)站百度推廣有哪些售后服務