Hibernate介绍

合集下载

hibernate sql拼接原理

hibernate sql拼接原理

Hibernate SQL拼接原理1. 什么是HibernateHibernate是一个开源的Java持久化框架,它提供了一个对象关系映射(Object-Relational Mapping,ORM)的解决方案,用于将Java对象与关系数据库进行映射。

通过Hibernate,我们可以使用面向对象的方式来操作数据库,而不需要直接编写SQL语句。

Hibernate采用了一种称为“延迟加载”的机制,它会在需要访问数据时才去执行SQL查询。

这种机制可以提高性能,并且使得开发者可以将更多的精力放在业务逻辑上。

2. Hibernate SQL拼接原理在使用Hibernate时,我们通常使用HQL(Hibernate Query Language)或者Criteria API来查询数据。

这些查询语言会被转换成对应的SQL语句,并由Hibernate执行。

2.1 HQL和SQLHQL是一种面向对象的查询语言,它类似于SQL但具有更高级的特性。

例如,HQL支持继承、多态、关联等概念,并且可以直接操作Java对象而不需要关心底层数据库表结构。

当我们使用HQL进行查询时,Hibernate会将HQL语句转换成对应的SQL语句,并通过JDBC驱动执行SQL查询。

这个过程包括两个阶段:解析和执行。

2.2 解析阶段在解析阶段,Hibernate会对HQL语句进行语法分析,并根据查询条件生成对应的SQL查询。

这个过程包括以下几个步骤:2.2.1 解析HQL语句首先,Hibernate会将HQL语句解析成一个抽象的查询树(Query Tree)。

这个查询树表示了HQL语句的结构和含义。

例如,对于以下的HQL语句:String hql = "from Employee e where = :deptName";Hibernate会解析成如下的查询树:SELECTeFROMEmployee eWHERE = :deptName2.2.2 解析实体和属性接下来,Hibernate会解析查询树中的实体和属性,并将它们映射到数据库表和列。

《hibernate入门》课件

《hibernate入门》课件

Hibernate配置
Hibernate通过配置文件指定数据库连接信息、 映射配置和其他配置选项。开发人员可以根 据实际需求进行灵活的配置,以满足不同的 场景和需求。
Hibernate映射
数据库表和Java类的映射
Hibernate提供了灵活的映射机制,将数据库 表和Java类之间的关系进行映射。开发人员 可以通过注解或XML配置文件定义映射规则, 实现数据的转换和传递。
Hibernate事件模型
Hibernate通过事件模型实现了灵活的事件处 理机制。开发人员可以通过注册事件监听器, 对特定的事件进行处理,如对象的加载、保 存、更新和删除等操作。
批量操作和预处理语句
Hibernate提供了批量操作和预处理语句的支 持,用于提高数据库操作的效率。批量操作 可以将多个操作合并成一个批量操作,减少 与数据库的交互次数。预处理语句可以预先 编译好SQL语句,提高查询性能。
《Hibernate入门》PPT课 件
Hibernate入门课程是为了让您了解Hibernate框架的使用和优势。通过本课程, 您将深入了解Hibernate的基本概念、映射、HQL查询、高级特性以及与Spring 的整合等内容。
简介
什么是Hibernate?
Hibernate是一个Java持久化框架,用于将Java对象映射到数据库。它提供了ORM解决方案, 使开发人员能够以面向对象的方式访问数据库。
HQL查询示例
HQL可以进行各种查询操作,包括简单的单 表查询、多表关联查询、聚合查询等。开发 人员可以根据实际需求编写HQL查询语句, 方便地获取所需的数据。
Hibernate高级特性
一级缓存和二级缓存
Hibernate提供了一级缓存和二级缓存机制, 用于提高系统的性能。一级缓存是Session级 别的缓存,用于缓存对象的读取和更新操作。 二级缓存是应用级别的缓存,用于缓存频繁 访问的数据。

hibernate配置

