个人使用mysql_mysql使用 - hexiaoming123的个人空间 - OSCHINA - 中文开源技术交流社区...

select * from user where name like '%%%' ;

b4b93919b786676d20b3c20a1b170837.png

select * from user where name like '%1%%' escape 1;

5652dd1739fb52470f75d3cb9d116e86.png

select *,RIGHT(name,LENGTH(name) - POSITION('@' in name)) from user;

f29ac12b029819ccae2a7ad974026e28.png

#对name列中b不为 null的计数 select COUNT(name = 'b' or null) as b , COUNT(name = 'c' or null) as c ,(select COUNT(id) from user where name is null) as nan from user ;

134b06fcf792ebcea555a5469c72ef3f.png

mysql存储过程

-- 存储过程创建

DELIMITER //

CREATE PROCEDURE SimpleCompare(n INT, m INT,k INT,h INT)

begin

START TRANSACTION; -- 开始事务

insert ignore into t values(n,'第一条',m);

if ()>0 then

set k =0;

COMMIT;

insert into t values(n+1,'第二条',m+1);

else

set k =-1;

ROLLBACK;

end if;

select * from t ;

end

//

DELIMITER ;

-- 存储过程调用

call SimpleCompare(133,66,@a,@b);

mysql中使用if case when

select if('322'='322',34,65)

select CASE address WHEN 1 THEN '男' ELSE '女' END as ssva from t where address != ''

DELIMITER //

CREATE PROCEDURE proc_getuserbyid(IN uId int)

BEGIN

SELECT * FROM user WHERE id=uId;

END

//

DELIMITER ;

call proc_getuserbyid(21)

mysql外键级联

MySQL中利用外键实现级联删除、更新

MySQL支持外键的存储引擎只有InnoDB,在创建外键的时候,要求父表必须有对应的索引,子表在创建外键的时候也会自动创建对应的索引。在创建索引的时候,可以指定在删除、更新父表时,对子表进行的相应操作,包括RESTRICT、NO ACTION、SET NULL和CASCADE。其中RESTRICT和NO ACTION相同,是指在子表有关联记录的情况下父表不能更新;CASCADE表示父表在更新或者删除时,更新或者删除子表对应记录;SET NULL则是表示父表在更新或者删除的时候,子表的对应字段被SET NULL。因为只有InnoDB引擎才允许使用外键,所以,我们的数据表必须使用InnoDB引擎。

我所使用的版本是Mysql5.7版本的,过程如下:

