mysql之数据库常用脚本有哪些

网友投稿 708 2023-10-31

mysql之数据库常用脚本有哪些

这篇文章主要介绍了mysql之数据库常用脚本有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql之数据库常用脚本有哪些文章都会有所收获,下面我们一起来看看吧。

mysql之数据库常用脚本有哪些

一、库

新增库create database estore; create database estore character set utf8mb4;删除库drop databaseestore;修改库alter database estore character set utf8mb4;查询库show databases;查看所有数据库名 show create databaseestore;查看库编码使用库use estore;切换数据库 select database();-- 查询当前使用的数据库名称

二、表结构

2.1表

新增表

CREATE TABLE `t_user ` (   `id` varchar(22NOT NULL,   `openid` varchar(50NOT NULL COMMENT 微信opedid,   `name` varchar(50DEFAULT NULL COMMENT 用户名称,   `phone` varchar(20NOT NULL COMMENT 手机号码,   `province_code` varchar(10DEFAULT NULL COMMENT 省份代码,   `city_code` varchar(10DEFAULT NULL COMMENT 城市代码,   `county_code` varchar(10DEFAULT NULL COMMENT 区县代码,   `card_type` varchar(5DEFAULT NULL COMMENT 证件类型,   `id_card` varchar(30DEFAULT NULL COMMENT 身份证,   `region` varchar(10DEFAULT NULL COMMENT 地区,   `user_id` varchar(22DEFAULT 0 COMMENT 普通用户表id,   `is_homeowner` varchar(2DEFAULT NULL COMMENT 是否有房,   `insurance_code` varchar(10DEFAULT NULL COMMENT 所属保险公司code,   `promo_code` varchar(50DEFAULT NULL COMMENT 推广码,   `create_time`datetimeDEFAULT NULL,   `create_user` varchar(22DEFAULT NULL,   `update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,   `update_user` varchar(22DEFAULT NULL,   `delete_flag` varchar(2DEFAULT NULL COMMENT 删除标识 1是 0 否,   PRIMARYKEY (`id`USING BTREE,   UNIQUE KEY `uniq_phone` (`phone`USING BTREE COMMENT 微信用户手机号,唯一索引,   KEY `index_open_id` (`openid`USING BTREE COMMENT opid普通索引,用于静默登录等COMMENT 信息员表;

删除表

DROP TABLE t_user ;

改表名、改编码集、改存储引擎

-- 改表名 rename table t_user to t_user_info; -- 改编码集 alter table t_user character set utf8mb4; -- 改存储引擎 alter table applicationdesk ENGINE = InnoDB;

查表

-- 查选中数据库的所有表名 show tables; -- 查表结构(表中所有字段) desc t_user; show columns from t_user;-- 展示表的列详情 -- 查建表信息 show create table t_user; show create table t_mdm_employee \G; -- 查询所有表及其注释 SELECT TABLE_NAME,TABLE_COMMENT FROM information_schema.TABLES WHERE table_schema=estore ORDER BY table_name; -- 查询库中所有字段及其相关属性,如注释等 select table_name,column_name,column_type,column_comment frominformation_schema.columnswhere table_schema=custom_sd;

改索引

-- 删除索引 DROP INDEX uniq_phone ON t_sd_messenger_info;2.2字段

新增字段 - - add

-- 新增字段(默认在最后一列追加) ALTER TABLE t_user ADD name varchar(22)  DEFAULT NULL COMMENT 用户名称 ; -- 在age字段后面添加sex字段: alter table t_user  add sex tinyint not null COMMENT 用户性别 after age ; -- 在第一列添加sex字段 alter table t_user  add sex tinyint not null first;  

删除字段 - - drop

alter table t_user  drop name;

修改字段 - - change 、modify

-- 修改字段名  alter table t_user changeaddress address_levelvarchar(2)  DEFAULT NULL COMMENT 地区级别 ;  -- 修改属性 alter table t_user modify name varchar(50not null;

三、数据记录

新增数据-- 插入三种方式 -- 1.仅对特定字段进行赋值插入 INSERT INTO t_user ( id, code ) VALUES ( 888892eee ); -- 2.对所有字段进行赋值插入 INSERT INTO `custom_sd`.`t_user `(`id``code``pid``name``delete_flag``create_time``create_user``update_time``update_user``standby_01``standby_02``standby_03``standby_04``standby_05``district_level1`VALUES (245379999371755哈利路亚02021-01-14 18:03:42NULLNULLNULLNULLNULLNULLNULLNULL5); -- 3.对所有字段进行赋值插入(可不指定字段) INSERT INTO `custom_sd`.`t_user ` VALUES (888893379999371755哈利路亚02021-01-14 18:03:42NULLNULLNULLNULLNULLNULLNULLNULL5);删除数据-- 根据条件删除 delete from t_user where id = 888893; -- 多表联合删除(无关联记录匹配时,不进行删除,开发中需注意区分) delete p,pp from t_a p, t_b pp where p.id = pp.PLAN_ID andpp.PRODUCT_ID =#{vo.id} delete p,pp,e from t_a p, t_b pp,t_c e where p.id = pp.PLAN_ID and e.PLAN_ID = p.ID andpp.PRODUCT_ID =#{vo.id}修改数据-- 修改单个或多个字段 update t_user set code = xxx, pid = 456 where id = 888892; -- 修改某个值的部分字符 updatet_roleset PERMISSION = REPLACE(PERMISSION,\"角色设置\",\"角色设置\", \"信息员列表\"where name = xxx;查询数据(博大精深,暂不讨论)-- 查询列名 SELECT     GROUP_CONCAT( COLUMN_NAME SEPARATOR "," )  FROM     information_schema.COLUMNS  WHERE     TABLE_NAME = t_order_ext2 and TABLE_SCHEMA = biz_channel;      -- 查询列名,并显示驼峰别名 (仅支持单个下划线) SELECT     GROUP_CONCATCONCAT(COLUMN_NAME," ",if(LOCATE(_"abc_bcd")>0,COLUMN_NAME,CONCAT(left(COLUMN_NAME,LOCATE(_, COLUMN_NAME)-1),UPPER(substring(COLUMN_NAME,LOCATE(_, COLUMN_NAME) + 1,1)),right(COLUMN_NAME,LENGTH(COLUMN_NAME) - LOCATE(_, COLUMN_NAME) -1)))) SEPARATOR "," )  FROM     information_schema.COLUMNS  WHERE     TABLE_NAME = t_order_ext2;      -- 查询列名,并显示驼峰别名 (可支持两个下划线) -- 注意:有重复数据,需取后面,可使用关键字去重,但去重后默认进行了排序 SELECT GROUP_CONCAT(CONCAT(COLUMN_NAME," ",IF(LOCATE(_,COLUMN_NAME)=0,COLUMN_NAME,CONCAT(LEFT (COLUMN_NAME,LOCATE(_,COLUMN_NAME)-1),UPPER(substring(COLUMN_NAME,LOCATE(_,COLUMN_NAME)+1,1)),IF (LOCATE(_,RIGHT (COLUMN_NAME,LENGTH(COLUMN_NAME)-LOCATE(_,COLUMN_NAME)-1))=0,RIGHT (COLUMN_NAME,LENGTH(COLUMN_NAME)-LOCATE(_,COLUMN_NAME)-1),CONCAT(LEFT (RIGHT(COLUMN_NAME,LENGTH(COLUMN_NAME)-LOCATE(_,COLUMN_NAME)-1),LOCATE(_,RIGHT (COLUMN_NAME,LENGTH(COLUMN_NAME)-LOCATE(_,COLUMN_NAME)-1))-1),UPPER(substring(RIGHT (COLUMN_NAME,LENGTH(COLUMN_NAME)-LOCATE(_,COLUMN_NAME)-1),LOCATE(_,RIGHT (COLUMN_NAME,LENGTH(COLUMN_NAME)-LOCATE(_,COLUMN_NAME)-1))+1,1)),RIGHT (RIGHT (COLUMN_NAME,LENGTH(COLUMN_NAME)-LOCATE(_,COLUMN_NAME)-1),LENGTH(RIGHT (COLUMN_NAME,LENGTH(COLUMN_NAME)-LOCATE(_,COLUMN_NAME)-1))-LOCATE(_,RIGHT (COLUMN_NAME,LENGTH(COLUMN_NAME)-LOCATE(_,COLUMN_NAME)-1))-1)))))) SEPARATOR ","FROM information_schema.COLUMNS WHERE TABLE_NAME=imgrecord;              -- 统计查询 if使用方法 mybatis   select     <include refid="BaseSql"/>     ,     sum(if(u.is_entering = 0,1,0)) AS count,     sum(if(u.is_entering =1,1,0)) AS total,     sum(if(u.is_entering = 1 and is_supplementary_data = 1,1,0))  AS countTotal     fromt_sd_info mleft join t_su_info u on m.id= u.im_id     where m.u_id = #{uId}

关于“mysql之数据库常用脚本有哪些”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“mysql之数据库常用脚本有哪些”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注行业资讯频道。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:mysql socket指的是什么
下一篇:mysql有没有varchar2
相关文章