中文亚洲精品无码_熟女乱子伦免费_人人超碰人人爱国产_亚洲熟妇女综合网

當(dāng)前位置: 首頁 > news >正文

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

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

目錄

前言

MyBatis的具體使用

一些小工具:MyBatisX

常見問題:

1.表中字段名和實(shí)體屬性名不一致

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

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

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

5.單條件查詢時(shí),不知道用戶到底選了哪一個(gè)

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

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

8.修改信息

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

10.批量刪除☆☆☆

MyBatis注解



前言

為什么要有MyBatis呢?

當(dāng)然是因?yàn)镴DBC代碼太繁瑣啦~

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

上圖標(biāo)2的代碼。如果表結(jié)構(gòu)發(fā)生變化,SQL語句就要進(jìn)行更改。這也不方便后期的維護(hù)。

操作很繁瑣

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

MyBatis的具體使用

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

2.導(dǎo)入依賴坐標(biāo)

3.在項(xiàng)目的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中可以不用設(shè)置成這樣了   --><!--    <select id="selectAll" resultType="org.example.pojo.User">--><!--    因?yàn)樵趍ybatis中配置了別名,所以可以不用謝前面的包名了    -->
<!--    <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映射的路徑   -->
<!--  因?yàn)樵趓esource目錄上有和src目錄下的下相同目錄,所以直接可以使用package包的方式  --><mappers>
<!--        <mapper resource="org/example/mapper/UserMapper.xml"/>--><package name="org.example.mapper"/></mappers>
</configuration>

4.創(chuàng)建實(shí)體類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.定義一個(gè)測試類進(jìn)行測試

/*** 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映射配置文件 和 接口方法 間相互跳轉(zhuǎn)

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

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

常見問題:

1.表中字段名和實(shí)體屬性名不一致

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

可以resultMap

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

然后將resultType換成resultMap

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

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

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

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

可以使用以下三種方法

mapper.xml的編寫

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

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

這個(gè)時(shí)候就要使用到動(dòng)態(tài)SQL

使用<where></where>標(biāo)簽 和 <if></if>標(biāo)簽

5.單條件查詢時(shí),不知道用戶到底選了哪一個(gè)

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

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

定義接口

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

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

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

添加?

useGeneratedKeys, keyProperty 關(guān)鍵字

8.修改信息

定義接口

編寫mapper.xml

執(zhí)行方法

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

10.批量刪除☆☆☆

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

MyBatis注解

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

使用注解開發(fā)會(huì)比配置文件開發(fā)更加方便。如下就是使用注解進(jìn)行開發(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://www.risenshineclean.com/news/31711.html

相關(guān)文章:

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