अपाचे डर्बी - ऑल्टर टेबल स्टेटमेंट
अतिरिक्त तालिका विवरण, आपको एक मौजूदा तालिका को बदलने की अनुमति देता है। इसके प्रयोग से आप निम्न कार्य कर सकते हैं -
एक कॉलम जोड़ें, एक बाधा जोड़ें
एक कॉलम ड्रॉप करें, एक बाधा छोड़ें
किसी तालिका की पंक्ति स्तर लॉकिंग बदलें
चलिए मान लेते हैं कि हमने कर्मचारी नाम की एक तालिका बनाई है जैसा कि नीचे दिखाया गया है -
ij> CREATE TABLE Employees (
Id INT NOT NULL GENERATED ALWAYS AS IDENTITY,
Name VARCHAR(255),
Salary INT NOT NULL,
Location VARCHAR(255),
PRIMARY KEY (Id)
);
और, सम्मिलित विवरण का उपयोग करके चार रिकॉर्ड सम्मिलित किए गए -
ij> INSERT INTO Employees (Name, Salary, Location) VALUES
('Amit', 30000, 'Hyderabad'),
('Kalyan', 40000, 'Vishakhapatnam'),
('Renuka', 50000, 'Delhi'),
('Archana', 15000, 'Mumbai');
तालिका में एक स्तंभ जोड़ना
ALTER स्टेटमेंट का उपयोग करते हुए तालिका में एक कॉलम जोड़ने के लिए सिंटैक्स निम्नलिखित है।
ALTER TABLE table_name ADD COLUMN column_name column_type;
उदाहरण
ALTER स्टेटमेंट का उपयोग करते हुए, हम टाइप पूर्णांक के साथ आयु नामक एक नया कॉलम जोड़ने का प्रयास कर रहे हैं।
ALTER TABLE Employees ADD COLUMN Age INT;
0 rows inserted/updated/deleted
प्रकार पूर्णांक के साथ Phone_No नाम का एक और कॉलम जोड़ें।
ALTER TABLE Employees ADD COLUMN Phone_No BIGINT;
0 rows inserted/updated/deleted
DESCRIBE कमांड कॉलम और उनके विवरण को सूचीबद्ध करके निर्दिष्ट तालिका का वर्णन करता है, यदि तालिका मौजूद है। यदि आप DESCRIBE करते हैं, तो टेबल के कर्मचारी आप नीचे दिखाए गए अनुसार नए जोड़े गए कॉलम देख सकते हैं -
ij> DESCRIBE Employees;
COLUMN_NAME |TYPE_NAME|DEC&|NUM&|COLUM&|COLUMN_DEF|CHAR_OCTE&|IS_NULL&
------------------------------------------------------------------------------
ID |INTEGER |0 |10 |10 |AUTOINCRE&|NULL |NO
NAME |VARCHAR |NULL|NULL|255 |NULL |510 |YES
SALARY |INTEGER |0 |10 |10 |NULL |NULL |NO
LOCATION |VARCHAR |NULL|NULL|255 |NULL |510 |YES
AGE |INTEGER |0 |10 |10 |NULL |NULL |YES
PHONE_NO |INTEGER |0 |10 |10 |NULL |NULL |YES
6 rows selected
एक मेज पर एक बाधा जोड़ना
ALTER स्टेटमेंट का उपयोग करके तालिका के एक स्तंभ में एक बाधा जोड़ने के लिए सिंटैक्स निम्नलिखित है।
ALTER TABLE table_name ADD CONSTRAINT constraint_name constraint (column_name);
कहाँ पे constraint पूरा नहीं किया जा सकता है, पूर्ण, प्राथमिक कुंजी, अद्वितीय, आगे का कुंजी, चेक।
उदाहरण
ALTER स्टेटमेंट का उपयोग करते हुए, हम बाधा जोड़ने की कोशिश कर रहे हैं UNIQUE Phone_No कॉलम के लिए।
ij> ALTER TABLE Employees ADD CONSTRAINT New_Constraint UNIQUE(Phone_No);
0 rows inserted/updated/deleted
एक बार, आप एक कॉलम में एक UNIQUE बाधा जोड़ते हैं, इसमें दो पंक्तियों के लिए समान मान नहीं हो सकते हैं, अर्थात, प्रत्येक कर्मचारी के लिए फ़ोन नंबर अद्वितीय होना चाहिए।
यदि आप एक ही फोन नंबर के साथ दो कॉलम जोड़ने का प्रयास करते हैं, तो आपको नीचे दिखाए गए अनुसार एक अपवाद मिलेगा।
ij> INSERT INTO Employees (Name, Salary, Location, Age, Phone_No) VALUES
('Amit', 30000, 'Hyderabad', 30, 9848022338);
1 row inserted/updated/deleted
ij> INSERT INTO Employees (Name, Salary, Location, Age, Phone_No) VALUES
('Sumit', 35000, 'Chennai', 25, 9848022338);
ERROR 23505: The statement was aborted because it would have caused a duplicate
key value in a unique or primary key constraint or unique index identified by
'NEW_CONSTRAINT' defined on 'EMPLOYEES'.
एक मेज से एक बाधा गिराने
स्तंभ के एक बाधा को छोड़ने के लिए वाक्य रचना निम्नलिखित है -
ALTER TABLE table_name DROP CONSTRAINT constraint_name;
उदाहरण
निम्नलिखित क्वेरी ऊपर बनाए गए स्तंभ Phone_No पर बाधा नाम New_Constraint को हटा देती है।
ij> ALTER TABLE Employees DROP CONSTRAINT New_Constraint;
0 rows inserted/updated/deleted
जब से हमने Phone_No कॉलम पर UNIQUE बाधा को हटा दिया है, आप उसी फ़ोन नंबर के साथ कॉलम जोड़ सकते हैं।
ij> INSERT INTO Employees (Name, Salary, Location, Age, Phone_No) VALUES
('Sumit', 35000, 'Chennai', 25, 9848022338);
1 row inserted/updated/deleted
आप तालिका की सामग्री को सत्यापित कर सकते हैं ij> कर्मचारियों से * का चयन करें इस प्रकार है -
ID |NAME |SALARY |LOCATION |AGE |PHONE_NO
-------------------------------------------------------------------------
1 |Amit |30000 |Hyderabad |30 |9848022338
2 |Sumit |35000 |Chennai |25 |9848022338
2 rows selected
एक तालिका से एक स्तंभ गिराना
कॉलम के एक कॉलम को छोड़ने के लिए सिंटैक्स निम्नलिखित है।
ALTER TABLE table_name DROP COLUMN column_name;
उदाहरण
निम्नलिखित क्वेरी नाम के कॉलम को हटा देती है age of the employee -
ij> ALTER TABLE Employees DROP COLUMN Age;
0 rows inserted/updated/deleted
यदि आप तालिका का वर्णन करते हैं, तो आप केवल 4 कॉलम देख सकते हैं।
ij> DESCRIBE Employees;
COLUMN_NAME |TYPE_NAME|DEC&|NUM&|COLUM&|COLUMN_DEF|CHAR_OCTE&|IS_NULL&
------------------------------------------------------------------------------
ID |INTEGER |0 |10 |10 |AUTOINCRE&|NULL |NO
NAME |VARCHAR |NULL|NULL|255 |NULL |510 |YES
SALARY |INTEGER |0 |10 |10 |NULL |NULL |NO
LOCATION |VARCHAR |NULL|NULL|255 |NULL |510 |YES
PHONE_NO |BIGINT |0 |10 |19 |NULL |NULL |YES
JDBC प्रोग्राम का उपयोग करके तालिका को बदलना
ALD क्वेरी का उपयोग करके तालिका को बदलने के लिए JDBC कार्यक्रम निम्नलिखित है -
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class AlterTableExample {
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();
//Executing the query
String createQuery = "CREATE TABLE Employees( "
+ "Id INT NOT NULL GENERATED ALWAYS AS IDENTITY, "
+ "Name VARCHAR(255), "
+ "Salary INT NOT NULL, "
+ "Location VARCHAR(255), "
+ "PRIMARY KEY (Id))";
stmt.execute(createQuery);
System.out.println("Table created");
System.out.println(" ");
//Executing the query
String insertQuery = "INSERT INTO Employees("
+ "Name, Salary, Location) VALUES "
+ "('Amit', 30000, 'Hyderabad'), "
+ "('Kalyan', 40000, 'Vishakhapatnam'), "
+ "('Renuka', 50000, 'Delhi'), "
+ "('Archana', 15000, 'Mumbai'), "
+ "('Trupti', 45000, 'Kochin')";
stmt.execute(insertQuery);
System.out.println("Values inserted");
System.out.println(" ");
//Executing the query
String selectQuery = "SELECT * FROM Employees";
ResultSet rs = stmt.executeQuery(selectQuery);
System.out.println("Contents of the table after inserting the table");
while(rs.next()) {
System.out.println("Id: "+rs.getString("Id"));
System.out.println("Name: "+rs.getString("Name"));
System.out.println("Salary: "+rs.getString("Salary"));
System.out.println("Location: "+rs.getString("Location"));
}
System.out.println(" ");
//Altering the table
stmt.execute("ALTER TABLE Employees ADD COLUMN Age INT");
stmt.execute("ALTER TABLE Employees ADD COLUMN Phone_No BigINT");
stmt.execute("ALTER TABLE Employees " + "ADD CONSTRAINT New_Constraint UNIQUE(Phone_No)");
stmt.execute("INSERT INTO Employees "
+ "(Name, Salary, Location, Age, Phone_No) "
+ "VALUES ('Amit', 30000, 'Hyderabad', 30, 9848022338)");
ResultSet alterResult = stmt.executeQuery("Select * from Employees");
System.out.println("Contents of the table after altering "
+ "the table and inserting values to it: ");
while(alterResult.next()) {
System.out.println("Id: "+alterResult.getString("Id"));
System.out.println("Name: "+alterResult.getString("Name"));
System.out.println("Salary: "+alterResult.getString("Salary"));
System.out.println("Location: "+alterResult.getString("Location"));
System.out.println("Age: "+alterResult.getString("Age"));
System.out.println("Phone_No: "+alterResult.getString("Phone_No"));
}
}
}
उत्पादन
उपरोक्त कार्यक्रम निष्पादित करने पर, निम्न आउटपुट उत्पन्न होगा -
Table created
Values inserted
Contents of the table after inserting the table
Id: 1
Name: Amit
Salary: 30000
Location: Hyderabad
Id: 2
Name: Kalyan
Salary: 40000
Location: Vishakhapatnam
Id: 3
Name: Renuka
Salary: 50000
Location: Delhi
Id: 4
Name: Archana
Salary: 15000
Location: Mumbai
Id: 5
Name: Trupti
Salary: 45000
Location: Kochin
Contents of the table after altering the table and inserting values to it:
Id: 1
Name: Amit
Salary: 30000
Location: Hyderabad
Age: null
Phone_No: null
Id: 2
Name: Kalyan
Salary: 40000
Location: Vishakhapatnam
Age: null
Phone_No: null
Id: 3
Name: Renuka
Salary: 50000
Location: Delhi
Age: null
Phone_No: null
Id: 4
Name: Archana
Salary: 15000
Location: Mumbai
Age: null
Phone_No: null
Id: 5
Name: Trupti
Salary: 45000
Location: Kochin
Age: null
Phone_No: null
Id: 6
Name: Amit
Salary: 30000
Location: Hyderabad
Age: 30
Phone_No: 9848022338