MySQL常见的脚本语句格式有哪些


这篇文章主要介绍“MySQL常见的脚本语句格式有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL常见的脚本语句格式有哪些”文章能帮助大家解决问题。针对数据库的表进行新增操作,考虑到脚本可重复执行,有以下两种方案使用TRYADDTABLE存储过程使用原生判断语句使用以上两种方式可能存在一个问题,就是数据库中存在一个表结构不同的表,此时以上的语句其实就是无效的,很多人都会采用先删表然后再建表的方式,如下所示但是删除表是存在巨大风险的,如果只是一些缓存表倒还好,如果是存放重要业务数据或者参数信息的表,删除表会导致程序运行失败。所以是不允许直接删除表的,那么如何避免数据库存在同样表名而结构不同呢?可以考虑在建表语句后面添加一个查询语句,其中包含完整的字段。一旦表结构不一致,就需要考虑针对表字段的增删操作以及数据同步操作。删除表的操作是存在巨大风险的,删除表之前必须准备评估是否导致业务数据丢失的问题。新增表字段通过TRYADDTABCOLUMN存储过程保证可重复执行。修改表字段原生语句已经支持可重复执行,直接使用即可删除表字段删除表字段同样是存在巨大风险的,需要仔细评估。可能会涉及的场合就是将某个字段替换为另一个字段(二者名称不一致)。通过先删除字段然后再添加字段会导致原来数据丢失,MySQL中可以通过ALTER TABLE CHANGE语句来修改字段。但是没法保证可重复性。添加索引主要考虑可重复执行问题,首先通过TRYDROPINDEX删除索引。然后再创建索引删除索引考虑可重复执行问题,直接使用存储过程。新增数据绝大多数的表新增数据都只需考虑先根据主键或者关键字删除,然后插入数据即可。如下所示以上表是没有数字型的主键的,如果涉及到数据型主键的,有两种方案:第一种采用主键自增,只用在表结构定义的时候将主键字段设置为AUTO_INCREMENT即可。第二种模仿oracle中的序列,在mysql中通过表SEQUENCE维护这些序列信息。在插入数据的时候,需要通过存储过程getSequenceNextVal获取序列值(其中S_TSYS_CUSTOMER对应SEQUENCE表的SEQ_NAME字段)但是有部分的表是不允许这样操作的,比如TPARA表、SEQUENCE表。前者在规范(http://191.168.0.126/svn/xIR_Web_J2EE/2.银行资管/文档/技术文档/脚本规范/初始化TPARA数据脚本规范.html)中已经详述,后者在规范(http://191.168.0.126/svn/xIR_Web_J2EE/2.银行资管/文档/技术文档/脚本规范/MySQL序列操作规范.html)中详述。TPARA表新增数据SEQUENCE表新增数据新增表数据类似于初始化操作,如果这个数据不会变化,无论操作多少次都是一样的,先删除后插入没有任何问题。但是这个数据可能会被修改的时候,就要考虑你的脚本会不会因为重复执行导致业务没法操作了。比如序列初始化的时候是1,然后在程序里使用了一段时间,再次执行你的脚本,数据库的序列值回去了,程序肯定会报错的(对应的主键值已经存在了)。TRYADDTABLE存储过程TRYADDTABCOLUMN存储过程TRYDROP免费云主机域名INDEX存储过程TRYCHANGETABCOLUMN存储过程关于“MySQL常见的脚本语句格式有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注百云主机行业资讯频道,小编每天都会为大家更新不同的知识点。

相关推荐: css怎么设置li标签并排

这篇文章主要介绍了css怎么设置li标签并排的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇css怎么设置li标签并排文章都会有所收获,下面我们一起来看看吧。1.首先,在页面中创建一个li标签列表;2.li标签列表创建好后,在css…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 03/11 11:17
下一篇 03/11 11:20

相关推荐