Hola:
El mensaje es muy claro
Column check constraint cannot reference other columns
El CHECK NO puede hacer referencia a otras columnas....
Es decir que esto:
No puede ser.... NO puedes hacer el check de una columna en referencia de otra
Supongo que estas estudiando, y es tu primer vez diseñando bases de datos aqui un par de temas que te pueden servir:
1. La logica del NEGOCIO (aplicacion) no deberia ser definida en la Base de Datos, es decir esta validacion de que la fecha de inicio sea menor a la fecha termino deberia estar en tu front end no aqui, ademas mas detalles ambos campos por defecto estan a NULO, no le has dicho que no lo sean, por lo que podria NO cumplirse dicha regla, seguramente dicha regla solo se cumple cuando vas a asignar un valor a fecha de termino, insisto que esta validacion deberia estar en tu aplicación.
2. Aunque ORACLE lo permita, estas usando como llave primaria de PROFESORES el Nombre_Profesor que es un VARCHAR, cuando tengas miles o millones de registros (obviamente quizas para esta tarea nunca los tengas, pero para ir corrigiendo), el igualar caracteres le cuesta 2 veces mas trabajo que igualar numeros, para eso le asignas un CODIGO o CLAVE.
3. Has declarado el Nombre_profesor en los cursos como UNIQUE, es decir que un profesor solo podra estar asignado a UNO y solo UN Curso, esto es realmente lo que quieres???
4. UNa buena costumbre es, declarar primero todas las columnas (campos), luego todos los constrainsts y/o indices... no irlos mezclando del modo en que lo haces... esto por efectos de lectura y por efectos logicos asi garantizas tener las columnas antes que los constraints e indices.
5. Por ultimo, el largo de los campos, te lo dejo a pensar pones el nombre del profesor como varchar(20)....
Si solo vas a guardar el nombre "Jorge", "Pedro", "Luis", etc, pues muy seguramente te sirva aun si se llamara "Francisco Javier" (16 posiciones)...
Pero obviamente si tienes dos profesores con el mismo nombre, "Francisco Javier Gómez Perez" y "Francisco Javier Gómez López" ... luego entonces hay que pensarselo no crees?