Apache Derby - 插入数据

插入查询将数据:新记录插入表中.

语法

以下是基本INSERT语句的语法 :

ij>INSERT INTO table_name VALUES (column_name1, column_name2, ...);

其中column1,column2是要插入的行中的列值.

示例

以下SQL INSERT语句在Student表中插入一个新行,它在 id,age,first name last name

SQL> INSERT INTO Student VALUES (101, 20, 'Zara', 'Ali');

语法2

或者,您可以通过提及列名来插入两个特定列,如下面给出的那样;

ij>INSERT INTO table_name VALUES (column_name1, column_name2, ...) VALUES
(value1, value2, ...);

注意 :  Apache Derby自动计算生成列的值.例如,不需要为本教程前面创建的student表中的id列传递值.如果您的表已生成列,请使用 syntax2 .

示例

ij> INSERT INTO Student(Age, First_Name, Last_Name) VALUES (21, 'Sucharitha' , 'Tyagi');
1 row inserted/updated/deleted

并且,您还可以使用以下一个语句插入两行,如下所示;

ij>INSERT INTO Student(Age, First_Name, Last_Name) VALUES (20, 'Amit',
'Bhattacharya'), (22, 'Rahul', 'Desai');
2 rows inserted/updated/deleted

您可以使用SELECT命令验证表的内容(我们将在稍后讨论此命令)教程).

语法3

您可以在insert语句中使用另一个查询作为 :

INSERT INTO table_Name Query

示例

假设我们有一张表在数据库中命名为 First_Year ,如下所示,其中列与Student表中的列相同;

ID |AGE |FIRST_NAME |LAST_NAME
-----------------------------------------------------------------
1 |20 |Raju |Pendyala
2 |21 |Bhargav |Prayaga
3 |22 |Deepthi |Yerramilli

执行完所有上述插入语句后,Student表将如下 :

ID |AGE |FIRST_NAME |LAST_NAME
-------------------------------------------------------------
1 |21 |Sucharitha |Tyagi
2 |20 |Amit |Bhattacharya
3 |22 |Rahul |Desai
4 |20 |Raju |Pendyala
5 |21 |Bhargav |Prayaga
6 |22 |Deepthi |Yerramilli

使用JDBC程序插入数据

本节教您如何将数据插入到使用JDBC应用程序在Apache Derby数据库中的表.

如果要使用网络客户端请求Derby网络服务器,请确保服务器已启动并正在运行.网络客户端驱动程序的类名是org.apache.derby.jdbc.ClientDriver,URL是jdbc:derby://localhost:1527/ DATABASE_NAME; create = true; user = USER_NAME; passw
ord = PASSWORD "

按照以下步骤将数据插入Apache Derby : 中的表格中;

步骤1:注册驱动程序

要与数据库通信,首先需要注册驱动程序. forName( )类的方法, Class 接受表示类名的String值将其加载到内存中,自动注册它.使用此方法注册驱动程序.

第2步:获取连接

通常,我们与数据库进行通信的第一步是连接它.连接 class表示与数据库服务器的物理连接.您可以通过调用 DriverManager 类的 getConnection()方法来创建连接对象.使用此方法.

步骤3:创建语句对象

您需要创建语句 PreparedStatement或CallableStatement 对象将SQL语句发送到数据库.您可以分别使用方法 createStatement(),prepareStatement() prepareCall()创建它们.使用适当的方法创建任何这些对象.

步骤4:执行查询

创建语句后,需要执行它. Statement 类提供了各种方法来执行查询,例如 execute()方法,以执行返回多个结果集的语句.

executeUpdate()方法执行INSERT,UPDATE,DELETE等查询. executeQuery()方法返回数据等结果.使用这些方法之一并执行先前创建的语句.

示例

以下JDBC示例演示了如何使用JDBC程序将数据插入到Apache Derby中的表中.在这里,我们使用嵌入式驱动程序连接到名为sampleDB的数据库(如果它不存在将创建).

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class InsertData {
   public static void main(String args[]) throws Exception {
      //Registering the driver
      Class.forName("org.apache.derby.jdbc.EmbeddedDriver");
      //Getting the Connection object
      String URL = "jdbc:derby:SampleDB;create=true";
      Connection conn = DriverManager.getConnection(URL);

      //Creating the Statement object
      Statement stmt = conn.createStatement();

      //Creating a table and populating
      String query = "CREATE TABLE Employees("
         + "Id INT NOT NULL GENERATED ALWAYS AS IDENTITY, "
         + "Name VARCHAR(255), Salary INT NOT NULL, "
         + "Location VARCHAR(255), "
         + "PRIMARY KEY (Id))";
      //Executing the query
      String query = "INSERT INTO Employees("
         + "Name, Salary, Location) VALUES "
         + "('Amit', 30000, 'Hyderabad'), "
         + "('Kalyan', 40000, 'Vishakhapatnam'), "
         + "('Renuka', 50000, 'Delhi'), "
         + "('Archana', 15000, 'Mumbai'), "
         + "('Trupthi', 45000, 'Kochin'), "
         + "('Suchatra', 33000, 'Pune'), "
         + "('Rahul', 39000, 'Lucknow'), "
         + "('Trupti', 45000, 'Kochin')";
      stmt.execute(query);
      System.out.println("Values inserted");
   }
}

输出

执行上述程序后,您将获得以下输出 :

Values inserted