在 Katalon Studio 中连接到 Oracle SQL
Connect to Oracle SQL in Katalon Studio
我尝试使用下面的 Groovy 脚本连接到 Oracle SQL
数据库:
def connectDB(String dataFile){
//Load driver class for your specific database type
Class.forName("oracle.jdbc.driver.OracleDriver")
String connectionString = "jdbc:sqlite:" + dataFile
if(connection != null && !connection.isClosed()){
connection.close()
}
connection = DriverManager.getConnection(connectionString)
return connection
}
连接字符串中有sqlite,但不确定我应该在那里使用哪个值。 (我也试过 jdbc:oracle
。)
我使用以下class建立数据库连接。
public class sqlconnect {
private static Connection connection = null;
/**
* Open and return a connection to database
* @param dataFile absolute file path
* @return an instance of java.sql.Connection
*/
@Keyword
def connectDB(String dataFile){
//Load driver class for your specific database type
Class.forName("oracle.jdbc.driver.OracleDriver")
String connectionString = "jdbc:sqlite:" + dataFile
if(connection != null && !connection.isClosed()){
connection.close()
}
connection = DriverManager.getConnection(connectionString)
return connection
}
/**
* execute a SQL query on database
* @param queryString SQL query string
* @return a reference to returned data collection, an instance of java.sql.ResultSet
*/
@Keyword
def executeQuery(String queryString) {
Statement stm = connection.createStatement()
ResultSet rs = stm.executeQuery(queryString)
return rs
}
@Keyword
def closeDatabaseConnection() {
if(connection != null && !connection.isClosed()){
connection.close()
}
connection = null
}
/**
* Execute non-query (usually INSERT/UPDATE/DELETE/COUNT/SUM...) on database
* @param queryString a SQL statement
* @return single value result of SQL statement
*/
@Keyword
def execute(String queryString) {
Statement stm = connection.createStatement()
boolean result = stm.execute(queryString)
return result
}
}
我已经在 Katalon Studio 的 Project > Settings > Database
下设置了数据库信息。
我使用 CustomKeyword connectDB()
和 executeQuery()
方法从测试用例调用。
更新:
我更新了 connectDB()
方法 Groovy
脚本:
def connectDB(){
Class.forName("oracle.jdbc.driver.OracleDriver")
//String connectionString = "jdbc:oracle:thin:username/password@ipaddress:port/servicename"
if(connection != null && !connection.isClosed()){
connection.close()
}
connection = DriverManager.getConnection("jdbc:oracle:thin:username/password@ipaddress:port/servicename", "username", "password")
return connection
}
我尝试使用变量 connectionString
作为 DriverManager.getConnection()
方法的参数,但在这两种情况下我都收到相同的错误消息。
Cannot cast object 'oracle.jdbc.driver.T4CConnection@' with class
'oracle.jdbc.driver.T4CConnection' to class
'com.mysql.jdbc.Connection'
连接字符串的格式为jdbc:oracle:<drivertype>:@<database>
(例如jdbc:oracle:thin:@host:1521:xe
)。
您可以在调用中传递用户名和密码:DriverManager.getConnection("<connection string>", "<user>", "<password>");
甚至在连接字符串中传递:jdbc:oracle:<drivertype>:<user>/<password>@<database>
(例如 jdbc:oracle:thin:scott/tiger@host:1521:xe
)。
我尝试使用下面的 Groovy 脚本连接到 Oracle SQL
数据库:
def connectDB(String dataFile){
//Load driver class for your specific database type
Class.forName("oracle.jdbc.driver.OracleDriver")
String connectionString = "jdbc:sqlite:" + dataFile
if(connection != null && !connection.isClosed()){
connection.close()
}
connection = DriverManager.getConnection(connectionString)
return connection
}
连接字符串中有sqlite,但不确定我应该在那里使用哪个值。 (我也试过 jdbc:oracle
。)
我使用以下class建立数据库连接。
public class sqlconnect {
private static Connection connection = null;
/**
* Open and return a connection to database
* @param dataFile absolute file path
* @return an instance of java.sql.Connection
*/
@Keyword
def connectDB(String dataFile){
//Load driver class for your specific database type
Class.forName("oracle.jdbc.driver.OracleDriver")
String connectionString = "jdbc:sqlite:" + dataFile
if(connection != null && !connection.isClosed()){
connection.close()
}
connection = DriverManager.getConnection(connectionString)
return connection
}
/**
* execute a SQL query on database
* @param queryString SQL query string
* @return a reference to returned data collection, an instance of java.sql.ResultSet
*/
@Keyword
def executeQuery(String queryString) {
Statement stm = connection.createStatement()
ResultSet rs = stm.executeQuery(queryString)
return rs
}
@Keyword
def closeDatabaseConnection() {
if(connection != null && !connection.isClosed()){
connection.close()
}
connection = null
}
/**
* Execute non-query (usually INSERT/UPDATE/DELETE/COUNT/SUM...) on database
* @param queryString a SQL statement
* @return single value result of SQL statement
*/
@Keyword
def execute(String queryString) {
Statement stm = connection.createStatement()
boolean result = stm.execute(queryString)
return result
}
}
我已经在 Katalon Studio 的 Project > Settings > Database
下设置了数据库信息。
我使用 CustomKeyword connectDB()
和 executeQuery()
方法从测试用例调用。
更新:
我更新了 connectDB()
方法 Groovy
脚本:
def connectDB(){
Class.forName("oracle.jdbc.driver.OracleDriver")
//String connectionString = "jdbc:oracle:thin:username/password@ipaddress:port/servicename"
if(connection != null && !connection.isClosed()){
connection.close()
}
connection = DriverManager.getConnection("jdbc:oracle:thin:username/password@ipaddress:port/servicename", "username", "password")
return connection
}
我尝试使用变量 connectionString
作为 DriverManager.getConnection()
方法的参数,但在这两种情况下我都收到相同的错误消息。
Cannot cast object 'oracle.jdbc.driver.T4CConnection@' with class 'oracle.jdbc.driver.T4CConnection' to class 'com.mysql.jdbc.Connection'
连接字符串的格式为jdbc:oracle:<drivertype>:@<database>
(例如jdbc:oracle:thin:@host:1521:xe
)。
您可以在调用中传递用户名和密码:DriverManager.getConnection("<connection string>", "<user>", "<password>");
甚至在连接字符串中传递:jdbc:oracle:<drivertype>:<user>/<password>@<database>
(例如 jdbc:oracle:thin:scott/tiger@host:1521:xe
)。