Hibernate實用技術.ppt
《Hibernate實用技術.ppt》由會員分享,可在線閱讀,更多相關《Hibernate實用技術.ppt(107頁珍藏版)》請在裝配圖網(wǎng)上搜索。
1、程序設計實用技術 - Hibernate 目標: 深入理解持久層框架 掌握 Hibernate配置方法、開發(fā)流程 掌握 Hiberate性能優(yōu)化 學習對象: 具備一定 Java編程能力的初級程序員 。 預備知識: 了解數(shù)據(jù)庫的基本概念 熟悉常用 SQL語言,具備一定的 Java編 程能力 課程內容: 持久層和 ORM Hibernate基礎 Hibernate性能優(yōu)化 程序設計實用技術 JAVA方向 第一講 持久層和 ORM 章節(jié)目標: 理解持久層和 ORM 持久層概述: 什么是 持久化 ? 什么是 持久層 ? “ 持久化 ” 與 “ 持久層 ” 之間的 關系 ? 持久層概述: 什么是持久化?
2、 將數(shù)據(jù)保存到物理的儲存器(硬盤、磁帶 等)上的過程叫持久化。 什么是持久層? 專門負責處理與物理數(shù)據(jù)相關操作(持久化 數(shù)據(jù),以供日后使用)的獨立層次。 之間的關系? 持久化是動詞,表示將內存中的數(shù)據(jù)存儲到 數(shù)據(jù)庫或其他媒介。 持久層是名詞,實現(xiàn)數(shù)據(jù)持久化的一個相對 獨立的領域(層)。 消費者 /前 端 倉庫 /數(shù)據(jù)庫系統(tǒng) 消費者 /前 端 倉庫 /數(shù)據(jù)庫系統(tǒng) 商場 /業(yè)務類 消費者 /前 端 倉庫 /數(shù)據(jù)庫系統(tǒng) 超市 /業(yè)務類 物流公司 /持久層 現(xiàn)實模型與持久層 ? Application上層應用層 Transaction Layer 事務層 Data Access Logic 數(shù)據(jù)訪問邏
3、輯 Persistence Layer 持久層 Database 數(shù)據(jù)層 持久層邏輯邊界 ? View Control Model JSP Action 持久層 Database 業(yè)務邏輯 持久層在 MVC中: 持久層解決了 MVC什么問題? 當發(fā)生以下三種情況: ( 1)表示層發(fā)生變化 ( 2)業(yè)務邏輯層發(fā)生變化 ( 3)底層數(shù)據(jù)格式或持久化機制發(fā)生變化 數(shù)據(jù) 持久化代碼 不需要重新編譯 為什么可以達到上述目標?是什么來的? 解耦合 持久層概述: 什么是解耦合? 采用某種方法將緊密耦合的關 系轉換為松散耦合的關系的過程 什么是耦合度? 兩個事物之間的耦合程度 什么是耦合度適中? 事物之間的耦
4、合度符合實際情況 或要求 緊耦合 耦合適中 太松耦合 持久層概述: 現(xiàn)實中還有哪些解耦合的實例? 電腦 ,各個組件(顯示器、 CPU、硬盤、內存)之間 相互獨立,組合在一起又能一起工作,連接它們的是 共同實現(xiàn)的標準接口;(思考集成顯卡、網(wǎng)卡?) 電腦上的 USB接口與原來的串口之間存在耦合度區(qū)別; 建筑中的磚混結構、框架結構; 社會上各行各業(yè)的產生,也是一種解耦合的過程。發(fā) 電廠的建立,使工廠不必為了開動機器去發(fā)電; 工程化也可以說就是一個解耦合的過程 。 現(xiàn)實中的解耦合的實例: 持久層概述: 軟件設計中解耦合的自然進化 實例:記錄論壇用戶登錄次數(shù) public boolean addLogi
5、nCount(String id,int count) Connection conn = null; Statement stmt = null; try Class.forName(“oracle.jdbc.driver.OracleDriver”); conn = DriverManager.getConnection( “ jdbc:orcle:thin:dbServer:1521:forum”, “ MyUserName”, “ MyPassword”); String sqlStr = “update BBSUser set loginCount=loginCount+1” + “
6、 where id=”+id+”; stmt = conn.createStatement(); return stmt.execute(sqlStr); catch(ClassNotFoundException e) e.printStackTrace(); public boolean addLoginCount(String id,int count) Connection conn = null; Statement stmt = null; try Class.forName(Config.getValue(“JDBC_DRIVER”); conn = DriverManager.g
7、etConnection( Config.getValue(“DB_URL”), Config.getValue(“DB_USER”), Config.getValue(“DB_PWD”); String sqlStr = “update BBSUser set loginCount=loginCount+1” + “ where id=”+id+”; stmt = conn.createStatement(); return stmt.execute(sqlStr); catch(ClassNotFoundException e) e.printStackTrace(); 實例:記錄論壇用戶
8、登錄次數(shù) 從編寫代碼的角度看他們的優(yōu)點: ()第一段代碼很容易掌握,容易理 解,直截了當,可以很好的執(zhí)行。 ()第二段代碼要引入一個外部文件, 用來保存數(shù)據(jù)庫連接信息,不大容易實現(xiàn), 但也比較好理解,也可以很好的執(zhí)行。 從耦合度的角度看,比較其優(yōu)缺點? 如數(shù)據(jù)庫密碼泄露,管理員要修改數(shù)據(jù)庫 密碼 : 第一段代碼: ()找到所有的與數(shù)據(jù)庫連接相關的代碼,修 改密碼; ()重新編譯修改后的文件; ()重新部署軟件。 第二段代碼: ()修改外部文件中配置的密碼; ()不需要重新編譯; ()不需要重新部署軟件。 進一步改進的方法? Connection conn = DBHelper.getConne
9、ction(); 再進一步改進的方法? ? 軟件設計中解耦合的目標 為什么要解耦合? 從 MVC理解軟件設計中的解耦合 軟件系統(tǒng)解耦合的目標: 數(shù)據(jù)訪問 操作系統(tǒng) 數(shù)據(jù)庫系統(tǒng) 應用系統(tǒng) 應用邏輯 應用程序層內部解耦合? 業(yè)務邏輯與數(shù)據(jù)訪問邏輯分離 應用程序與資源層解耦合? 應用層邏輯與底層數(shù)據(jù)庫、操作系統(tǒng)結構分離 程序設計實用技術 JAVA方向 第二講 DAO模式解耦合 解耦合實例 : DAO模式 示例:銀行轉帳 現(xiàn)有 賬戶 A 賬戶 B 轉帳金額 amount 由賬戶 A轉給賬戶 B。 編寫一個方法,實現(xiàn)轉帳。 public boolean zhuanzhang(String user1,S
10、tring user2,int amount) Connection conn = DBHelper.getConnection(); /獲得數(shù)據(jù)庫連接 PrearedStatement stmt = conn.prepareStatement( “ select * from user where username=?”); stmt.setString(1,user1); ResultSet user1_Set = stmt.executeQuery(); if (user1_Set.next() /檢查 賬戶 A 余額是否夠轉帳 , 夠則減掉要轉帳的金額 if (user1_Set.ge
11、tInt(“amount”)=amount) PrearedStatement stmt = conn.prepareStatement( “ update user set amount = amount-“ stmt.executeUpdate(); else return false; /余額不足 else return false; /找不到 賬戶 A /將 賬戶 B 加上轉帳金額 PrearedStatement stmt = conn.prepareStatement( “ update user set amount=amount+” stmt.setString(1,user2
12、); stmt.executeUpdate(); return true; 示例:銀行轉帳 上例實現(xiàn)了三個操作: ()檢查賬戶 A的余額是否夠轉帳; ()在賬戶 A中減掉要轉帳的金額; ()在賬戶 B中加上要轉帳的金額。 最后 DAO模式下的代碼: public boolean zhuanzhang(String user1,String user2,int amount) User userA = UserProxy.getUser(user1); /分離數(shù)據(jù)訪問邏輯 User userB = UserProxy.getUser(user2); return userA. accord(us
13、erB , amount); Factory模式 Proxy模式 DAO模式: Data Accessor Object(數(shù)據(jù)訪問對象 DAO) Data 數(shù)據(jù) Data Accessor 數(shù)據(jù)訪問器 Domain Object 領域對象 (數(shù)據(jù)抽象 ) DAO模式分解 DAO模式解耦合的目標: Application 應用邏輯 Data Accessor 數(shù)據(jù)訪問抽象 Domain Object業(yè)務對象 Database Accessor Abstract 數(shù)據(jù)訪問接口 Database Accessor Imp 數(shù)據(jù)訪問實現(xiàn) DAO模式實現(xiàn)的層次 數(shù)據(jù)存儲邏輯與業(yè)務邏輯分離 數(shù)據(jù)存儲邏輯與
14、數(shù)據(jù)底層實現(xiàn) 分離 ( 資源層解耦合 ) 封裝業(yè)務對象 Database 在 DAO模式中引入 Factory模式: 如何理解 Factory工廠模式 ? 根據(jù)給定的模具( 類名稱 ), 從倉庫里取出相應原料( 類代碼 ), 加工成產品( 類實現(xiàn)或對象 )。 Factory模式: Factory模式: UserDAO userDAO = DAOFactory.getDAO(UserDAO.class); User userA = userDAO.getUser(User1); Factory在 DAO的作用? 根據(jù)需要加載相應的實現(xiàn),具體點說就是: 給定 UserDAO.class類名,產生
15、UserDAO類實現(xiàn)。 之前的實現(xiàn) 完成銀行轉帳: public boolean zhuanzhang(String user1,String user2,int amount) UserDAO userDAO = DAOFactory.getDAO(UserDAO.class); User userA = UserDAO.getUser(user1); User userB = UserDAO.getUser(user2); return userA. accord(userB,amount); 最終版本 現(xiàn)實生活中的 Proxy代理? 軟件開發(fā)中的 Proxy代理? 在 DAO模式中引入
16、Proxy模式 在 DAO模式中引入 Proxy模式 public class UserProxy public static User getUser(String userid) UserDAO userDAO = (UserDAO)DAOFactory.getDAO(UserDAO.class); return userDAO.getUser(userid); public static void sava(User user) UserDAO userDAO = (UserDAO)DAOFactory.getDAO(UserDAO.class); userDAO.save(user);
17、 最終版本 為什么要引入 Proxy? 、使得代碼看起來更整潔 、為附加其他功能留接口 、? 為什么要引入 Proxy? 思考類比房屋建筑中的代理層? 最終版本 DAO模式總結: Client DAOFactory UserDAO UserObject UserProxy UserData/Table DBHelper 應用層 數(shù)據(jù)訪問層 數(shù)據(jù)層 對象 /關系映射 DAO模式總結: 對象 描述 Client 業(yè)務邏輯,相對與數(shù)據(jù)庫層來說是客戶 UserProxy 執(zhí)行代理,執(zhí)行業(yè)務邏輯需要的針對數(shù)據(jù)庫的操作 DAOFactory DAO工廠,根據(jù)配置文件產生 DAO對象類 UserDAO DA
18、O對象,使用 DBHelper連接數(shù)據(jù)庫,加載數(shù)據(jù) /實例 化 DAO DBHelper 連接數(shù)據(jù)庫幫助類,使用配置文件連接數(shù)據(jù)庫 UserObject 數(shù)據(jù)封裝類,具有屬性和 get/set方法,對表 /關系數(shù) 據(jù)進行封裝 UserDate/Table 數(shù)據(jù)庫表,表記錄是 UserObject的屬性,實例化 UserObject DAO模式總結: Client Object/業(yè)務邏輯 DAOProxy/代理 DAOFactory/DAO工廠 Implementation/DAO實現(xiàn) DAOConfiguration 調用服務方法 獲得服務實現(xiàn)接口 獲得 DAO配置 獲得 DAO/服務實現(xiàn) 執(zhí)
19、 行 方 法 返回結果 ( 1) interface接口,在實現(xiàn)解耦合中的作用? ( 2) Java Class動態(tài)加栽? ( 3) XML配置文件? 回顧與 DAO相關的知識: 提升持久層性能 軟件系統(tǒng)中有哪些性能指標? 提升持久層性能: 數(shù)據(jù)庫容量 執(zhí)行某次業(yè)務的時間 同時并發(fā)訪問數(shù) 等等 軟件系統(tǒng)中有哪些性能指標? 系統(tǒng)性能低下有哪些原因? 提升持久層性能: 硬件環(huán)境、網(wǎng)絡環(huán)境差 軟件配置環(huán)境低(操作系統(tǒng)、數(shù)據(jù)庫 系統(tǒng))達不到系統(tǒng)使用要求 設計本身存在缺陷 系統(tǒng)性能低下有哪些原因? 設計本身存在缺陷,主要表現(xiàn)在: 、算法不科學合理 、資源的管理和調配失當 哪一個是最主要因素? 提升持久層
20、性能: 從前有一個鋼鐵工廠,有個車間,每個車間的 生產效率都很高(工人技能高、生產管理科學、設備 先進); 每個車間都設立有自己的原料采購車隊,以保障生產 所需的原料。 (存在的問題?如何解決?) 提升持久層性能: 從前有一個 DAO模式的系統(tǒng),有個子過程,每 個子過程的執(zhí)行效率都很高(代碼非常簡練,并經(jīng)過 代碼優(yōu)化); 每個子過程都包含有自己的數(shù)據(jù)庫連接,以保障有效 的數(shù)據(jù)存取。 (存在的問題?如何解決?) 提升持久層性能: 問題出現(xiàn)的前提: “ 大量 ” 提升持久層性能: 市場對鋼鐵的需求 “ 大量 ” 增 長 用戶同時登陸的數(shù)量 “ 大量 ” 增 長 會出現(xiàn)什么大問題? 提升持久層性能:
21、 措施: Connection Pool 數(shù)據(jù)庫連接池 請求獲得連接 數(shù)據(jù)庫連接池 判斷是否 有 有 沒有 創(chuàng)建一個連接 移除返回連接 提升持久層性能: Connection Pool 數(shù)據(jù)庫連接池 請求返回連接 數(shù)據(jù)庫連接池 判斷是否滿 滿 不滿 加入到池中 關閉連接 提升持久層性能: 數(shù)據(jù)庫連接池技術帶來的優(yōu)勢? ( 1)資源重用 ( 2)更快的響應速度 ( 3)控制資源分配 ( 4)避免連接泄露 提升持久層性能: 措施:緩存 計算機領域的緩存有哪些? 緩存什么東西?為什么要緩存?緩存 到什么地方? 軟件系統(tǒng)中的緩存主要緩存什么? 提升持久層性能總結回顧: 、數(shù)據(jù)庫連接池引入的原因? 提升
22、系統(tǒng)性能。 、數(shù)據(jù)庫連接池與持久層的關系? 持久層負責數(shù)據(jù)訪問。 數(shù)據(jù)庫連接池負責統(tǒng)一管理和調 度數(shù)據(jù)庫連接。 有了數(shù)據(jù)庫連接才能訪問數(shù)據(jù)。 提升持久層性能: 理解持久層、 DAO、數(shù)據(jù)庫連接池這些 概念的目的是什么? 是: 對現(xiàn)有持久層來歷和發(fā)展方向有深入的理解,為 應用開發(fā)打下理論基礎。 不是: 使用這些理論知識實現(xiàn)軟件項目中的持久層。 因為: 不必為了吃面包,就要去種小麥。無論是商業(yè)領 域還是開源社區(qū),都為我們提供了豐富的、久經(jīng) 考驗的持久層組件,比如 Hibernate。 程序設計實用技術 JAVA方向 第三講 Hibernate基礎開發(fā) 回顧 現(xiàn)有持久層框架: Hibernate A
23、pache OJB Cayenne Jaxor iBatis jRelationFramework mirage SMYLE TopLink( oracle,非 開 源 產 品) Hibernate是什么 : 持久層框架? ORM映射理論? 提供強大、高性能的對象到關系型數(shù)據(jù)庫持久化服務 的框架產品(開源) Hibernate的起源 : Hibernate的設計者: Gavin King 2001年末,正式發(fā)布第一個版本 2003年中,發(fā)布 Hibernate2 2003年末, Hibernate被開源組織 JBoss收納 2005年初,發(fā)布 Hibernate3 為什么如此快速的成功 : 快
24、速發(fā)布、即時響應 全面的回歸測試 避免過渡設計 集權 文檔 避免標準化 5分鐘內成功運行 Hibernate 開發(fā)人員的責任感 快速起步 快速起步準備工作 : 下載: Hibernate Hibernate-Extension Middlegen-Hibernate JUnit Mysql 準備開發(fā)工具: Eclipse MyEclipse4 準備數(shù)據(jù)庫環(huán)境: Mysql/Oracle Hibernate配置 : Hibernate日志 : 第一程序 : 代碼解釋 : ()初始化 Hibernate配置管理類: Configuration。 ()通過 Configuration類實例創(chuàng)建 Se
25、ssion的工廠類: SessionFactory。 ()通過 SessionFactory得到: Session。 圖釋 : Hibernate hibernate.hbm.xml SessionFactory Session Database Configuration 理解 : Hibernate完成了什么配置工作 ? 如何完成的 ? Hibernate在數(shù)據(jù)操作中起到了什么作用 ? 如何做的 ? 基礎語法 Configuration SessionFactory Session hibernate.hbm.xml hibernate.properties (myHibernate.hb
26、m.xml) Session.save(user) Session.close() User.hbm.xml H I B E R N A T E 基礎語法 : Configuration類 負責管理 Hibernate的配置信息 Configuration config = new Configuration().configure(); File file = new File(“D:oramyHibernate.hbm.xml”); Configuration config = new Configuration().configure(file); 基礎語法 : SessionFacto
27、ry類 負責創(chuàng)建 Session實例 。 是線程安全的 , 可并發(fā)同時訪問 。 Configuration config = new Configuration().configure(); SessionFactory factory = config.buildSessionFactory(); 基礎語法 : SessionFactory類 SessionFactory實例是 Configuration實 例 config根據(jù)當前的配置信息構造的 。 多個數(shù)據(jù)庫就有多個 config實例,并構 造不同的 SessionFactory。 SessionFactory中保存著數(shù)據(jù)庫配置的 所有
28、映射關系,也維護緩存等,消耗巨大, 應重點考慮重用策略。 基礎語法 : Session類 持久化操作的基礎 Configuration config = new Configuration().configure(); SessionFactory factory = config.buildSessionFactory(); Session session = factory.openSession(); 基礎語法 : Hibernate Session與 HttpSession的區(qū)別 ? 基礎語法 : Session數(shù)據(jù)持久化方法: Save Get/Load flush Delete Q
29、uery、 Criteria 基礎配置 基礎配置 : Hibernate基礎配置 主要針對 SessionFactory展開 Hibernate內部配置 與應用服務器(或容器)的相關配置 基礎配置 : Hibernate配置方法 主要針對 SessionFactory展開 使用配置文件 ( hibernate.hbm.xml/hibernate.propert ies) ,在 Hibernate啟動時加栽配置屬性。 使用 Configuration類在程序中,指定 配置屬性。 基礎配置 : Hibernate配置屬性分類: 數(shù)據(jù)庫連接 數(shù)據(jù)庫連接池 事務屬性 對象 /關系映射文件 其他屬性 H
30、ibernate O/R Mapping Hibernate O/R Mapping? Hibernate O/R Mapper? 基本數(shù)據(jù)類型映射 : Java數(shù)據(jù)類型 數(shù)據(jù)庫字段類型 O/R映射定義 Hibernate類型轉換 基本實體映射 : Java對象與數(shù)據(jù)庫表關系之間的映射: 類名 表名 主鍵映射 字段 屬性 基本數(shù)據(jù)類型映射 : Java對象 /POJO 數(shù)據(jù)庫表關系 O/R映射定義 Hibernate數(shù)據(jù)交換 基本實體映射 : Id int (pk) Name varchar(20) sex varchar(4) group_id int (fk) 學生表 Id int (pk
31、) Code varchar(50) createTime time 學生證表 private int id; private String name; private String sex; private int group; Card card; Student private int id; private String code; private time createtime Student student; Card 自定義數(shù)據(jù)類型 映射 : Hibernate自定義數(shù)據(jù)類型,接口: UserType CompositeUserType 將數(shù)據(jù)庫中復雜的數(shù)據(jù)格式轉換成業(yè)務層 易于
32、操作的類型對象 復合主鍵 映射 : 注意:有駁于業(yè)務邏輯和數(shù)據(jù)邏輯分離的原則 復合主鍵類: 基于實體類屬性的復合主鍵 基于主鍵類的復合主鍵 需要實現(xiàn): Serializable接口及 equals、 hashCode方法 Blob、 Clob字段映射: 不同的數(shù)據(jù)庫對應的大對象類型不同 實體映射策略 : Component組件映射 繼承映射 Component組件映射 : id int firstName vchar(20) lastName vchar(20) sex int age int homeAdd vchar(100) officeAdd vchar(100) telZone vc
33、har(4) telPhone vchar(11) telPerson vchar(4) Name對象 Tel對象 通過將復雜的表字段分類,實現(xiàn)面向對象的領域劃分,使 系統(tǒng)邏輯更加清晰。 繼承映射 : 學生表 id 姓名 性別 年齡 班級 老師表 id 姓名 性別 年齡 職務 Person類 Student類 Teacher類 繼承映射 : 用戶表 id 姓名 性別 年齡 班級 學生表 id Person類 Student類 Teacher類 老師表 id 職務 繼承映射 : 用戶表 id 姓名 性別 年齡 班級 用戶類別 Person類 Student類 Teacher類 職務 級聯(lián)關系 關
34、系映射類別 : 一對一關聯(lián) /one-to-one 一對多關聯(lián) /one-to-many 多對一關聯(lián) /many-to-one 多對多關聯(lián) /many-to-many ORM(對象 /關系映射),不但包括對單獨的數(shù)據(jù)庫表和對象 的映射,還包括對表之間的關聯(lián)的影射。 一對一關聯(lián) : 主鍵關聯(lián) Id int (pk) Name varchar(20) sex varchar(4) group_id int (fk) 學生表 Id int (pk) Code varchar(50) createTime time 學生證表 private int id; private String name; p
35、rivate String sex; private int group; Card card; Student private int id; private String code; private time createtime Student student; Card 一對一關聯(lián) : 外鍵關聯(lián) Id int (pk) Name varchar(20) sex varchar(4) group_id int (fk) 學生表 Id int (pk) name varchar(50) 組表 private int id; private String name; private Stri
36、ng sex; private Group group; Student private int id; private String name; Group Student.hbm.xml Group.hbm.xml 一對多關聯(lián) : Id int (pk) Name varchar(20) sex varchar(4) group_id int (fk) 學生表 Id int (pk) address varchar(50) zipcode varchar(6) userid int 地址表 private int id; private String name; private Strin
37、g sex; private Group group; private Set address; Student private int id; private String address; private String zipcode; private int userid; private Student student; Address Student.hbm.xml Address.hbm.xml 多對多關聯(lián) : Id int (pk) role varchar(20) 角色表 Id int (pk) group varchar(20) 組 (崗位 )表 private int id; private String role; private Set groups; Role private int id; private String group; private Set roles; Group Role.hbm.xml Group.hbm.xml Role_id Group_id 角色 _組表
- 溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 指向核心素養(yǎng)發(fā)展的高中生物學1輪復習備考建議
- 新課程新評價新高考導向下高三化學備考的新思考
- 新時代背景下化學高考備考策略及新課程標準的高中化學教學思考
- 2025屆江西省高考政治二輪復習備考建議
- 新教材新高考背景下的化學科學備考策略
- 新高考背景下的2024年高考化學二輪復習備考策略
- 2025屆高三數(shù)學二輪復習備考交流會課件
- 2025年高考化學復習研究與展望
- 2024年高考化學復習備考講座
- 2025屆高考數(shù)學二輪復習備考策略和方向
- 2024年感動中國十大人物事跡及頒獎詞
- XX教育系統(tǒng)單位述職報告教育工作概述教育成果展示面臨的挑戰(zhàn)未來規(guī)劃
- 2025《增值稅法》全文解讀學習高質量發(fā)展的增值稅制度規(guī)范增值稅的征收和繳納
- 初中資料:400個語文優(yōu)秀作文標題
- 初中語文考試專項練習題(含答案)