hibernate配置
属性可以是update、create和drop-create三个值。
目录
1 Hibernate概述 2 第一个Hibernate程序 3 Hibernate的配置文件 4 深入理解持久化对象 5 Hibernate的映射文件 6持久化对象 如果PO 实例与Session实例关联起来,且该实例关联到数据库的记录
脱管对象 如果PO实例曾经与Session实例关联过,但是因为Session的关闭等原 因,PO实例脱离了Session 的管理
Hibernate全面解决方案架构解释
事务(Transaction) 代表一次原子操作,它具有数据库事务的概念 但它通过抽象,将应用程序从底层的具体的JDBC、JTA和CORBA 事务中隔离开。 一个Session 之内可能包含多个Transaction对象。 所有的持久化操作都应该在事务管理下进行,即使是只读操作。
管态,对该对象操作无须锁定数据库,不会造成性能的下降。
持久化对象的状态迁移
持久化实体: 1、Serializable save(object obj) 将对象变为持久化状态 2、void persist(object obj) 将对象转化为持久化状态 3、Serializable save(object obj,object pk) 将obj对象转化为持久化状态,该对象保存到数据库,指定主键值 4、void persist(object obj,object pk) 也加了一个设定主键
Hibernate工作原理
Configuration cfg = new Configuration().configure();
开始
启动hibernate
构建Configuration 实例,初始 化该实例中的所有变量

hibernate的save方法

hibernate的save方法

hibernate的save方法Hibernate中的save方法是用来将对象持久化到数据库中的。

下面将详细介绍Hibernate的save方法以及相关内容。

Hibernate是一个开源的Java持久化框架,它是基于JDBC的ORM框架,提供了面向对象的数据操作方式。

Hibernate的核心思想是将对象和数据库之间的映射关系进行配置,通过框架提供的API来进行数据库的操作,从而避免了编写大量的JDBC代码以及手动处理对象与数据库之间的转换问题。

在Hibernate中,使用Session对象来进行数据库的操作。

Session类是Hibernate中的核心类之一,它代表了与数据库之间的一次会话。

在Session中,有许多方法可以用于数据库操作,其中之一就是save方法。

save方法用于将一个对象持久化到数据库中。

调用save方法时,Hibernate会生成一条INSERT语句,将对象的属性值插入到数据库的对应表中。

具体的步骤如下:1. 配置Hibernate的SessionFactory:在使用Hibernate之前,需要配置一个SessionFactory对象,该对象是用来创建Session的工厂对象。

2. 创建Session对象:要使用Hibernate进行数据库操作,首先需要创建一个Session对象。

可以通过SessionFactory来创建Session对象,也可以使用现有的Session对象。

3. 创建一个实体类对象:要将一个对象保存到数据库中,首先需要创建一个实体类的对象。

这个实体类对象应该是一个持久化类,在Hibernate的配置文件中进行了配置,指明了与数据库中的哪个表进行映射。

4. 调用save方法:通过Session对象的save方法来将实体类对象持久化到数据库中。

Hibernate会自动生成INSERT语句,并将对象的属性值插入到数据库的对应表中。

6. 关闭Session对象:在数据库操作完成之后,需要关闭Session对象,释放资源。

hibernate的save方法

hibernate的save方法

Hibernate的save方法1. 简介Hibernate是一个开源的Java持久化框架,它提供了一种方便的方式来将Java对象映射到关系数据库中。

在Hibernate中,save方法是用于将一个对象保存到数据库中的方法之一。

本文将详细介绍Hibernate的save方法的使用方式、参数、返回值和注意事项。

2. save方法的使用方式在Hibernate中,使用save方法将一个对象保存到数据库中非常简单。

首先,需要创建一个SessionFactory对象,该对象是Hibernate的核心对象,用于创建Session对象。

然后,通过Session对象调用save方法来保存对象。

下面是一个简单的示例代码:SessionFactory sessionFactory = new Configuration().configure().buildSessionFa ctory();Session session = sessionFactory.openSession();Transaction transaction = session.beginTransaction();MyObject myObject = new MyObject();// 设置对象的属性myObject.setName("John");myObject.setAge(25);session.save(myObject);mit();session.close();在上面的示例中,我们首先创建了一个SessionFactory对象,然后打开一个Session对象,并开启了一个事务。

接下来,创建了一个MyObject对象,并设置了其属性。

最后,通过调用session的save方法将对象保存到数据库中。

最后,我们提交事务并关闭Session。

3. save方法的参数save方法接受一个对象作为参数,该对象将被保存到数据库中。

hibernate sql写法

hibernate sql写法

hibernate sql写法Hibernate是一个开源的、高效的、强大的Java持久化框架,它提供了面向对象的方式来操作关系型数据库。

使用Hibernate,开发者可以以一种简单、灵活的方式进行数据库操作,而无需编写大量的SQL 语句。

在Hibernate中,我们可以通过编写映射文件或注解来定义实体类与数据库表之间的映射关系,通过Session对象来执行对数据库的操作。

在Hibernate中,SQL语句可以通过多种方式来编写。

下面将针对Hibernate中的SQL编写进行详细介绍。

1. HQL(Hibernate Query Language)Hibernate Query Language(HQL)是一种面向对象的查询语言,它类似于SQL语句,但是使用的是实体类和属性名,而不是表名和列名。

HQL可以实现对实体对象的查询、更新和删除等操作。

以下是HQL的一些常用语法:-查询所有的实体对象:FROM实体类名-条件查询:FROM实体类名WHERE条件-投影查询:SELECT属性列表FROM实体类名-排序查询:FROM实体类名ORDER BY属性ASC/DESC-分页查询:FROM实体类名LIMIT开始位置,查询数量HQL的编写与SQL类似,但是可以直接使用实体类和属性名,从而更加面向对象。

例如,以下HQL语句可以查询出所有年龄大于18岁的用户:FROM User WHERE age > 182.原生SQL查询除了HQL,Hibernate还支持原生的SQL查询。

原生SQL查询可以直接编写传统的SQL语句,但是需要使用Session对象的createNativeQuery方法来执行。

以下是原生SQL查询的一些常用语法:-执行查询:session.createNativeQuery("SELECT * FROM表名").getResultList()-执行更新或删除:session.createNativeQuery("UPDATE/DELETE FROM表名WHERE条件").executeUpdate()-参数绑定:Query.setParameter(参数名,参数值)原生SQL查询可以更灵活地操作数据库,但是需要注意SQL语句的安全性和兼容性问题。

hibernate replace函数

hibernate replace函数摘要:1.Hibernate 简介2.Hibernate 的REPLACE 函数3.REPLACE 函数的使用方法4.REPLACE 函数的实例5.总结正文:Hibernate 是一个开源的持久化框架,主要用于将Java 对象映射到关系数据库中。

它提供了一种对象关系映射(ORM)的方式,使得Java 程序员可以更专注于业务逻辑的实现,而无需关注底层数据库操作。

在Hibernate 中,有一个REPLACE 函数,可以用于替换数据表中的记录。

REPLACE 函数接收两个参数:第一个参数是要进行替换操作的数据表名,第二个参数是要替换的新记录。

这个函数会根据数据表名找到对应的表,然后查找具有相同主键的记录,如果找到则替换为新记录,否则插入新记录。

REPLACE 函数的使用方法如下:1.获取Hibernate 的Session 对象。

2.开启事务。

3.使用REPLACE 函数进行替换操作。

4.提交事务。

5.关闭Session 对象。

下面通过一个实例来说明REPLACE 函数的使用:假设我们有一个员工表(employee),其中包含员工的基本信息(如:id、name、age 等)。

现在,我们想要根据员工ID 替换员工的姓名。

代码实现如下:```java// 1.获取Hibernate 的Session 对象Session session = HibernateUtil.getSession();// 2.开启事务session.beginTransaction();// 3.使用REPLACE 函数进行替换操作Employee employee = (Employee) session.get(Employee.class, 1); // 根据员工ID 获取员工对象employee.setName("新姓名"); // 修改员工姓名session.replace(employee); // 调用REPLACE 函数进行替换操作// 4.提交事务session.getTransaction().commit();// 5.关闭Session 对象session.close();```在这个例子中,我们首先通过HibernateUtil 工具类获取到了一个Session 对象,然后开启了一个事务。

hibernate 的词根词缀

词根词缀是构成英语单词的基础,对于学习和理解单词的意义起着至关重要的作用。

在英语中,很多单词的意义可以通过词根和词缀来推测或解释,因此了解词根词缀是提高英语词汇水平的关键。

对于单词“hibernate”来说,其词根是“hibern-”,词缀是“-ate”。

接下来,我们将分别介绍这两部分的含义和意义,以帮助读者更好地理解和应用这个单词。

