cn.vonce.sql.dialect.SqlServerDialect Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vonce-sqlbean-core Show documentation
Show all versions of vonce-sqlbean-core Show documentation
This is the core project of Sqlbean.
The newest version!
package cn.vonce.sql.dialect;
import cn.vonce.sql.bean.Alter;
import cn.vonce.sql.bean.ColumnInfo;
import cn.vonce.sql.bean.Table;
import cn.vonce.sql.config.SqlBeanDB;
import cn.vonce.sql.constant.SqlConstant;
import cn.vonce.sql.enumerate.AlterType;
import cn.vonce.sql.enumerate.DbType;
import cn.vonce.sql.enumerate.JavaMapSqlServerType;
import cn.vonce.sql.enumerate.JdbcType;
import cn.vonce.sql.exception.SqlBeanException;
import cn.vonce.sql.uitls.SqlBeanUtil;
import cn.vonce.sql.uitls.StringUtil;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;
/**
* SQLServer方言
*
* @author Jovi
* @email [email protected]
* @date 2024/4/16 10:09
*/
public class SqlServerDialect implements SqlDialect {
@Override
public JavaMapSqlServerType getType(Field field) {
Class> clazz = SqlBeanUtil.getEntityClassFieldType(field);
for (JavaMapSqlServerType javaType : JavaMapSqlServerType.values()) {
for (Class> thisClazz : javaType.getClasses()) {
if (thisClazz == clazz) {
return javaType;
}
}
}
throw new SqlBeanException(field.getDeclaringClass().getName() + "实体类不支持此字段类型:" + clazz.getSimpleName());
}
@Override
public JdbcType getJdbcType(Field field) {
return JdbcType.getType(getType(field).name());
}
@Override
public String getTableListSql(SqlBeanDB sqlBeanDB, String schema, String tableName) {
StringBuffer sql = new StringBuffer();
sql.append("SELECT t.name, p.value AS remarks ");
sql.append("FROM sys.tables t ");
sql.append("INNER JOIN sys.schemas s ON s.schema_id = t.schema_id ");
sql.append("LEFT JOIN sys.extended_properties p ");
sql.append("ON p.major_id = t.object_id AND p.minor_id = 0 ");
sql.append("WHERE t.type= 'U'");
sql.append(" AND s.name = ");
if (StringUtil.isNotEmpty(schema)) {
sql.append("'");
sql.append(schema);
sql.append("'");
} else {
sql.append("USER_NAME()");
}
if (StringUtil.isNotEmpty(tableName)) {
sql.append(" AND t.name = '" + tableName + "'");
}
return sql.toString();
}
@Override
public String getColumnListSql(SqlBeanDB sqlBeanDB, String schema, String tableName) {
StringBuffer sql = new StringBuffer();
sql.append("SELECT a.cid, a.name, a.type, (CASE a.notnull WHEN 0 THEN 1 ELSE 0 END) AS notnull, ");
sql.append("(CASE LEFT(constraint_name, 2) WHEN 'PK' THEN 1 ELSE 0 END) AS pk, ");
sql.append("(CASE LEFT(constraint_name, 2) WHEN 'FK' THEN 1 ELSE 0 END) AS fk, ");
sql.append("a.length, a.scale, c.value AS remarks ");
sql.append("FROM (");
sql.append("SELECT syscolumns.id, syscolumns.colid AS cid, syscolumns.name AS name, syscolumns.prec AS length, syscolumns.scale, systypes.name AS type, syscolumns.isnullable AS notnull, t.name AS table_name,s.name AS schemaName ");
sql.append("FROM syscolumns ");
sql.append("INNER JOIN systypes ON syscolumns.xusertype = systypes.xusertype ");
sql.append("INNER JOIN sys.tables t ON t.object_id = syscolumns.id ");
sql.append("INNER JOIN sys.schemas s ON s.schema_id = t.schema_id ");
sql.append("WHERE s.name = ");
sql.append(StringUtil.isNotBlank(schema) ? "'" + schema + "'" : "USER_NAME()");
sql.append("AND t.name = '");
sql.append(tableName);
sql.append("') a ");
sql.append("LEFT JOIN information_schema.key_column_usage b ON a.name = b.column_name AND a.table_name = b.table_name AND b.table_schema = a.schemaName ");
sql.append("LEFT JOIN sys.extended_properties c ON c.major_id = a.id AND c.minor_id = a.cid ");
sql.append("ORDER BY a.cid");
return sql.toString();
}
@Override
public List alterTable(List alterList) {
List sqlList = new ArrayList<>();
StringBuffer sql = new StringBuffer();
StringBuffer remarksSql = new StringBuffer();
for (int i = 0; i < alterList.size(); i++) {
Alter alter = alterList.get(i);
if (alter.getType() == AlterType.ADD) {
sql.append(SqlConstant.ALTER_TABLE);
sql.append(getFullName(alter, alter.getTable(), null));
sql.append(SqlConstant.ADD);
sql.append(SqlBeanUtil.addColumn(alter, alter.getColumnInfo(), alter.getAfterColumnName()));
remarksSql.append(addRemarks(false, alter, null));
} else if (alter.getType() == AlterType.CHANGE) {
//改名
sql.append(SqlConstant.EXEC_SP_RENAME);
sql.append(getFullName(alter, alter.getTable(), alter.getOldColumnName()));
sql.append(SqlConstant.COMMA);
sql.append(SqlConstant.SINGLE_QUOTATION_MARK);
sql.append(alter.getColumnInfo().getName());
sql.append(SqlConstant.SINGLE_QUOTATION_MARK);
sql.append(SqlConstant.COMMA);
sql.append(SqlConstant.SINGLE_QUOTATION_MARK);
sql.append(SqlConstant.COLUMN);
sql.append(SqlConstant.SINGLE_QUOTATION_MARK);
sql.append(SqlConstant.SPACES);
sql.append(SqlConstant.SEMICOLON);
//先改名后修改信息
StringBuffer modifySql = modifyColumn(alter);
if (modifySql.length() > 0) {
sql.append(SqlConstant.ALTER_TABLE);
sql.append(modifySql);
}
remarksSql.append(addRemarks(false, alter, null));
} else if (alter.getType() == AlterType.MODIFY) {
sql.append(SqlConstant.ALTER_TABLE);
sql.append(modifyColumn(alter));
remarksSql.append(addRemarks(false, alter, null));
} else if (alter.getType() == AlterType.DROP) {
sql.append(SqlConstant.ALTER_TABLE);
sql.append(getFullName(alter, alter.getTable(), null));
sql.append(SqlConstant.DROP);
sql.append(SqlConstant.COLUMN);
sql.append(SqlConstant.BEGIN_SQUARE_BRACKETS);
sql.append(alter.getColumnInfo().getName(SqlBeanUtil.isToUpperCase(alter)));
sql.append(SqlConstant.END_SQUARE_BRACKETS);
}
sql.append(SqlConstant.SPACES);
sql.append(SqlConstant.SEMICOLON);
}
sqlList.add(sql.toString());
sqlList.add(remarksSql.toString());
return sqlList;
}
/**
* 获取全名
*
* @param alter
* @param table
* @param columnName
* @return
*/
private String getFullName(Alter alter, Table table, String columnName) {
StringBuffer sql = new StringBuffer();
boolean rename = alter.getType() == AlterType.CHANGE && StringUtil.isNotBlank(columnName);
if (rename) {
sql.append(SqlConstant.SINGLE_QUOTATION_MARK);
}
if (StringUtil.isNotBlank(table.getSchema())) {
sql.append(SqlConstant.BEGIN_SQUARE_BRACKETS);
sql.append(table.getSchema());
sql.append(SqlConstant.END_SQUARE_BRACKETS);
sql.append(SqlConstant.POINT);
}
// sql.append(SqlConstant.BEGIN_SQUARE_BRACKETS);
// sql.append(SqlConstant.DBO);
// sql.append(SqlConstant.END_SQUARE_BRACKETS);
// sql.append(SqlConstant.POINT);
sql.append(SqlConstant.BEGIN_SQUARE_BRACKETS);
sql.append(table.getName(SqlBeanUtil.isToUpperCase(alter)));
sql.append(SqlConstant.END_SQUARE_BRACKETS);
if (rename) {
sql.append(SqlConstant.POINT);
sql.append(SqlConstant.BEGIN_SQUARE_BRACKETS);
sql.append(columnName);
sql.append(SqlConstant.END_SQUARE_BRACKETS);
sql.append(SqlConstant.SINGLE_QUOTATION_MARK);
}
sql.append(SqlConstant.SPACES);
return sql.toString();
}
/**
* 更改列信息
*
* @param alter
* @return
*/
private StringBuffer modifyColumn(Alter alter) {
ColumnInfo columnInfo = alter.getColumnInfo();
StringBuffer modifySql = new StringBuffer();
String fullName = getFullName(alter, alter.getTable(), null);
modifySql.append(fullName);
modifySql.append(SqlConstant.ALTER);
modifySql.append(SqlConstant.COLUMN);
JdbcType jdbcType = JdbcType.getType(columnInfo.getType());
modifySql.append(SqlBeanUtil.getTableFieldName(alter, columnInfo.getName()));
modifySql.append(SqlConstant.SPACES);
modifySql.append(jdbcType.name());
if (columnInfo.getLength() != null && columnInfo.getLength() > 0) {
modifySql.append(SqlConstant.BEGIN_BRACKET);
//字段长度
modifySql.append(columnInfo.getLength());
if (jdbcType.isFloat()) {
modifySql.append(SqlConstant.COMMA);
modifySql.append(columnInfo.getScale() == null ? 0 : columnInfo.getScale());
}
modifySql.append(SqlConstant.END_BRACKET);
}
//是否为null
if ((columnInfo.getNotnull() != null && columnInfo.getNotnull()) || columnInfo.getPk()) {
modifySql.append(SqlConstant.SPACES);
modifySql.append(SqlConstant.NOT_NULL);
} else {
if (columnInfo.getNotnull() != null && !columnInfo.getNotnull()) {
modifySql.append(SqlConstant.SPACES);
modifySql.append(SqlConstant.NULL);
}
}
//是否自增
if (columnInfo.getAutoIncr() != null && columnInfo.getAutoIncr()) {
if (alter.getSqlBeanDB().getDbType() == DbType.MySQL || alter.getSqlBeanDB().getDbType() == DbType.MariaDB) {
modifySql.append(SqlConstant.SPACES);
modifySql.append(SqlConstant.AUTO_INCREMENT);
}
}
return modifySql;
}
@Override
public String addRemarks(boolean isTable, Alter item, String escape) {
String remarks = StringUtil.isNotBlank(item.getColumnInfo().getRemarks()) ? item.getColumnInfo().getRemarks() : "''";
StringBuffer remarksSql = new StringBuffer();
String schema = SqlConstant.DBO;
if (StringUtil.isNotBlank(item.getTable().getSchema())) {
schema = item.getTable().getSchema();
}
remarksSql.append("IF ((SELECT COUNT(*) FROM ::fn_listextendedproperty(");
remarksSql.append("'MS_Description', 'SCHEMA', N'" + schema + "', 'TABLE', N'" + item.getTable().getName() + (!isTable ? "', 'COLUMN', N'" + item.getColumnInfo().getName() + "'" : "', NULL, NULL"));
remarksSql.append(")) > 0)");
remarksSql.append("\n EXEC sp_updateextendedproperty ");
remarksSql.append("'MS_Description', N'" + remarks + "', 'SCHEMA', N'" + schema + "', 'TABLE', N'" + item.getTable().getName() + "'" + (!isTable ? (", 'COLUMN', N'" + item.getColumnInfo().getName() + "'") : ""));
remarksSql.append("\nELSE");
remarksSql.append("\n EXEC sp_addextendedproperty ");
remarksSql.append("'MS_Description', N'" + remarks + "', 'SCHEMA', N'" + schema + "', 'TABLE', N'" + item.getTable().getName() + "'" + (!isTable ? (", 'COLUMN', N'" + item.getColumnInfo().getName() + "'") : ""));
remarksSql.append(SqlConstant.SEMICOLON);
return remarksSql.toString();
}
@Override
public String getSchemaSql(SqlBeanDB sqlBeanDB, String schemaName) {
StringBuffer sql = new StringBuffer();
sql.append("SELECT name FROM sys.schemas ");
if (StringUtil.isNotEmpty(schemaName)) {
sql.append("WHERE name = ");
sql.append("'" + this.getSchemaName(sqlBeanDB, schemaName) + "'");
}
return sql.toString();
}
@Override
public String getCreateSchemaSql(SqlBeanDB sqlBeanDB, String schemaName) {
StringBuffer sql = new StringBuffer();
sql.append("IF NOT EXISTS (SELECT name FROM sys.schemas WHERE name = N'");
sql.append(this.getSchemaName(sqlBeanDB, schemaName));
sql.append("') BEGIN EXEC ('CREATE SCHEMA [");
sql.append(this.getSchemaName(sqlBeanDB, schemaName));
sql.append("]'); END");
return sql.toString();
}
@Override
public String getDropSchemaSql(SqlBeanDB sqlBeanDB, String schemaName) {
StringBuffer sql = new StringBuffer();
sql.append("IF EXISTS (SELECT name FROM sys.schemas WHERE name = N'");
sql.append(this.getSchemaName(sqlBeanDB, schemaName));
sql.append("') BEGIN EXEC ('DROP SCHEMA [");
sql.append(this.getSchemaName(sqlBeanDB, schemaName));
sql.append("]'); END");
return sql.toString();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy