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

62次阅读
没有评论

共计 5588 个字符,预计需要花费 14 分钟才能阅读完成。

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

一、库新增库

create database estore;
create database estore character set  utf8mb4

删除库

drop database estore;

修改库

alter database estore character set  utf8mb4

查询库

show databases; 查看所有数据库名
show create database estore; 查看库编码 

使用库

use estore; 切换数据库
select database();--  查询当前使用的数据库名称 

二、表结构 2.1 表

新增表

CREATE TABLE `t_user ` ( `id` varchar(22) NOT NULL,
 `openid` varchar(50) NOT NULL COMMENT  微信 opedid ,
 `name` varchar(50) DEFAULT NULL COMMENT  用户名称 ,
 `phone` varchar(20) NOT NULL COMMENT  手机号码 ,
 `province_code` varchar(10) DEFAULT NULL COMMENT  省份代码 ,
 `city_code` varchar(10) DEFAULT NULL COMMENT  城市代码 ,
 `county_code` varchar(10) DEFAULT NULL COMMENT  区县代码 ,
 `card_type` varchar(5) DEFAULT NULL COMMENT  证件类型 ,
 `id_card` varchar(30) DEFAULT NULL COMMENT  身份证 ,
 `region` varchar(10) DEFAULT NULL COMMENT  地区 ,
 `user_id` varchar(22) DEFAULT  0  COMMENT  普通用户表 id ,
 `is_homeowner` varchar(2) DEFAULT NULL COMMENT  是否有房 ,
 `insurance_code` varchar(10) DEFAULT NULL COMMENT  所属保险公司 code ,
 `promo_code` varchar(50) DEFAULT NULL COMMENT  推广码 ,
 `create_time` datetime DEFAULT NULL,
 `create_user` varchar(22) DEFAULT NULL,
 `update_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
 `update_user` varchar(22) DEFAULT NULL,
 `delete_flag` varchar(2) DEFAULT NULL COMMENT  删除标识  1 是  0  否 ,
 PRIMARY KEY (`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 from information_schema.columns where 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 change address address_level varchar(2) DEFAULT NULL COMMENT  地区级别  ; 
--  修改属性
alter table t_user modify name varchar(50) not null;

三、数据记录新增数据

--  插入三种方式
-- 1. 仅对特定字段进行赋值插入
INSERT INTO t_user ( id, code ) VALUES ( 888892,  eee  );
-- 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 (245,  379999 ,  371755 ,  哈利路亚 , 0,  2021-01-14 18:03:42 , NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  5 
-- 3. 对所有字段进行赋值插入(可不指定字段)INSERT INTO `custom_sd`.`t_user ` VALUES (888893,  379999 ,  371755 ,  哈利路亚 , 0,  2021-01-14 18:03:42 , NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,  5

删除数据

--  根据条件删除
delete from t_user where id = 888893;
--  多表联合删除 (无关联记录匹配时,不进行删除,开发中需注意区分)
delete p,pp from t_a p, t_b pp where p.id = pp.PLAN_ID and pp.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 and pp.PRODUCT_ID = #{vo.id}

修改数据

--  修改单个或多个字段
update t_user set code =  xxx , pid = 456 where id = 888892;
--  修改某个值的部分字符
update t_role set PERMISSION = REPLACE(PERMISSION, \ 角色设置 \ , \ 角色设置 \ , \ 信息员列表 \) where name =  xxx

查询数据 (博大精深,暂不讨论)

--  查询列名
SELECT
 GROUP_CONCAT( COLUMN_NAME SEPARATOR  ,  ) 
 information_schema.COLUMNS 
WHERE
 TABLE_NAME =  t_order_ext2  and TABLE_SCHEMA =  biz_channel 
 
--  查询列名,并显示驼峰别名  (仅支持单个下划线)
SELECT
 GROUP_CONCAT( CONCAT(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  ,  ) 
 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
 from t_sd_info m
 left join t_su_info u on m.id= u.im_id
 where m.u_id = #{uId}

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

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-13发表,共计5588字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)