1. 词根“hibern-”:这个词根源自拉丁语“hibernare”,意为“冬眠”或“过冬”。

在英语中,这个词根通常被用来表示动植物在寒冷季节中进入休眠或冬眠状态的意义。

“hibernation”就表示动物在冬季进入休眠状态,以节省能量和应对恶劣的气候条件。

2. 词缀“-ate”:这个词缀在动词或形容词后面加上“-ate”构成新的动词或形容词,表示“使...”、“具有...的特征”或“经...”等意义。

在“hibernate”这个单词中,“-ate”表示“使进入冬眠状态”的意思,将动词“hibern”转化为“hibernate”,表示动物进入冬眠状态的动作或状态。

单词“hibernate”由词根“hibern-”和词缀“-ate”组成,意为“进入冬眠状态”。

了解词根词缀有助于我们理解和记忆单词的意义,同时也可以帮助我们推测和解释未知单词的含义。

掌握词根词缀是提高词汇水平和阅读能力的重要途径之一,希望读者能够在学习英语词汇的过程中重视词根词缀的学习,从而更好地掌握英语语言。

词根和词缀是英语单词构成的基本元素,它们为我们理解和记忆单词的含义提供了重要的线索。

通过学习词根和词缀,我们能够更好地把握单词的意义,从而扩大自己的词汇量,提高阅读和写作能力。

在学习单词构词法时,掌握词根和词缀的含义和用法是至关重要的,因为通过这些基本元素,我们能够推测单词的意义,甚至推断出未知单词的含义。

回到词根“hibern-”和词缀“-ate”,我们可以发现,这两者结合在一起构成了一个常用的单词“hibernate”。

hibernate_中_对数据库中date类型的处理_概述说明

hibernate 中对数据库中date类型的处理概述说明1. 引言1.1 概述:在软件开发中,与日期相关的数据类型在数据库处理中经常出现。

hibernate是一个流行的Java持久化框架,在与数据库交互时也需要考虑对日期类型数据的处理。

本文旨在提供有关hibernate中对数据库中date类型的处理的全面概述。

1.2 文章结构:本文按照以下结构进行阐述:2. hibernate 中对数据库中date类型的处理:介绍了hibernate中处理Date 类型数据的方法和技巧,以及在数据库中保存和检索Date类型数据时需要遵循的最佳实践。

3. Date类型与其他数据类型之间的转换:探讨了Date类型与字符串、Timestamp和Calendar之间相互转换的方法和注意事项。

4. Hibernate中使用日期函数进行查询和计算:介绍了常用的日期函数,以及如何在Hibernate中使用这些函数进行查询和计算,并附有示例代码和解释。

5. 结论: 总结了文章内容,并提出进一步研究该主题可能涉及到的方向。

1.3 目的:通过本文,读者将能够理解在hibernate中如何正确地操作和处理数据库中的Date类型数据。

我们将讨论一些重要概念、方法和技巧,并提供示例代码来帮助读者更好地理解。

此外,我们还将讨论与Date类型有关的其他数据类型之间的转换,并详细介绍如何在Hibernate中使用日期函数进行高级查询和计算。

最后,我们将通过总结文章内容并提出进一步研究的方向来归纳全文。

(注意:本段是按照普通文本格式回答,以下部分也同样)2. hibernate 中对数据库中date类型的处理2.1 Date类型介绍在Hibernate中,Date是Java中表示日期和时间的类之一。

它可以直接与数据库中的date类型进行映射,并提供了许多操作和方法用于处理日期和时间数据。

2.2 Hibernate中操作Date类型的方法和技巧当我们使用Hibernate操作数据库中的Date类型数据时,可以使用以下方法和技巧来处理:- 映射配置:在Hibernate实体类中,使用注解或XML文件进行映射配置。

iBATIS和Hibernate的区别

一、iBATIS概述iBATIS一词来源于“internet”和“abatis”的组合,是一个由Clinton Begin(克林顿)在2001年发起的开放源代码项目。

最初侧重于密码软件的开发,现在是一个基于Java的持久层框架。

相对Hibernate和Apache OJB(Object Relational Bridge-OJB是基于XML 的对象/关系映射工具.OJB提供一些高级的特性如:对象缓存,延迟加载,利用事务隔离级别的结构进行分布式管理,支持悲观与乐观锁.OJB还提供了一个灵活的配置与插件机制以便可以扩展加入自己的功能)等“一站式”ORM(Obeject/Relation Mapping对象关系映射)解决方案而言,ibatis 是一种“半自动化”的ORM实现。

