此内容没有您所选择的语言版本。
16.4. Additional SQL Functions
16.4.1. Custom SQL for Create, Update and Delete
复制链接链接已复制到粘贴板!
		Hibernate3 can use custom SQL statements for create, update, and delete operations. The class and collection persisters in Hibernate already contain a set of configuration time generated strings (insertsql, deletesql, updatesql etc.). The mapping tags 
<sql-insert>, <sql-delete>, and <sql-update> override these strings:
	
		The SQL is directly executed in your database, so you can use any dialect you like. This will reduce the portability of your mapping if you use database specific SQL.
	
		Stored procedures are supported if the 
callable attribute is set:
	
		The order of the positional parameters is vital, as they must be in the same sequence as Hibernate expects them.
	
		You can view the expected order by enabling debug logging for the 
org.hibernate.persister.entity level. With this level enabled, Hibernate will print out the static SQL that is used to create, update, delete etc. entities. To view the expected sequence, do not include your custom SQL in the mapping files, as this will override the Hibernate generated static SQL.
	
		The stored procedures are in most cases required to return the number of rows inserted, updated and deleted, as Hibernate has some runtime checks for the success of the statement. Hibernate always registers the first statement parameter as a numeric output parameter for the CUD operations: