返回顶部
首页 > 资讯 > 数据库 >MySQL常见的脚本语句格式有哪些
  • 831
分享到

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

2023-07-02 00:07:14 831人浏览 泡泡鱼
摘要

这篇文章主要介绍“MySQL常见的脚本语句格式有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Mysql常见的脚本语句格式有哪些”文章能帮助大家解决问题。表整体(TABLE )操作针对数据库的表

这篇文章主要介绍“MySQL常见的脚本语句格式有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Mysql常见的脚本语句格式有哪些”文章能帮助大家解决问题。

表整体(TABLE )操作

针对数据库的表进行新增操作,考虑到脚本可重复执行,有以下两种方案

  • 使用TRYADDTABLE存储过程

CALL TRYADDTABLE('ACT_GE_PROPERTY', 'CREATE TABLE ACT_GE_PROPERTY  (  NAME_ varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,  VALUE_ varchar(600) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,  REV_ decimal(22, 0) NULL DEFAULT NULL,  PRIMARY KEY (NAME_) USING BTREE,  INDEX SYS_C001769640(NAME_) USING BTREE) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;')
  • 使用原生判断语句

CREATE TABLE IF NOT EXISTS ACT_GE_PROPERTY  (  NAME_ varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,  VALUE_ varchar(600) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,  REV_ decimal(22, 0) NULL DEFAULT NULL,  PRIMARY KEY (NAME_) USING BTREE,  INDEX SYS_C001769640(NAME_) USING BTREE) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

使用以上两种方式可能存在一个问题,就是数据库中存在一个表结构不同的表,此时以上的语句其实就是无效的,很多人都会采用先删表然后再建表的方式,如下所示

DROP TABLE IF EXISTS ACT_GE_PROPERTY;CREATE TABLE ACT_GE_PROPERTY  (  NAME_ varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,  VALUE_ varchar(600) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,  REV_ decimal(22, 0) NULL DEFAULT NULL,  PRIMARY KEY (NAME_) USING BTREE,  INDEX SYS_C001769640(NAME_) USING BTREE) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

但是删除表是存在巨大风险的,如果只是一些缓存表倒还好,如果是存放重要业务数据或者参数信息的表,删除表会导致程序运行失败。所以是不允许直接删除表的,那么如何避免数据库存在同样表名而结构不同呢?可以考虑在建表语句后面添加一个查询语句,其中包含完整的字段。

SELECT NAME_,VALUE_,REV_ FROM ACT_GE_PROPERTY LIMIT 0,1;

一旦表结构不一致,就需要考虑针对表字段的增删操作以及数据同步操作。

删除表的操作是存在巨大风险的,删除表之前必须准备评估是否导致业务数据丢失的问题。

表字段(COLUMN )操作

  • 新增表字段

通过TRYADDTABCOLUMN存储过程保证可重复执行。

CALL TRYADDTABCOLUMN('ACT_GE_PROPERTY','VALUE_ ','varchar(600) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL');
  • 修改表字段

原生语句已经支持可重复执行,直接使用即可

ALTER TABLE ACT_GE_PROPERTY MODIFY COLUMN VALUE_ varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL;
  • 删除表字段

删除表字段同样是存在巨大风险的,需要仔细评估。可能会涉及的场合就是将某个字段替换为另一个字段(二者名称不一致)。通过先删除字段然后再添加字段会导致原来数据丢失,mysql中可以通过ALTER TABLE CHANGE语句来修改字段。但是没法保证可重复性。

-- 将ACT_GE_PROPERTY字段VALUE_的名字修改为VALUE2_-- 对应的Mysql原语句 ALTER TABLE ACT_GE_PROPERTY CHANGE VALUE_ VALUE2_ varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL;CALL TRYCHANGETABCOLUMN('ACT_GE_PROPERTY','VALUE_','VALUE2_','varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL');-- 将ACT_GE_PROPERTY字段VALUE2_的名字修改为VALUE_CALL TRYCHANGETABCOLUMN('ACT_GE_PROPERTY','VALUE2_','VALUE_','varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL');

索引(INDEX )操作

  • 添加索引

主要考虑可重复执行问题,首先通过TRYDROPINDEX删除索引。然后再创建索引

-- 创建普通索引CALL TRYDROPINDEX('ACT_GE_PROPERTY','IDX_REV_');CREATE INDEX IDX_REV_ ON ACT_GE_PROPERTY (REV_ ASC)  USING BTREE;-- 创建唯一索引CALL TRYDROPINDEX('ACT_GE_PROPERTY','IDX_VALUE_');CREATE UNIQUE INDEX IDX_VALUE_ ON ACT_GE_PROPERTY (VALUE_ ASC)  USING BTREE;-- 多个字段的索引CALL TRYDROPINDEX('ACT_GE_PROPERTY','IDX_VALUE_REV_');CREATE UNIQUE INDEX IDX_VALUE_REV_ ON ACT_GE_PROPERTY (VALUE_ ASC,REV_ ASC)  USING BTREE;
  • 删除索引

考虑可重复执行问题,直接使用存储过程。

CALL TRYDROPINDEX('ACT_GE_PROPERTY','IDX_REV_');CALL TRYDROPINDEX('ACT_GE_PROPERTY','IDX_VALUE_');CALL TRYDROPINDEX('ACT_GE_PROPERTY','IDX_VALUE_REV_');

表数据操作

  • 新增数据

绝大多数的表新增数据都只需考虑先根据主键或者关键字删除,然后插入数据即可。如下所示

DELETE FROM act_ge_property WHERE NAME_ IN('next.dbid','schema.history','schema.version');INSERT INTO act_ge_property(NAME_, VALUE_, REV_) VALUES ('next.dbid', '1215401', 12155);INSERT INTO act_ge_property(NAME_, VALUE_, REV_) VALUES ('schema.history', 'create(5.15.1)', 1);INSERT INTO act_ge_property(NAME_, VALUE_, REV_) VALUES ('schema.version', '5.15.1', 1);COMMIT;

以上表是没有数字型的主键的,如果涉及到数据型主键的,有两种方案:

第一种采用主键自增,只用在表结构定义的时候将主键字段设置为AUTO_INCREMENT即可。

第二种模仿oracle中的序列,在mysql中通过表SEQUENCE维护这些序列信息。在插入数据的时候,需要通过存储过程getSequenceNextVal获取序列值(其中S_TSYS_CUSTOMER对应SEQUENCE表的SEQ_NAME字段)

DELETE FROM TSYS_CUSTOMER WHERE S_CODE = 'PY2022';INSERT INTO `TSYS_CUSTOMER`(`S_ID`, `S_CODE`, `C_CODE`, `C_NAME`) VALUES (getSequenceNextVal('S_TSYS_CUSTOMER'),  'PY2022', 'PUFA_BANK', '浦银自营');COMMIT;

但是有部分的表是不允许这样操作的,比如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表新增数据

CALL TRYEXCUTEIFNOTEXISTS('TPARA','P_CODE','IsUsedInstVerifyApproval',' INSERT INTO TPARA(P_ID, P_NAME, P_CODE, P_VALUE, P_VALUE_NAME, P_TYPE, P_ISVISIBLE, P_ENUM_VALUE, P_ENUM_TYPE, P_ISMULTI, P_CREAT_DATE, P_REMARK) VALUES (''31020'', ''是否使用指令验证审批流程'', ''IsUsedInstVerifyApproval'', ''false'', ''否'', ''3'', ''1'', ''true_是@false_否'', ''1'', ''0'', ''20171124'', NULL)');

SEQUENCE表新增数据

CALL TRYADDSEQUENCE('S_TTRD_AUTH_PORTAL_CONFIG', 'INSERT INTO SEQUENCE(SEQ_NAME, CURRENT_VAL, INCREMENT_VAL, MIN_VAL, MAX_VAL, CACHE_SIZE) VALUES (''S_TTRD_AUTH_PORTAL_CONFIG'', 1, 1, 0, 9223372036854775807, 20)');

新增表数据类似于初始化操作,如果这个数据不会变化,无论操作多少次都是一样的,先删除后插入没有任何问题。但是这个数据可能会被修改的时候,就要考虑你的脚本会不会因为重复执行导致业务没法操作了。比如序列初始化的时候是1,然后在程序里使用了一段时间,再次执行你的脚本,数据库的序列值回去了,程序肯定会报错的(对应的主键值已经存在了)。

FUNCTION 函数操作

DROP FUNCTION IF EXISTS GZB_GET_PRECISION_VALUE;-- 在创建函数语句前修改默认分割符DELIMITER $CREATE FUNCTION GZB_GET_PRECISION_VALUE(VAL VARCHAR(100),V_CASH_ACCT_ID VARCHAR(10)) RETURNS VARCHAR(100) BEGIN  DECLARE  RET_VAL VARCHAR(100);  DECLARE V_INDEX_PRECISION INTEGER ;  DECLARE V_CALC_TYPE VARCHAR(1);  IF VAL IS NULL OR V_CASH_ACCT_ID IS NULL THEN  SET RET_VAL=COALESCE(VAL, '0');    RETURN RET_VAL;  ELSE  SELECT MAX(PRC.INDEX_PRECISION), MAX(PRC.CALC_TYPE)    INTO V_INDEX_PRECISION, V_CALC_TYPE    FROM V_GZB_INDEX_PRECISION PRC    INNER JOIN TTRD_WMPS_DEFINE WPS      ON PRC.I_CODE = WPS.I_CODE     AND PRC.A_TYPE = WPS.A_TYPE     AND PRC.M_TYPE = WPS.M_TYPE    INNER JOIN TTRD_ACC_CASH ACC_CASH    ON WPS.UNIT_ID = ACC_CASH.PC1   WHERE WPS.ZMCP_FLAG = '0'     AND INSTR(WPS.I_CODE, 'TEMP') = 0     AND PRC.F_CODE = 'NAV_OTHER'     AND ACC_CASH.ACCID = V_CASH_ACCT_ID;  END IF;   IF COALESCE(V_CALC_TYPE, '1') = '1' THEN      SET RET_VAL = LEFT(VAL, INSTR(VAL,'.')+COALESCE(V_INDEX_PRECISION, 8));   ELSE    SET RET_VAL = ROUND(VAL, COALESCE(V_INDEX_PRECISION, 8));   END IF;    RETURN RET_VAL;-- 结束时使用指定的分隔符    END $--  最后修改分割符为默认值DELIMITER ;

PROCEDURE 存储过程操作

DROP PROCEDURE IF EXISTS TRYADDTABCOLUMN;DELIMITER $CREATE PROCEDURE `TRYADDTABCOLUMN`(IN tableName VARCHAR(100),IN colName VARCHAR(50),IN colType VARCHAR(1000))BEGIN    DECLARE colCount INT;    SELECT COUNT(*) INTO colCount FROM information_schema.COLUMNS WHERE TABLE_NAME = tableName AND COLUMN_NAME = colName;    IF(colCount = 0) THEN  -- @表示全局变量 相当于PHP $ 拼接赋值 INTO 必须要用全局变量不然语句会报错  SET @add_sql = CONCAT('ALTER TABLE ',tableName,' ADD COLUMN ',colName,' ',colType,';');  -- 预处理需要执行的动态SQL,其中stmt是一个变量  PREPARE stmt FROM @add_sql;  -- 执行SQL语句  EXECUTE stmt;  -- 释放掉预处理段  deallocate prepare stmt;END IF;END $DELIMITER ;

附录

  • TRYADDTABLE存储过程

DROP PROCEDURE    IF    EXISTS TRYADDTABLE;DELIMITER $CREATE PROCEDURE `TRYADDTABLE`(IN tableName VARCHAR(50),IN createTableSql VARCHAR(3000))BEGIN    DECLARE tableCount INT;    SELECT COUNT(*) INTO tableCount FROM information_schema.TABLES WHERE TABLE_NAME = tableName;    IF(tableCount = 0) THEN  -- @表示全局变量 相当于php $ 拼接赋值 INTO 必须要用全局变量不然语句会报错    SET @create_sql = createTableSql;    -- 预处理需要执行的动态SQL,其中stmt是一个变量    PREPARE stmt FROM @create_sql;    -- 执行SQL语句    EXECUTE stmt;    -- 释放掉预处理段    deallocate prepare stmt;END IF;END $DELIMITER ;
  • TRYADDTABCOLUMN存储过程

DROP PROCEDURE    IF    EXISTS TRYADDTABCOLUMN;DELIMITER $CREATE PROCEDURE `TRYADDTABCOLUMN`(IN tableName VARCHAR(100),IN colName VARCHAR(50),IN colType VARCHAR(1000))BEGIN    DECLARE colCount INT;    SELECT COUNT(*) INTO colCount FROM information_schema.COLUMNS WHERE TABLE_NAME = tableName AND COLUMN_NAME = colName;    IF(colCount = 0) THEN  -- @表示全局变量 相当于php $ 拼接赋值 INTO 必须要用全局变量不然语句会报错  SET @add_sql = CONCAT('ALTER TABLE ',tableName,' ADD COLUMN ',colName,' ',colType,';');  -- 预处理需要执行的动态SQL,其中stmt是一个变量  PREPARE stmt FROM @add_sql;  -- 执行SQL语句  EXECUTE stmt;  -- 释放掉预处理段  deallocate prepare stmt;END IF;END $DELIMITER ;
  • TRYDROPINDEX存储过程

DROP PROCEDURE    IF    EXISTS TRYDROPINDEX;DELIMITER $CREATE PROCEDURE `TRYDROPINDEX`(IN tableName VARCHAR ( 2000 ), IN indexName VARCHAR ( 2000 ))BEGIN    DECLARE row1 INT;    SELECT    COUNT( * ) INTO row1    FROM    INFORMATION_SCHEMA.STATISTICS    WHERE    TABLE_SCHEMA = (SELECT DATABASE())    AND TABLE_NAME = tableName    AND INDEX_NAME = indexName;    IF    ( row1 > 0 ) THEN    SET @exeuteSQL = CONCAT( 'ALTER table ', tableName, ' DROP INDEX ', indexName );    PREPARE stmt FROM @exeuteSQL;    EXECUTE stmt;    DEALLOCATE PREPARE stmt;END IF;END $DELIMITER ;
  • TRYCHANGETABCOLUMN存储过程

DROP PROCEDURE IF EXISTS TRYCHANGETABCOLUMN;delimiter //CREATE PROCEDURE TRYCHANGETABCOLUMN (IN tableName VARCHAR(50),IN origiColName VARCHAR(50),IN targetColName VARCHAR(50),IN targetColType VARCHAR(100))BEGINDECLARE colCount INT;  SELECT COUNT(*) INTO colCount FROM information_schema.COLUMNS WHERE TABLE_NAME = tableName AND COLUMN_NAME = targetColName;IF(colCount > 0) THENSET @excute_sql = CONCAT('ALTER TABLE ',tableName,' MODIFY COLUMN ',targetColName,' ',targetColType,';');ELSESET @excute_sql = CONCAT('ALTER TABLE ',tableName,' CHANGE ',origiColName,' ',targetColName,' ',targetColType,';');END IF;-- 预处理需要执行的动态SQL,其中stmt是一个变量PREPARE stmt FROM @excute_sql;-- 执行SQL语句EXECUTE stmt;-- 释放掉预处理段deallocate prepare stmt;END //delimiter ;

关于“MySQL常见的脚本语句格式有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网数据库频道,小编每天都会为大家更新不同的知识点。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL常见的脚本语句格式有哪些

