MySQL导出全部Index和自律的主意,列名无效

MySQL导出全部Index和自律的主意,列名无效。       在sql后查询,给现存表增加三个字段,即实行sql语句:

成都百货上千时候对数据库表修改字段后会出现“列名无效”,或许在查询分析器里面是革命的下划线,形成那些场景的从头到尾的经过是:SQL
Server的intellisense(智能感知成效),没有感知到改动,需求重新整理一下

本文汇总了MySQL导出全数Index 和平条款束的不二等秘书籍,提须要大家以利于大家查询利用。具体如下:

alter table [sxrq_1108]997755.com澳门葡京,.[dbo].[厂商周报表详细的情况] add 总计 int
default 0

艺术:用火速键Ctrl+Shift+路虎极光就能够

壹. 导出创造自增字段语句:

     
然后在上述sql查语句扩大字段‘总计’,展现总括是无用列名,更为严重的是心有余而力不足向表中insert恐怕update含有新增加列名的数量。不过改造后的sql语句依然能够施行成功。那是出于SQL
Server的intellisense的滋生的。

SELECT
CONCAT(
'ALTER TABLE `',
TABLE_NAME,
'` ',
'MODIFY COLUMN `',
COLUMN_NAME,
'` ',
IF(UPPER(DATA_TYPE) = 'INT',
REPLACE(
SUBSTRING_INDEX(
UPPER(COLUMN_TYPE),
')',
1
),
'INT',
'INTEGER'
),
UPPER(COLUMN_TYPE)
),
') UNSIGNED NOT NULL AUTO_INCREMENT;'
)
FROM information_schema.COLUMNS
WHERE TABLE_SCHEMA = 'source_database_name' AND
EXTRA = UPPER('AUTO_INCREMENT')
ORDER BY TABLE_NAME ASC

      intellisense是SQL
Server的智能记录智能感知功用,即当给sql表名加上”.”符号后会并弹出字段名,表名,数据库名。类似于编辑器的智能提示。

2. 导出全体索引:

     上述难题的解决办法是:按下快捷键ctrl+shift+r,重新整理运行SQL
Server的intellisense。

SELECT
CONCAT('ALTER TABLE `',TABLE_NAME,'` ', 'ADD ', 
 IF(NON_UNIQUE = 1,
 CASE UPPER(INDEX_TYPE)
 WHEN 'FULLTEXT' THEN 'FULLTEXT INDEX'
 WHEN 'SPATIAL' THEN 'SPATIAL INDEX'
 ELSE CONCAT('INDEX `',
  INDEX_NAME,
  '` USING ',
  INDEX_TYPE
 )
END,
IF(UPPER(INDEX_NAME) = 'PRIMARY',
 CONCAT('PRIMARY KEY USING ',
 INDEX_TYPE
 ),
CONCAT('UNIQUE INDEX `',
 INDEX_NAME,
 '` USING ',
 INDEX_TYPE
)
)
),'(', GROUP_CONCAT(DISTINCT CONCAT('`', COLUMN_NAME, '`') ORDER BY SEQ_IN_INDEX ASC SEPARATOR ', '), ');') AS 'Show_Add_Indexes'
FROM information_schema.STATISTICS
WHERE TABLE_SCHEMA = 'pbq'
GROUP BY TABLE_NAME, INDEX_NAME
ORDER BY TABLE_NAME ASC, INDEX_NAME ASC

三. 创制删除全体自增字段:

SELECT
CONCAT(
'ALTER TABLE `',
TABLE_NAME,
'` ',
'MODIFY COLUMN `',
COLUMN_NAME,
'` ',
IF(UPPER(DATA_TYPE) = 'INT',
REPLACE(
SUBSTRING_INDEX(
UPPER(COLUMN_TYPE),
')',
1
),
'INT',
'INTEGER'
),
UPPER(COLUMN_TYPE)
),
') UNSIGNED NOT NULL;'
)
FROM information_schema.COLUMNS
WHERE TABLE_SCHEMA = 'destination_database_name' AND
EXTRA = UPPER('AUTO_INCREMENT')
ORDER BY TABLE_NAME ASC

四. 删除库全数索引:

SELECT
CONCAT(
'ALTER TABLE `',
TABLE_NAME,
'` ',
GROUP_CONCAT(
DISTINCT
CONCAT(
'DROP ',
IF(UPPER(INDEX_NAME) = 'PRIMARY',
'PRIMARY KEY',
CONCAT('INDEX `', INDEX_NAME, '`')
)
)
SEPARATOR ', '
),
';'
)
FROM information_schema.STATISTICS
WHERE TABLE_SCHEMA = 'destination_database_name'
GROUP BY TABLE_NAME
ORDER BY TABLE_NAME ASC

盼望本文所述示例可以对大家有着帮忙。

您只怕感兴趣的篇章:

  • mysql创建Bitmap_Join_Indexes中的约束与索引
  • SQL
    Server约束加强的两点建议
  • Mysql中回到一个数据库的持有表名,列名数据类型备注
  • sql语句查询数据库中的表名/列名/主键/自动拉长值实例
  • sqlserver
    修改列名及表名的sql语句
  • MySQL学习笔记4:完整性约束限制字段
  • sql脚本查询数据库表,数据,结构,约束等操作的不二等秘书籍
  • MySQL
    加多、修改、删除表的列及约束等表的概念
  • 选用sql语句创设和删除约束示例代码
  • SQLSEMuranoVE宝马X5达成转移表名,退换列名,退换约束代码

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

*
*
Website