Mybatis開發(fā)環(huán)境搭建實(shí)現(xiàn)數(shù)據(jù)的增刪改查功能
config.xml的配置
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!--
拿到數(shù)據(jù)庫信息,這是db.properties的內(nèi)容
driver=com.MySQL.jdbc.Driver
url=jdbc:mysql://localhost:3306/usertest
username=root
password=root
--!>
<properties resource="db.properties">
</properties>
<!-- 別名優(yōu)化--!>
<typeAliases>
<!-- <package name="com.leige.entity" /> -->
<typeAlias type="com.leige.entity.User" alias="user"/>
</typeAliases>
<!--設(shè)置框架工作模式development開發(fā)者模式 ,work是工作模式 -->
<environments default="development">
<environment id="development">
<transactionManager type="jdbc"></transactionManager>
<!-- 配置數(shù)據(jù)源 -->
<dataSource type="POOLED">
<!-- 注冊(cè)驅(qū)動(dòng) -->
<property name="driver" value="${driver}"/>
<!-- 連接數(shù)據(jù)庫 -->
<property name="url" value="${url}"/>
<!-- 密碼帳號(hào)登錄 -->
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
<!-- 使用xml,mapper resource需要設(shè)置--!>
<!-- <mappers>
<mapper resource="com/leige/entity/UserMappen.xml"></mapper>
</mappers> -->
<!--使用注解,mapper配置class,查詢方法寫在接口中--!>
<mappers>
<mapper class="com.leige.impl.UserImpl"/>
</mappers>
使用xml需要再配置一個(gè)mappen.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">
<!-- 建立表與類的映射關(guān)系有兩種:一個(gè)是xml(傾向),另一個(gè)是注解 -->
<mapper namespace="com.leige.entity.UserMappen">
<!-- 查詢?nèi)?-->
<select id="selectAll" resultType="user">
select * from user
</select>
<!-- 增加用戶 -->
<update id="insertUser" parameterType="user">
insert into user values (null,#{name},#{password},#{age})
</update>
</mapper>
使用注解則用接口
public interface UserImpl {
//更新用戶,更新用@update,查詢用@select,插入用@insert,刪除使用@delete這些注解
@Update("update user set name=#{name} where id=#{id}")
public void updateUser(User user);
}
demo測(cè)試代碼
public class Demo {
static InputStream in = null;
static SqlSessionFactory ssf = null;
static{
in = Demo.class.getClassLoader().getResourceAsStream("config.xml");
ssf = new SqlSessionFactoryBuilder().build(in);
}
public static void main(String[] args) {
//selectAll();
//insertUser();
updateUser();
}
//查詢?nèi)?
public static void selectAll(){
SqlSession session = ssf.openSession();
List<User> list = session.selectList("com.leige.entity.UserMappen.selectAll");
System.out.println(list);
session.close();
}
//增加用戶
public static void insertUser(){
SqlSession session = ssf.openSession();
User user = new User();
user.setName("小霸王");
user.setPassword("aaaaa");
user.setAge(25);
int num = session.insert("com.leige.entity.UserMappen.insertUser",user);
session.commit();
System.out.println(num);
session.close();
}
//修改用戶信息
public static void updateUser(){
SqlSession session = ssf.openSession();
UserImpl userImpl = session.getMapper(UserImpl.class);
User user = new User();
user.setName("我是大頭鬼");
user.setPassword("aaaaa");
user.setAge(25);
user.setId(79);
userImpl.updateUser(user);
session.commit();
session.close();
}
}
</configuration>
以上所述是小編給大家介紹的Mybatis開發(fā)環(huán)境搭建實(shí)現(xiàn)數(shù)據(jù)的增刪改查功能,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Java中RSA加密解密的實(shí)現(xiàn)方法分析
這篇文章主要介紹了Java中RSA加密解密的實(shí)現(xiàn)方法,結(jié)合具體實(shí)例形式分析了java實(shí)現(xiàn)RSA加密解密算法的具體步驟與相關(guān)操作技巧,并附帶了關(guān)于RSA算法密鑰長(zhǎng)度/密文長(zhǎng)度/明文長(zhǎng)度的參考說明,需要的朋友可以參考下2017-07-07
基于SpringBoot服務(wù)端表單數(shù)據(jù)校驗(yàn)的實(shí)現(xiàn)方式
這篇文章主要介紹了基于SpringBoot服務(wù)端表單數(shù)據(jù)校驗(yàn)的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-10-10
Java中將String類型依照某個(gè)字符分割成數(shù)組的方法
下面小編就為大家分享一篇Java中將String類型依照某個(gè)字符分割成數(shù)組的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-03-03
基于idea把maven工程轉(zhuǎn)換為web項(xiàng)目
這篇文章主要介紹了基于idea把maven工程轉(zhuǎn)換為web項(xiàng)目,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04
Java實(shí)現(xiàn)每日給女友微信發(fā)送早安信息
這篇文章主要為大家詳細(xì)介紹了Java如何實(shí)現(xiàn)每日給女友微信發(fā)送早安等微信信息,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以了解一下2022-12-12
MyBatis執(zhí)行動(dòng)態(tài)SQL的方法
今天小編就為大家分享一篇關(guān)于MyBatis執(zhí)行動(dòng)態(tài)SQL的方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12
SpringBoot整合達(dá)夢(mèng)數(shù)據(jù)庫的教程詳解
這篇文章主要給大家介紹了SpringBoot整合達(dá)夢(mèng)數(shù)據(jù)庫的詳細(xì)教程,文章中有詳細(xì)的圖片介紹和代碼示例供大家參考,具有一定的參考價(jià)值,需要的朋友可以參考下2023-08-08
Java HashMap在遍歷時(shí)刪除元素的實(shí)現(xiàn)
本文主要介紹了Java HashMap在遍歷時(shí)刪除元素的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-12-12
java基于ConcurrentHashMap設(shè)計(jì)細(xì)粒度實(shí)現(xiàn)代碼
這篇文章主要介紹了java基于ConcurrentHashMap設(shè)計(jì)細(xì)粒度實(shí)現(xiàn)代碼,通過ConcurrentHashMap實(shí)現(xiàn)細(xì)粒度,具有一定參考價(jià)值,需要的朋友可以了解。2017-10-10
Java最簡(jiǎn)潔數(shù)據(jù)結(jié)構(gòu)之冒泡排序快速理解
冒泡排序是編程中數(shù)據(jù)結(jié)構(gòu)繞不過的一個(gè)基礎(chǔ)點(diǎn),有關(guān)于冒泡排序的文章也有很多,但可能會(huì)比較繚亂未能理解,本章將一子u為簡(jiǎn)潔明了的例圖帶你通關(guān)冒泡排序2021-11-11