CREATE TABLE `user` (

`id` int(4) NOT NULL,

`sex` enum('f','m') DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

CREATE TABLE `userinfo` (

`sn` int(4) NOT NULL AUTO_INCREMENT,

`userid` int(4) NOT NULL,

`info` varchar(20) DEFAULT NULL,

PRIMARY KEY (`sn`),

KEY `userid` (`userid`),

CONSTRAINT `userinfo_ibfk_1` FOREIGN KEY (`userid`) REFERENCES `user` (`id`)

ON DELETE CASCADE ON UPDATE CASCADE

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

#添加数据

INSERT INTO `test`.`user`(`id`, `name`, `age`) VALUES (22, 'c', 0);

INSERT INTO `test`.`userinfo`(`sn`, `userid`, `info`) VALUES (1, 22, '2');

#验证数据

DELETE FROM `test`.`userinfo` WHERE `sn` = 1 #这行不会删除user表数据;

DELETE FROM `test`.`user` WHERE `id` = 22#这行不会删除userinfo表对应userid为22的数据

#userinfo删除约束

ALTER TABLE `test`.`userinfo` DROP FOREIGN KEY `userinfo_ibfk_1`

触发器

e48d32e2e1cf28a73f00f163352114c2.png

删除后会放到旧的表中。OLD.id

27d5e4f890214d8d757860996083e26b.png

新插入的id会放到NEW表中

f1fc713e48f709710ef4bb12c7fd3a73.png

用户账号管理

创建用户 CREATE USER [IF NOT EXISTS]

user [auth_option] [, user [auth_option]] ...

[REQUIRE {NONE | tls_option [[AND] tls_option] ...}]

[WITH resource_option [resource_option] ...]

[password_option | lock_option] ...

示例: CREATE USER 'jeffrey'@'localhost' IDENTIFIED BY 'password';

首次创建的帐户没有特权。要分配特权,请使用以下GRANT 语句。 GRANT

priv_type [(column_list)]

[, priv_type [(column_list)]] ...

ON [object_type] priv_level

TO user [auth_option] [, user [auth_option]] ...

[REQUIRE {NONE | tls_option [[AND] tls_option] ...}]

[WITH {GRANT OPTION | resource_option} ...]

帐户的主机名部分(如果省略)默认为 '%'。

通常,数据库管理员首先用于 CREATE USER创建帐户并定义其非特权特征,例如其密码,是否使用安全连接以及对服务器资源的访问限制,然后再用于 GRANT定义其特权。 ALTER USER可用于更改现有帐户的非特权特征。例如: CREATE USER 'jeffrey'@'localhost' IDENTIFIED BY 'password';

GRANT ALL ON db1.* TO 'jeffrey'@'localhost';

GRANT SELECT ON db2.invoice TO 'jeffrey'@'localhost';

ALTER USER 'jeffrey'@'localhost' WITH MAX_QUERIES_PER_HOUR 90;

删除用户 DROP USER [IF EXISTS] user [, user] ...

该DROP USER语句删除一个或多个MySQL帐户及其特权。它从所有授权表中删除该帐户的特权行。 DROP USER 'jeffrey'@'localhost';

帐户名的主机名部分(如果省略)默认为 '%'。

授权

以下语句全局授予 SELECT和 INSERT特权: GRANT SELECT, INSERT ON *.* TO u1;

授予 全局访问特权 GRANT ALL ON *.* TO u1;

重命名用户

示例: RENAME USER 'jeffrey'@'localhost' TO 'jeff'@'127.0.0.1';

撤销特权

要撤消所有特权,该语法将删除一个或多个指定用户的所有全局,数据库,表,列和例程特权: REVOKE ALL PRIVILEGES, GRANT OPTION FROM user [, user] ...

示例: #撤销localhost机器上jeffrey的INSERT所有权限

REVOKE INSERT ON *.* FROM 'jeffrey'@'localhost';

SET PASSWORD语句

示例:创建明文密码 ALTER USER user IDENTIFIED BY 'auth_string';

该语句 使用子句设置命名帐户的密码,该密码必须存在: FOR user SET PASSWORD FOR 'jeffrey'@'localhost' = 'auth_string';

如果没有no 子句,该语句将为当前用户设置密码: FOR user SET PASSWORD = 'auth_string';

使用该PASSWORD()函数(自MySQL 5.7.6起不推荐使用) SET PASSWORD FOR 'jeffrey'@'localhost' = PASSWORD('password');

该PASSWORD()参数是明文(未加密的)密码。 PASSWORD()散列密码并返回加密的密码字符串,以存储在mysql.user系统表的帐户行中 。

该PASSWORD()函数使用由old_passwords系统变量值的值确定的哈希方法对密码进行哈希处理 。确保 old_passwords该值具有与该帐户关联的身份验证插件所需的哈希方法相对应的值。例如,如果帐户使用 mysql_native_password插件,则该 old_passwords值必须为0: SET old_passwords = 0;

SET PASSWORD FOR 'jeffrey'@'localhost' = PASSWORD('password');

活锁和死锁解决方法

活锁

活锁出现的场景 很多个执行事务进来,T1到了执行。T2进来优先级级别低,同时T3....很多事务进来都比T2优先级别高,导致T2一直等待,造成活锁。

解决方案: 加个队列执行。

死锁

一次性锁请求(把相关的事务都加到一次请求锁中,几乎不可能实现)

锁请求排序

序列化处理

资源剥夺(给锁加超时时间,让资源回滚,然后重写请求)

不去防止 (定时检测死锁,去解除死锁)

可串行 一组事务是可串行的。(把并行的转换成串行)

两段封锁法

b109bbcd51a831ca95dd5c567d481288.png

备份还原

备份

修改/etc/my.conf

[mysqld]标签下添加 #所以目录都可以导入导出

secure_file_priv=''

执行导出

t1表导出到/tmp/user.csv

格式: into outfile ‘导出的目录和文件名’

指定导出的目录和文件名

fields terminated by ‘字段间分隔符’

定义字段间的分隔符

optionally enclosed by ‘字段包围符’

定义包围字段的字符(数值型字段无效)

lines terminated by ‘行间分隔符’

定义每行的分隔符

select a,b,a+b from t1 into outfile '/tmp/user.txt' fields terminated by ',' optionally enclosed by '"' lines terminated by '\r\n';

还原

这里(a,b,c)指定了列,如果不指定列就是导入数据到所有列,这里导入数据会插入到之前的数据后边。 LOAD DATA INFILE '/tmp/user.csv' INTO TABLE t1 fields terminated by ',' optionally enclosed by '"' lines terminated by '\r\n' (a,b,c);

ca30137590d3ad3a7124492800454068.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值