本文链接: https://lsjlt.com/news/338681.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL常见的脚本语句格式有哪些
    这篇文章主要介绍“MySQL常见的脚本语句格式有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL常见的脚本语句格式有哪些”文章能帮助大家解决问题。表整体(TABLE )操作针对数据库的表...
    99+
    2023-07-02
  • MySQL常见的脚本语句格式参考指南
    目录表整体(TABLE )操作表字段(COLUMN )操作表索引(INDEX )操作表数据操作FUNCTION 函数操作PROCEDURE 存储过程操作附录总结表整体(TABLE )操作针对数据库的表进行新增操作,考虑到脚本可重复执行,有以...
    99+
    2022-06-09
    mysql 脚本 语句
  • mysql有哪些常用的基本语句
    下文我给大家简单讲讲关于mysql有哪些常用的基本语句,大家之前了解过相关类似主题内容吗?感兴趣的话就一起来看看这篇文章吧,相信看完mysql有哪些常用的基本语句对大家多少有点帮助吧。create user...
    99+
    2024-04-02
  • sql中常见语句有哪些
    小编给大家分享一下sql中常见语句有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!结构化查询语言(Structured Qu...
    99+
    2024-04-02
  • MYSQL常用的基本SQL语句有哪些
    这篇文章主要讲解了“MYSQL常用的基本SQL语句有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MYSQL常用的基本SQL语句有哪些”吧!mysql服...
    99+
    2024-04-02
  • 常见的SQL语句具体有哪些
    这期内容当中小编将会给大家带来有关常见的SQL语句具体有哪些,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。(1)更新数据记录:sql="update数...
    99+
    2024-04-02
  • mysql常用的语句有哪些
    本篇内容介绍了“mysql常用的语句有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!mysqld 常规...
    99+
    2024-04-02
  • 常见的Shell脚本面试题有哪些
    这篇文章主要介绍常见的Shell脚本面试题有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Shell脚本是什么、它是必需的吗答:一个Shell脚本是一个文本文件,包含一个或多个命令。作为系统管理员,我们经常需要使...
    99+
    2023-06-04
  • MySQL中数据库优化的常见sql语句有哪些
    这篇文章主要介绍“MySQL中数据库优化的常见sql语句有哪些”,在日常操作中,相信很多人在MySQL中数据库优化的常见sql语句有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
    99+
    2024-04-02
  • 常见的压缩文件格式有哪些
    常见的压缩文件格式包括:1. ZIP格式(.zip):最常见的压缩格式之一,可在多个操作系统和软件中使用。2. RAR格式(.rar...
    99+
    2023-06-11
    压缩文件格式
  • python使用语句的常见陷阱有哪些
    这篇文章主要为大家展示了“python使用语句的常见陷阱有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“python使用语句的常见陷阱有哪些”这篇文章吧。1、冗余input语句的冗余使用,这...
    99+
    2023-06-20
  • MySQL有哪些常用的基础语句
    下文主要给大家带来MySQL有哪些常用的基础语句,希望这些内容能够带给大家实际用处,这也是我编辑MySQL有哪些常用的基础语句这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。一、查看数据库。对于查看...
    99+
    2024-04-02
  • MySQL中有哪些常用的SQL语句
    MySQL中有哪些常用的SQL语句,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1、复杂SQL查询1.1、单表查询(1)选择指定的列[例]查询...
    99+
    2024-04-02
  • 常用的mysql命令语句有哪些
    1. 创建数据库:CREATE DATABASE database_name;2. 删除数据库:DROP DATABASE ...
    99+
    2023-06-10
    mysql命令 mysql
  • 常用的mysql分页语句有哪些
    常用的MySQL分页语句有以下几种: 使用LIMIT关键字进行分页: SELECT * FROM table_name ...
    99+
    2023-10-22
    mysql
  • MySQL主要有哪些常用语句
    下面讲讲关于MySQL主要有哪些常用语句,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完MySQL主要有哪些常用语句这篇文章你一定会有所受益。    &nbs...
    99+
    2024-04-02
  • Linux-MySQL-有哪些常用sql语句
    不知道大家之前对类似Linux-MySQL-有哪些常用sql语句的文章有无了解,今天我在这里给大家再简单的讲讲。感兴趣的话就一起来看看正文部分吧,相信看完Linux-MySQL-有哪些常用sql语句你一定会...
    99+
    2024-04-02
  • MYSQL常用sql语句有哪些呢
    这篇文章给大家介绍MYSQL常用sql语句有哪些呢,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 SQL分类: DDL—数据定义语言(CREAT...
    99+
    2024-04-02
  • MySQL常用拼接语句有哪些
    这篇文章给大家分享的是有关MySQL常用拼接语句有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1.拼接查询所有用户SELECT DISTINCT &nbs...
    99+
    2024-04-02
  • Linux Shell常见的命令行格式有哪些
    这篇文章主要介绍“Linux Shell常见的命令行格式有哪些”,在日常操作中,相信很多人在Linux Shell常见的命令行格式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Linux Shell常见...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作