I’m using OLEDB provider for ADO.Net connecting to an Oracle database. In my loop, I am doing an insert:
insert into ps_tl_compleave_tbl values('2626899', 0, TO_DATE('01/01/2002', 'MM/DD/YYYY'), 'LTKN', 'LTKN', '52', TO_DATE('01/01/2002', 'MM/DD/YYYY'), 16.000000, 24.000)insert into ps_tl_compleave_tbl values('4327142', 0, TO_DATE('03/23/2002', 'MM/DD/YYYY'), 'LTKN', 'LTKN', '51', TO_DATE('03/23/2002', 'MM/DD/YYYY'), 0.000000, 0.000)
The first insert succeeds but the second one gives an error:
ORA-00933: SQL command not properly ended
What am I doing wrong?
Are you getting the ORA-00933: SQL command not properly ended error? Learn what causes it and how to resolve it in this article.
This error is caused by an SQL statement with a clause that is not allowed for that statement. Some examples that might cause this error are:
- An INSERT statement with an ORDER BY clause or an INNER JOIN
- A DELETE statement with an INNER JOIN or ORDER BY clause
- An UPDATE statement with an INNER JOIN
ORA-00933 Solution
The solution to the ORA-00933 error is to update your query to remove the clause that’s causing the issue. This would depend on the type of query being run.
Let’s take a look at some example solutions.
While you’re here, if you want an easy-to-use list of the main features in Oracle SQL, get my SQL Cheat Sheet here:
INSERT Statement
If you’re getting an “ORA-00933 sql command not properly ended” on INSERT, then it could be because:
- You have a JOIN keyword (such as INNER JOIN, LEFT JOIN) in the query.
- You have an ORDER BY in the query.
You might have a query that looks like this:
INSERT INTO student (student_id, first_name, last_name)
VALUES (20, 'Jack', 'Wheeler')
ORDER BY student_id;
This statement fails because the INSERT statement does not support ORDER BY. When you insert data, you don’t need to specify an order. The data is inserted into the table anyway, and the ORDER BY is only used for SELECT queries.
So, to correct the statement and stop the error, remove the ORDER BY:
INSERT INTO student (student_id, first_name, last_name)
VALUES (20, 'Jack', 'Wheeler');
Refer to my guide on the SQL INSERT statement here for more information.
UPDATE Statement
If you’re getting the “ORA-00933 sql command not properly ended” on UPDATE, then your query might look like this:
UPDATE student
SET student.fees_paid = payment.amount
INNER JOIN payment ON student.student_id = payment.student_id;
You can’t use a JOIN clause in an UPDATE statement. To update a value like this, include the JOIN logic in a subquery:
UPDATE student
SET student.fees_paid = (
SELECT amount
FROM payment
WHERE student.student_id = payment.student_id
);
This statement should now run without errors.
Read my guide on the SQL UPDATE statement for more information.
DELETE Statement
If you’re getting the “ORA-00933 sql command not properly ended” on DELETE, then your query might look like this:
DELETE FROM student
WHERE last_name = 'Smith'
ORDER BY student_id;
The error appears because the ORDER BY does not belong in a DELETE statement. The ORDER BY is only for ordering data returned by a SELECT statement, and serves no purpose in a DELETE statement.
So, change your query to remove the ORDER BY clause:
DELETE FROM student
WHERE last_name = 'Smith';
You can refer to my guide on the SQL DELETE statement for more information.
SELECT Statement
Are you getting an “ORA-00933 sql command not properly ended” in a SELECT query?
Well, the SELECT query can support joins and ORDER BY, so what could be causing it?
There can be several reasons for this:
- Your SELECT statement is using UNION or UNION ALL, and you have an ORDER BY at any point except the end of the query. You can only have an ORDER BY at the end of the query, not within each UNION.
- You have forgotten a comma in between tables when selecting them.
- You’re running Oracle 8i and trying to use INNER JOIN keywords (or similar join keywords). These were implemented in Oracle 9i.
The exact solution will depend on your SELECT query, but here are a few things you can check:
- Check that you have the right clauses for your query and are in the right place (e.g. not missing a FROM clause).
- Check that you’re not missing a comma anywhere, such as in the SELECT clause or the FROM clause.
- Check that you’re not missing a bracket anywhere. This can be made easier with SQL Developer’s matching bracket highlighting or formatting the SQL to see if something is missing. Other IDEs have similar features.
So, that’s how you resolve the ORA-00933 error.
While you’re here, if you want an easy-to-use list of the main features in Oracle SQL, get my SQL Cheat Sheet here:
ORA-00933: SQL command not properly ended error occurs when an Oracle SQL command is ended with an inappropriate clause. The DML commands INSERT, UPDATE, DELETE, and SELECT should use oracle’s syntax. The error is thrown when a clause is added that does not normally come within the command of a SQL query. An SQL statement with a clause that isn’t allowed for that statement causes this error. The error SQL Error: ORA-00933: SQL command not properly ended may be fixed by updating your query and removing the clause that is creating the problem. This would be determined by the query type.
This error is caused by a SQL statement that has a clause that isn’t permitted in that statement. The query contains a JOIN keyword, such as INNER JOIN or LEFT JOIN. The query contains an ORDER BY that is not permitted in the query. In your query, you have a where clause that isn’t allowed. You may need to update the sql query using various ways such as sub queries or correlated queries to achieve the same functional results. To resolve the problem, eliminate any clauses that aren’t related to the sql query.
The Problem
If you add an incorrect clause to a query like INSERT, UPDATE, DELETE, or SELECT, the sql query will not be able to add the clause. The Oracle query will fail because it was unable to process the clause that is unrelated to the sql query. To get the same functionality, the clause should be deleted from the sql query or the query should be redone using an alternative technique.
update employee set deptid=1 orderby name;
Error
Error starting at line : 4 in command -
update employee set deptid=1 orderby name
Error at Command Line : 4 Column : 30
Error report -
SQL Error: ORA-00933: SQL command not properly ended
00933. 00000 - "SQL command not properly ended"
*Cause:
*Action:
Solution 1
The INNER JOIN, OUTER JOIN, WHERE clause, or ORDER BY clause are not allowed in the INSERT statement. If any of the above clauses are included in the INSERT statement, the sql query will fail because it will encounter the irrelevant clause linked to the insert statement. To fix the error SQL Error: ORA-00933: SQL command not properly ended, delete the above clause from the INSERT statement.
Error 1
insert into employee values (2,'test',1) order by name;
Solution 1
insert into employee values (2,'test',1);
Error 2
insert into employee values (2,'test',1) where name ='sample';
Solution 2
insert into employee values (2,'test',1);
Error 3
insert into employee values (2,'test',1) join dept on dept.deptid=employee.deptid;
Solution 3
insert into employee values (2,'test',1);
Solution 2
If the update statement contains the irrelevant clauses such as ORDER BY, INNER JOIN, OUTTER JOIN the sql query will throw the error. The ORDER BY clause or joins should be removed to resolve the error SQL Error: ORA-00933: SQL command not properly ended.
Error 1
update employee set deptid=1 orderby name;
Solution 1
update employee set deptid=1;
Error 2
update employee
set employee.name = manager.name
inner join manager ON employee.managerid = manager.empid;
Solution 2
update employee set employee.name = (
select name from manager
where employee.managerid = manager.empid
);
Solution 3
If the DELETE statement includes an ORDER BY clause or an INNER JOIN, OUTER JOIN, the delete statement will fail. The table name and where condition for retrieving the record to delete should be included in the DELETE statement. If any additional clause is introduced to the delete statement, Oracle will thrown an error SQL Error: ORA-00933: SQL command not properly ended
Error 1
delete from employee where deptid=1 orderby name;
Solution 1
delete from employee where deptid=1;
Error 2
delete from employee
where employee.name = manager.name
inner join manager ON employee.managerid = manager.empid;
Solution 2
delete from employee where employee.name = (
select name from manager
where employee.managerid = manager.empid
);
Solution 4
If the SELECT query contains two or more tables, the tables are connected by using a comma as a separator and appending the table name. The error will be thrown if a comma is missing between table names. In the select query, a comma should be used between table names.
Error
select * from employee a employee b;
Solution
select * from employee a, employee b;
Solution 5
The select query includes the WHERE clause, ORDER BY clause, GROUP BY clause, and HAVING clause. The clauses must be placed in the proper order. If the clauses are added in a different order than expected, an error SQL Error: ORA-00933: SQL command not properly ended will be thrown.
Error
select * from employee b order by b.name where b.name='test';
Solution
select * from employee b where b.name='test' order by b.name ;
Summary
Bitbucket server startup failed with the below error:
ORA-00933: sql command not properly ended
Diagnosis
You’ll notice the below in the logs:
Caused by: liquibase.exception.DatabaseException: Error executing SQL UPDATE ADMIN.DATABASECHANGELOGLOCK SET LOCKED = 1, LOCKEDBY = 'tti-bbk001-cl.bps.private (28.12.11.57)', LOCKGRANTED = TO_TIMESTAMP('2021-08-26 04:03:36.019', 'YYYY-MM-DD HH24:MI:SS.FF') WHERE ID = 1 AND LOCKED = 0: ORA-00933: SQL command not properly ended
The lock is established during start-up, and then released once all changes to the database are done (all DDL, or structural changes). The node while joining the cluster is setting the lock into databasechangeloglock for the time required to verify the schema usually for few seconds or maybe a minute, but not more than that, then the lock is released and you would pretty much never see the lock again. There are cases where table databasechangeloglock has not been updated with the release lock information as described in KB Could not acquire change log lock.
It’s the Liquibase that uses the DATABASECHANGELOGLOCK table to ensure only one instance of Liquibase is running at one time. So it prevents the racing condition during the startup of the nodes in the cluster or during the upgrade procedure when the lock stays during the whole schema upgrade procedure.
Cause
The message ORA-00933: sql command not properly ended. This error is usually caused by an SQL statement with a clause that is not allowed for that statement. Some examples that might cause this error are:
- An INSERT statement with an ORDER BY clause or an INNER JOIN
- A DELETE statement with an INNER JOIN or ORDER BY clause
- An UPDATE statement with an INNER JOIN
- If the SQL syntax is incorrect.
The error also might occur because of using a semicolon «;» at the end or incorrect syntax since the other causes involve joins.
Solution
Bitbucket Server needs an exclusive lock on the DATABASECHANGELOGLOCK table in order to start successfully. This table needs to be updated with the release lock information.
UPDATE DATABASECHANGELOGLOCK SET LOCKED=0, LOCKGRANTED=null, LOCKEDBY=null where ID=1;
Please refer to our KB article:
- Bitbucket Server Does Not Start — Could not acquire change log lock
First, separate you queries with a semicolon and fix your SET
conditions:
CREATE VIEW cambiodatos AS
SELECT
a.last_name||','||a.first_name AS "Nombre",
a.salary AS "Salario",
b.name AS "Nombre Departamento",
c.name AS "Nombre de Region"
FROM
s_emp a, s_dept b, s_region c
WHERE
a.dept_id = b.id AND b.region_id = c.id;
UPDATE
cambiodatos
SET
name = 'North America'
WHERE
last_name = 'Biri'
AND first_name = 'Ben'
That’s the reason of your error ORA-00933
Second, your UPDATE
statement will fail, as the view you created does not contain field name
.
This query will compile:
UPDATE
cambiodatos
SET
"Nombre de Region" = 'North America'
WHERE
"Nombre" = 'Biri, Ben'
, but most probably will fail as s_region
is not key-preserved
in this view.
To update, use this instead:
MERGE
INTO s_region c
USING (
SELECT b.region_id
FROM s_emp a, s_dept b
WHERE a.last_name || ',' || a.first_name = 'Biri, Ben'
AND b.id = a.dept_id
) q
ON c.id = q.region_id
WHEN MATCHED THEN
UPDATE
SET c.name = 'North America'