package com.han.ch20.q1;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import com.han.Derby;
public class UpdateStu {
private static Connection conn;
private static PreparedStatement ps;
private static ResultSet rs;
private static ResultSetMetaData rsmd; // ResultSetMetaData has not the close() method
public static void main(String[] rgs){
Derby.loadDriver();// As is said in the class Derby, this action is not necessary with a JRE 1.6 and later.
try {
// create database "ch20"
conn=Derby.createDatabaseAndGetConnection("ch20", "", "");
// drop the table "tb_emp" if it exists
if(Derby.isTableExists("tb_emp", conn)){
ps=conn.prepareStatement("drop table tb_emp");
ps.execute();
}
// create a table "tb_emp" in this database
ps=conn.prepareStatement("create table tb_emp(id int, name varchar(20), department varchar(20))");
ps.execute();
// add elements into the table
ps=conn.prepareStatement("insert into tb_emp values(?,?,?)");
ps.setInt(1, 1);
ps.setString(2, "Jing LI");
ps.setString(3, "Computer technology");
ps.executeUpdate();
ps.setInt(1, 2);
ps.setString(2, "Hao LI");
ps.setString(3, "Sales department");
ps.executeUpdate();
ps.setInt(1, 3);
ps.setString(2, "Yuanyuan XIONG");
ps.setString(3, "Copumter technology");
ps.executeUpdate();
ps.setInt(1, 4);
ps.setString(2, "Mei LIU");
ps.setString(3, "Sales department");
ps.executeUpdate();
// consult the information associated with the department "Sales department"
ps=conn.prepareStatement("select * from tb_emp where department='Sales department'");
rs=ps.executeQuery();
// display the query results on the console
rsmd=rs.getMetaData();
int numberOfColumns=rsmd.getColumnCount();
String[] columnNames=new String[numberOfColumns];
String[] columnTypeNames=new String[numberOfColumns];
int[] precisions=new int[numberOfColumns];
for(int i=0;i<numberOfColumns;i++){
columnNames[i]=rsmd.getColumnName(i+1);
columnTypeNames[i]=rsmd.getColumnTypeName(i+1);
precisions[i]=rsmd.getPrecision(i+1);
System.out.println(columnNames[i]+" : "
+columnTypeNames[i]+"("
+precisions[i]+")");
}
for(int i=0;i<numberOfColumns;i++){
String columnName=columnNames[i];
if(columnName.length()>precisions[i]){
columnName=columnName.substring(0, precisions[i]);
}
System.out.printf("%-"+precisions[i]+"s|",columnName);
}
System.out.println();
while(rs.next()){
for(int i=0;i<numberOfColumns;i++){
System.out.printf("%-"+precisions[i]+"s|",rs.getObject(i+1));
}
System.out.println();
}
// close the opened resources
rs.close();
ps.close();
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
// perform a clean database closing
Derby.shutdownDatabase("ch20");
Derby.shutdownAll();
}
}
}
package com.han;
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Properties;
/**
* The Embedded mode is limited by that we can't run simultaneously
* two programs (two JVM instances) using a same database (databaseName is the same).
* <p>
* But we can instead use the NetworkServer mode to avoid this case,
* it is to say the "Client/Server" mode.
* In this mode, you have to first start the NetworkServer by this command :
* <pre>
* java org.apache.derby.drda.NetworkServerControl start [-h hostIP -p portNumber]
* </pre>
* Or use the API :
* <pre>
* NetworkServerControl serverControl = new NetworkServerControl(InetAddress.getByName("myhost"),1621);
* serverControl.shutdown();
* </pre>
* schema is above the table/view. In MySQL schema is equivalent to database.
* So in MySQL, create database==create schema,
* but create database is not applicable to Java Derby.
* <p>
* In Derby, schema is also equivalent to a user name.
* @author HAN
*
*/
public class Derby {
private static Connection con=null;
private static String port=null;
private static String ip=null;
/**
* The port will be set to default: 1527
*/
public static void setPortToDefault(){
port="1527";
}
public static void setPort(String port){
Derby.port=port;
}
public static void setServer(String ip){
Derby.ip=ip;
}
/**
* This express loading driver is not necessary for Java 6 and later, JDBC 4.0 and later.
* Because it can be added automatically by <code>DriverManager</code> when connecting to a database.
*/
public static void loadDriver(){
//load the driver
if(port==null){
if(ip!=null){
System.out.println("You seem to have set an ip address, if so, you have also to assign a port, or else an embedded database will be automatically used");
}
try {
Class.forName("org.apache.derby.jdbc.EmbeddedDriver");
System.out.println("The embedded driver is successfully loaded");
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}else{
try{
Class.forName("org.apache.derby.jdbc.ClientDriver");
System.out.println("The client driver is successfully loaded");
}catch(ClassNotFoundException e){
e.printStackTrace();
}
}
}
/**
* create and connect a database
* @param databaseName
* @param user
* @param password
* @return a connection to the URL
* @throws SQLException
*/
public static Connection createDatabaseAndGetConnection(String databaseName, String user, String password) throws SQLException{
//create and connect the database
Properties props=new Properties();
props.put("user",user);
props.put("password",password);
if(port==null){
if(ip!=null){
System.out.println("You seem to have set an ip address, if so, you have also to assign a port before loading the driver, or else an embedded database is automatically used");
}
con=DriverManager.getConnection("jdbc:derby:"+databaseName+";create=true", props);
System.out.println("Connection is successfully established, it uses an Embedded database");
}else if(ip==null){
con=DriverManager.getConnection("jdbc:derby://localhost:"+port+"/"+databaseName+";create=true", props);
System.out.println("Connection is sucessfully established, it uses an network database but stored in the local host via the port: "+port);
}else{
con=DriverManager.getConnection("jdbc:derby://"+ip+":"+port+"/"+databaseName+";create=true", props);
System.out.println("Connection is sucessfully established, it uses an network database whose host ip is: "+ip+" and via the port: "+port);
}
return con;
}
/**
* Shut down a specified database. But it doesn't matter that later we could also connect to another database.
* Because the Derby engine is not closed.
* @param databaseName
*/
public static void shutdownDatabase(String databaseName){
boolean gotSQLExc = false;
if(port==null){
try {
DriverManager.getConnection("jdbc:derby:"+databaseName+";shutdown=true");
} catch (SQLException se) {
if ( se.getSQLState().equals("08006") ) {
gotSQLExc = true;
}
}
if (!gotSQLExc) {
System.out.println("Database did not shut down normally");
} else {
System.out.println("Database: "+databaseName+" shut down normally");
}
}else if(ip==null){
try {
DriverManager.getConnection("jdbc:derby://localhost:"+port+"/"+databaseName+";shutdown=true");
} catch (SQLException se) {
// TODO Auto-generated catch block
if ( se.getSQLState().equals("08006") ) {
gotSQLExc = true;
}
}
if (!gotSQLExc) {
System.out.println("Database did not shut down normally");
} else {
System.out.println("Database: "+databaseName+" shut down normally");
}
}else{
try {
DriverManager.getConnection("jdbc:derby://"+ip+":"+port+"/"+databaseName+";shutdown=true");
} catch (SQLException se) {
if ( se.getSQLState().equals("08006") ) {
gotSQLExc = true;
}
}
if (!gotSQLExc) {
System.out.println("Database did not shut down normally");
} else {
System.out.println("Database: "+databaseName+" shut down normally");
}
}
}
/**
* shut down all opened databases and close the Derby engine.
* The effect is that after the execution of this method, we will not permitted to use Derby again in the rest of our program.
* Or else, an exception of "can't find a suitable driver for [a database URL]" will be thrown.
* However, you can still use another approach to resolve this problem: newInstance()
* For example,
* <pre>
* Class.forName("org.apache.derby.jdbc.EmbeddedDriver").newInstance();
* </pre>
*/
public static void shutdownAll(){
boolean gotSQLExc = false;
try {
DriverManager.getConnection("jdbc:derby:;shutdown=true");
} catch (SQLException se) {
// TODO Auto-generated catch block
if ( se.getSQLState().equals("XJ015") ) {
gotSQLExc = true;
}
}
if (!gotSQLExc) {
System.out.println("Database did not shut down normally");
} else {
System.out.println("All databases shut down normally and Derby completely closed");
}
}
/**
* Just connect to a database desired by providing the appropriate parameters.
* @param databaseName
* @param user
* @param password
* @return
* @throws SQLException
*/
public static Connection getConnection(String databaseName, String user, String password) throws SQLException{
if(port==null){
if(ip!=null){
System.out.println("You seem to have set an ip address, if so, you have also to assign a port before loading the driver, or else an embedded database is automatically used");
}
con=DriverManager.getConnection("jdbc:derby:"+databaseName,user,password);
System.out.println("Connection is sucessfully established, it uses an Embedded database");
}else if(ip==null){
con=DriverManager.getConnection("jdbc:derby://localhost:"+port+"/"+databaseName,user,password);
System.out.println("Connection is sucessfully established, it uses an network database but stored in the local host via the port: "+port);
}else{
con=DriverManager.getConnection("jdbc:derby://"+ip+":"+port+"/"+databaseName,user,password);
System.out.println("Connection is sucessfully established, it uses an network database whose host ip is: "+ip+" and via the port: "+port);
}
return con;
}
public static HashSet<String> listAllTables(Connection con) throws SQLException{
DatabaseMetaData meta = con.getMetaData();
ResultSet res = meta.getTables(null, null, null, new String[]{"TABLE"});
HashSet<String> set=new HashSet<String>();
while (res.next()) {
set.add(res.getString("TABLE_NAME"));
//use TABLE_SCHEM to view all users or schemas
//set.add(res.getString("TABLE_SCHEM"));
}
System.out.println("All the tables associated to current connection are :");
System.out.println(set);
return set;
}
public static boolean isTableExists(String table, Connection con) throws SQLException{
if(listAllTables(con).contains(table.toUpperCase())){
return true;
}else{
return false;
}
}
public static HashSet<String> listAllSchemas(Connection con) throws SQLException{
DatabaseMetaData meta = con.getMetaData();
ResultSet res = meta.getSchemas(null, null);
HashSet<String> set=new HashSet<String>();
while (res.next()) {
set.add(res.getString("TABLE_SCHEM"));
}
System.out.println("All the schemas associated to current connection are :");
System.out.println(set);
return set;
}
public static HashMap<String, String> listAllSchemasAndTables(Connection con) throws SQLException{
DatabaseMetaData meta = con.getMetaData();
ResultSet res = meta.getTables(null, null, null, new String[]{"TABLE"});
HashMap<String, String> map=new HashMap<String, String>();
while (res.next()) {
map.put(res.getString("TABLE_SCHEM"),res.getString("TABLE_NAME"));
}
System.out.println("All the tables and their corresponding schemas associated to current connection are :");
System.out.println(map);
return map;
}
}