Discussions
Categories
- 197K All Categories
- 2.5K Data
- 546 Big Data Appliance
- 1.9K Data Science
- 450.9K Databases
- 221.9K General Database Discussions
- 3.8K Java and JavaScript in the Database
- 31 Multilingual Engine
- 552 MySQL Community Space
- 479 NoSQL Database
- 7.9K Oracle Database Express Edition (XE)
- 3.1K ORDS, SODA & JSON in the Database
- 556 SQLcl
- 4K SQL Developer Data Modeler
- 187.2K SQL & PL/SQL
- 21.4K SQL Developer
- 296.4K Development
- 17 Developer Projects
- 139 Programming Languages
- 293.1K Development Tools
- 111 DevOps
- 3.1K QA/Testing
- 646.1K Java
- 28 Java Learning Subscription
- 37K Database Connectivity
- 161 Java Community Process
- 105 Java 25
- 22.1K Java APIs
- 138.2K Java Development Tools
- 165.3K Java EE (Java Enterprise Edition)
- 19 Java Essentials
- 162 Java 8 Questions
- 86K Java Programming
- 81 Java Puzzle Ball
- 65.1K New To Java
- 1.7K Training / Learning / Certification
- 13.8K Java HotSpot Virtual Machine
- 94.3K Java SE
- 13.8K Java Security
- 205 Java User Groups
- 24 JavaScript - Nashorn
- Programs
- 475 LiveLabs
- 39 Workshops
- 10.2K Software
- 6.7K Berkeley DB Family
- 3.5K JHeadstart
- 5.7K Other Languages
- 2.3K Chinese
- 175 Deutsche Oracle Community
- 1.1K Español
- 1.9K Japanese
- 233 Portuguese
Cannot create trigger using OraOLEDB.Oracle from .Net

604519
Member Posts: 7
Hi,
I have a problem creating a trigger using OraOLEDB.Oracle provider for OleDb.
The problem is that the command with create trigger statement executes fine but I cannot find the trigger in the database after that.
I tried executing the same create trigger statement using Microsoft's OracleCommand from Oracle.DataAccess and it all worked but I really need to be able to do it connecting from OleDb.
I am using the latest OleDb provider downloaded from Oracle.
The database is oracle 10 express and I am working on a Windows Vista.
Below is a sample code:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.OleDb;
using Oracle.DataAccess.Client;
namespace OracleTriggerRegisterTest
{
class Program
{
//OraOLEDB.Oracle
private static readonly string m_connString = @Provider=OraOLEDB.Oracle;Data Source=XXX.XXX.X.XX/XE;User Id=XXXXX;Password=XXXX;;
private static readonly string m_connStringOracle = @Data Source=XXX.XXX.X.XX/XE;User Id=XXXX;Password=XXXX;;
private static readonly string newLine = Environment.NewLine; //Also tried with " "
private static readonly string m_command = "CREATE OR REPLACE TRIGGER \"TGI_EMPLOYEES\"" + newLine
+ "AFTER INSERT" + newLine
+ "ON \"HR\".\"EMPLOYEES\"" + newLine
+ "REFERENCING NEW AS source_rec FOR EACH ROW" + newLine
+ "DECLARE" + newLine
+ " recCount int := 0;" + newLine
+ "BEGIN" + newLine
+ "SELECT NVL(MAX(\"IST_recId\"),0) + 1 INTO recCount FROM \"HR\".\"Employee_KEys\";" + newLine
+ "INSERT INTO \"HR\".\"Employee_KEys\" (" + newLine
+ "\"IST_SearchKey\", \"IST_recId\", \"IST_definitionId\"," + newLine
+ "\"FIRST_NAME\"," + newLine
+ "\"EMPLOYEE_ID\"" + newLine
+ ")" + newLine
+ "SELECT" + newLine
+ "B.COLUMN_VALUE, recCount, 1," + newLine
+ ":source_rec.\"FIRST_NAME\", :source_rec.\"EMPLOYEE_ID\"" + newLine
+ "FROM TABLE ( IST_GETKEYS ( 'Matcher', 'name1 ', rtrim(NVL( :source_rec.\"FIRST_NAME\", '')) )) B;" + newLine
+ "END;" + newLine; //Tried removing the ; tried adding newLine + /
static void Main(string[] args)
{
DoOleDB();
DodotNet();
}
private static void DoOleDB()
{
try
{
OleDbConnection conn = new OleDbConnection(m_connString);
conn.Open();
OleDbCommand cmd = new OleDbCommand();
cmd.Connection = conn;
cmd.CommandType = System.Data.CommandType.Text;
cmd.CommandText = m_command;
cmd.ExecuteNonQuery();
conn.Close();
}
catch (Exception ex)
{
String msg = ex.Message;
}
}
private static void DodotNet()
{
try
{
OracleConnection conn = new OracleConnection(m_connStringOracle);
conn.Open();
OracleCommand cmd = new OracleCommand();
cmd.Connection = conn;
cmd.CommandType = System.Data.CommandType.Text;
cmd.CommandText = m_command;
cmd.ExecuteNonQuery();
conn.Close();
}
catch (Exception ex)
{
String msg = ex.Message;
}
}
}
}
I appreciate any help on this.
Regards,
Kos Mitev
I have a problem creating a trigger using OraOLEDB.Oracle provider for OleDb.
The problem is that the command with create trigger statement executes fine but I cannot find the trigger in the database after that.
I tried executing the same create trigger statement using Microsoft's OracleCommand from Oracle.DataAccess and it all worked but I really need to be able to do it connecting from OleDb.
I am using the latest OleDb provider downloaded from Oracle.
The database is oracle 10 express and I am working on a Windows Vista.
Below is a sample code:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.OleDb;
using Oracle.DataAccess.Client;
namespace OracleTriggerRegisterTest
{
class Program
{
//OraOLEDB.Oracle
private static readonly string m_connString = @Provider=OraOLEDB.Oracle;Data Source=XXX.XXX.X.XX/XE;User Id=XXXXX;Password=XXXX;;
private static readonly string m_connStringOracle = @Data Source=XXX.XXX.X.XX/XE;User Id=XXXX;Password=XXXX;;
private static readonly string newLine = Environment.NewLine; //Also tried with " "
private static readonly string m_command = "CREATE OR REPLACE TRIGGER \"TGI_EMPLOYEES\"" + newLine
+ "AFTER INSERT" + newLine
+ "ON \"HR\".\"EMPLOYEES\"" + newLine
+ "REFERENCING NEW AS source_rec FOR EACH ROW" + newLine
+ "DECLARE" + newLine
+ " recCount int := 0;" + newLine
+ "BEGIN" + newLine
+ "SELECT NVL(MAX(\"IST_recId\"),0) + 1 INTO recCount FROM \"HR\".\"Employee_KEys\";" + newLine
+ "INSERT INTO \"HR\".\"Employee_KEys\" (" + newLine
+ "\"IST_SearchKey\", \"IST_recId\", \"IST_definitionId\"," + newLine
+ "\"FIRST_NAME\"," + newLine
+ "\"EMPLOYEE_ID\"" + newLine
+ ")" + newLine
+ "SELECT" + newLine
+ "B.COLUMN_VALUE, recCount, 1," + newLine
+ ":source_rec.\"FIRST_NAME\", :source_rec.\"EMPLOYEE_ID\"" + newLine
+ "FROM TABLE ( IST_GETKEYS ( 'Matcher', 'name1 ', rtrim(NVL( :source_rec.\"FIRST_NAME\", '')) )) B;" + newLine
+ "END;" + newLine; //Tried removing the ; tried adding newLine + /
static void Main(string[] args)
{
DoOleDB();
DodotNet();
}
private static void DoOleDB()
{
try
{
OleDbConnection conn = new OleDbConnection(m_connString);
conn.Open();
OleDbCommand cmd = new OleDbCommand();
cmd.Connection = conn;
cmd.CommandType = System.Data.CommandType.Text;
cmd.CommandText = m_command;
cmd.ExecuteNonQuery();
conn.Close();
}
catch (Exception ex)
{
String msg = ex.Message;
}
}
private static void DodotNet()
{
try
{
OracleConnection conn = new OracleConnection(m_connStringOracle);
conn.Open();
OracleCommand cmd = new OracleCommand();
cmd.Connection = conn;
cmd.CommandType = System.Data.CommandType.Text;
cmd.CommandText = m_command;
cmd.ExecuteNonQuery();
conn.Close();
}
catch (Exception ex)
{
String msg = ex.Message;
}
}
}
}
I appreciate any help on this.
Regards,
Kos Mitev
Tagged:
This discussion has been closed.