Documentation ¶
Overview ¶
Copyright © 2020 Marvin
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright © 2020 Marvin ¶
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright © 2020 Marvin ¶
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright © 2020 Marvin ¶
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright © 2020 Marvin ¶
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright © 2020 Marvin ¶
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Copyright © 2020 Marvin ¶
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Index ¶
- func ChangeTableColumnDefaultValue(ctx context.Context, oracle *oracle.Oracle, dataDefault string) (string, error)
- func ChangeTableColumnType(ctx context.Context, oracle *oracle.Oracle, ...) (string, error)
- func GenOracleTableColumnMeta(ctx context.Context, oracle *oracle.Oracle, ...) (string, error)
- func GetOracleConstraint(schemaName, tableName string, oracle *oracle.Oracle) ([]ConstraintPUKey, []ConstraintForeign, []ConstraintCheck, error)
- func GetOracleTableColumn(schemaName, tableName string, oracle *oracle.Oracle, ...) (map[string]Column, string, error)
- func OracleTableColumnMapRuleCheck(ctx context.Context, oracle *oracle.Oracle, ...) (string, table.Row, error)
- type Check
- func (c *Check) CheckCheckKey() (string, error)
- func (c *Check) CheckColumn() (string, error)
- func (c *Check) CheckColumnCharacterSetAndCollation() string
- func (c *Check) CheckColumnCounts() (string, error)
- func (c *Check) CheckForeignKey() (string, error)
- func (c *Check) CheckIndex() (string, error)
- func (c *Check) CheckPartitionTable() (string, error)
- func (c *Check) CheckPartitionTableType() string
- func (c *Check) CheckPrimaryAndUniqueKey() (string, error)
- func (c *Check) CheckTableCharacterSetAndCollation() string
- func (c *Check) CheckTableComment() string
- func (c *Check) String() string
- func (c *Check) Writer(f *check.File) error
- type Column
- type ColumnInfo
- type ConstraintCheck
- type ConstraintForeign
- type ConstraintPUKey
- type Index
- type IndexInfo
- type O2M
- type Partition
- type Table
- type Task
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func ChangeTableColumnType ¶
func ChangeTableColumnType(ctx context.Context, oracle *oracle.Oracle, sourceSchema, sourceTableName, columnName string, columnINFO Column) (string, error)
数据库查询获取自定义表结构转换规则 加载数据类型转换规则【处理字段级别、表级别、库级别数据类型映射规则】 数据类型转换规则判断,未设置自定义规则,默认采用内置默认字段类型转换
func GenOracleTableColumnMeta ¶
func GenOracleTableColumnMeta(ctx context.Context, oracle *oracle.Oracle, sourceSchema, sourceTableName, columnName string, columnINFO Column) (string, error)
Oracle 表字段映射转换 -> Check 阶段
func GetOracleConstraint ¶
func GetOracleConstraint(schemaName, tableName string, oracle *oracle.Oracle) ([]ConstraintPUKey, []ConstraintForeign, []ConstraintCheck, error)
func GetOracleTableColumn ¶
Types ¶
type Check ¶
type Check struct { Ctx context.Context OracleTableINFO *Table `json:"oracle_table_info"` MySQLTableINFO *Table `json:"mysql_table_info"` MySQLDBVersion string `json:"mysqldb_version"` MySQLDBType string `json:"mysqldb_type"` Oracle *oracle.Oracle `json:"-"` }
func NewChecker ¶
func (*Check) CheckCheckKey ¶
func (*Check) CheckColumn ¶
func (*Check) CheckColumnCharacterSetAndCollation ¶
func (*Check) CheckColumnCounts ¶
func (*Check) CheckForeignKey ¶
func (*Check) CheckIndex ¶
func (*Check) CheckPartitionTable ¶
func (*Check) CheckPartitionTableType ¶
func (*Check) CheckPrimaryAndUniqueKey ¶
func (*Check) CheckTableCharacterSetAndCollation ¶
func (*Check) CheckTableComment ¶
type Column ¶
type ColumnInfo ¶
type ConstraintCheck ¶
type ConstraintCheck struct {
ConstraintExpression string
}
type ConstraintForeign ¶
type ConstraintPUKey ¶
type Index ¶
type Table ¶
type Table struct { SchemaName string TableName string TableComment string TableCharacterSet string TableCollation string Columns map[string]Column // KEY 字段名 Indexes []Index PUConstraints []ConstraintPUKey ForeignConstraints []ConstraintForeign CheckConstraints []ConstraintCheck IsPartition bool Partitions []Partition // 获取分区键、分区类型以及子分区键、子分区类型 }
func NewMySQLTableINFO ¶
func NewOracleTableINFO ¶
type Task ¶
type Task struct { SourceSchemaName string `json:"source_schema_name"` TargetSchemaName string `json:"target_schema_name"` TableName string `json:"table_name"` TargetDBType string `json:"target_db_type"` SourceDBCharacterSet string `json:"source_db_character_set"` SourceDBNLSSort string `json:"source_dbnls_sort"` SourceDBNLSComp string `json:"source_dbnls_comp"` SourceDBCollation bool `json:"source_db_collation"` SourceTableCollation string `json:"source_table_collation"` SourceSchemaCollation string `json:"source_schema_collation"` Oracle *oracle.Oracle MySQL *mysql.MySQL }