二、Hibernate概述Hibernate是一个基于JDBC的开源的持久化框架,是一个优秀的ORM实现(可以自动的根据xml完成对象关系映射,并持久化到数据库),它很大程度上简化了数据访问对象层(持久层)的编码工作,Hibernate对JDBC访问数据库的代码做了深度封装,大大简化了数据访问层繁琐的重复性代码。

在分层结构中Hibernate处于持久层,封装对数据库的访问细节,使业务逻辑层更专注于实现业务逻辑.hibernate优点:1、封装了jdbc,简化了很多重复性代码。

2、简化了DAO层编码工作,使开发更对象化了。

3、移植性好,支持各种数据库,如果换个数据库只要在配置文件中变换配置就可以了,不用改变hibernate代码。

4、hibernate使用Java反射机制,而不是字节码增强程序来支持透明持久化,因为hibernate操作的是纯粹的(pojo)java类,没有实现任何接口,没有侵入性。

所以说它是一个轻量级框架。

它支持各种关系数据库,从一对一到多对多的各种复杂关系。

三、iBATIS和Hibernate的区别相同点:1、屏蔽JDBC API的底层访问细节,使我们不用与JDBC API打交道,就可以访问数据二者都是比较优秀的开源产品;不同点:2、ibatis是在结果集与实体类之间进行映射,hibernate是在数据库与实体类之间进行映射。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

面向对象应用程序中的持久层
• 在多层结构中,持久层负责向一个或多个 数据存储器中存储或者获取数据的一组类 或者组件。这个层必须包含业务领域实体 的模型。 • 用SQL/JDBC编写持久层,需要花费开发人员 几个月的时间。例如,Hibernate有80000行代 码,包括25000行测试代码.
对象关系映射 (ORM)
•ห้องสมุดไป่ตู้


启动项目
• 创建基本的Hibernate应用程序,需要Object、 数据库的表、两种配置文件、客户端程序 来调用Hibernate的接口操作。 • 环境构造:
– Hibernate libraries – JDBC driver – slf4j-log4j12-1.5.8.jar – log4j-1.2.16.jar
• select m.MESSAGE_ID, m.MESSAGE_TEXT, m.NEXT_MESSAGE_ID from MESSAGES m where m.MESSAGE_ID = 1 • insert into MESSAGES (MESSAGE_ID, MESSAGE_TEXT, NEXT_MESSAGE_ID) values (2, 'Take me to your leader (please)', null) • update MESSAGES set MESSAGE_TEXT = 'Greetings Earthling', NEXT_MESSAGE_ID = 2 where MESSAGE_ID =1 • Automatic Dirty Checking:自动修改第一个message 对象的两个属性。 • Cascading Save :自动添加第二个message对象 • Write Behind:SQL语句的排序与设置属性值的顺序 不同。Hibernate使用了运算法则,避免违背数据库 外键约束。
领域模型(Domain Model)和元数据 (Metadata)
• 软件开发的工作从问题领域的分析开始。 • 创建业务模型开始。
– 实体的识别,如用户、货物或者订单. – 实体之间的关系.
• 问题领域的面向对象的实体模型为领域模 型。
Hibernate 体系结构的高层概要图
Hibernate 运行时体系结构
Hibernate的主要构件
• • SessionFactory (org.hibernate.SessionFactory) 针对单个数据库映射关 系经过编译后的内存镜像,是线程安全的(不可变)。它是生成 Session的工厂,本身要用到ConnectionProvider。 Session (org.hibernate.Session)表示应用程序与持久储存层之间交互 操作的一个单线程对象,此对象生存期很短,隐藏了JDBC连接,也 是Transaction的工厂。 Transaction (org.hibernate.Transaction) 应用程序用来指定原子操作单 元范围的对象,它是单线程的,生命周期很短。它通过 抽象将应用 从底层具体的JDBC、JTA以及CORBA事务隔离开。 ConnectionProvider (org.hibernate.connection.ConnectionProvider) 生 成JDBC连接的工厂(有连接池的作用)。它通过抽象将应用从底层 的Datasource或DriverManager隔离开。仅供开发者扩展/实现用,并 不暴露给应用程序使用。 TransactionFactory (org.hibernate.TransactionFactory) 生成Transaction 对象实例的工厂。仅供开发者扩展/实现用,并不暴露给应用程序使 用。
• 这个单元的运行,执行下列SQL语句.
• select m.MESSAGE_ID, m.MESSAGE_TEXT, m.NEXT_MESSAGE_ID from MESSAGES m order by m.MESSAGE_TEXT asc
• Session thirdSession = • HibernateUtil.getSessionFactory().openSession(); • Transaction thirdTransaction = thirdSession.beginTransaction(); • // msgId holds the identifier value of the first message • message = (Message) thirdSession.get( Message.class, msgId ); • message.setText( "Greetings Earthling" ); • message.setNextMessage( • new Message( "Take me to your leader (please)" ) • ); • mit(); • thirdSession.close(); • 这个单元的运行,执行下列SQL语句.
• 利用描述对象和数据库直接的映射的元数 据,自动的把Java应用程序中的对象持久化 到关系数据库中的表。 • 益处:
– 生产力:减少持久化相关代码的开发 – 可维护性:更少的代码行。 – 性能:优化性能 – 供应商独立性:从底层SQL数据库和SQL方言抽 象出来。
问题
• 使用JDBC,用SQL来操作数据库,只是看动 态生成还是人工写代码来实现。大家想想, 我们实现过ORMapping吗?
3
• 开发人员应该关注于业务功能模块的开发。 • 关系型数据模型和SQL适合面向对象应用程 序中的持久化吗? • 在面向对象应用程序中,持久化允许一个 对象在创建之后依然存在。对象的状态可 以保存到磁盘中,在未来的某个时候被重 新创建.
范式/阻抗不匹配问题 (Impedance Mismatch)
• The impedance mismatch refers to the opposition between a relational model with a well defined mathematical model and normalized data in tables, and the Object Oriented model with classes, inheritance and polymorphism.
范式/阻抗不匹配
• 粒度问题。Java粒度的多样性(User类、 Address类)。SQL数据库只有表和列。 • 子类问题。Java有继承和多态性。 • 同一性问题。Java对象的同一性(内存位置,用 a==b检查)和等值性(用equals()方法). SQL数据库 用主键。Equals()和==都不会必然等于主键值. • 关联问题。Java对象使用对象引用,然而SQL 数据库用外键。Java对象是有方向的。频繁查 询引用对象降低系统性能。
Hibernate介绍
刘明
教学大纲
• • • • 理解对象/关系持久化 Hibernate概念简介 启动一个Hibernate项目 领域模型和元数据
什么是持久化
• 利用SQL在关系数据库中存储数据。 • Java通过JDBC把SQL语句发到数据库。 • 需要Java程序员用JDBC API绑定实参,来准 备查询参数,执行查询、滚动查询结果表、 从结果集中获取值。
JDBC: Java Database Connectivity
The JDBC API: database-independent connectivity between Java and a wide range of databases. Connection conn = DriverManager.getConnection ( "jdbc:somejdbcvendor:other data needed by some jdbc vendor", "myLogin", "myPassword" ); try { /* you use the connection here */ } finally { //Important close the connection when you are done { conn.close(); } catch (Throwable ignore) { } ..... Statement stmt = conn.createStatement(); try { stmt.executeUpdate("INSERT INTO MyTable(name) VALUES ('my name')");} finally { { stmt.close(); } catch (Throwable ignore) {} }
(1)类和表的映射 (2)主键的映射 (3)类的属性和DB中字段的映射 (4)关系的映射
message.hbm.xml映射文档
• Hibernate配置文件
• public static void main(String[] args) { – // First unit of work – Session session = HibernateUtil.getSessionFactory().openSession(); – Transaction tx = session.beginTransaction(); – Message message = new Message("Hello World"); – Long msgId = (Long) session.save(message); – mit(); – session.close(); • } • 这个单元的运行,执行下列SQL语句. • insert into MESSAGES (MESSAGE_ID, MESSAGE_TEXT, NEXT_MESSAGE_ID) values (1, 'Hello World', null) • MESSAGE_ID是标示符值。
相关文档
最新文档