MySQL(一)

MySQL(一)

目录

MySQL(一)

1.1数据库的操作

1.2数据表的操作


安装Windows服务

mysqld --install //安装Windows服务
mysqld --remove  //卸载Windows服务

net start mysql //开启服务
net stop mysql //关闭服务

设置密码:
mysqladmin -uroot -p password "123"  #设置初始密码 由于原密码为空,因此-p可以不用 
Mysql版本的不同,可能执行这句指令不起作用
请使用update mysql.user set authentication_string =password('') where User='root'; 
忘记密码怎么办?
(1)先关闭之前的mysql服务器的进程;
(2)跳过权限表开启mysql的服务端 mysqld --skip-grant-tables
(3)客户端连接 mysql -uroot -p;
(4)更改密码:updata mysql.user set authentication_string =password('') where User='root';
(5)刷新权限:flush privileges;

查询进程号:tasklist |findstr mysql
关闭进程:tasklist /F /PID 进程号

生成data(启动):mysqld --initialize-insecure

1.1数据库的操作

a.显示数据库

show databases;

b.创建,删除数据库

create database db1;  //创建数据库
create database db1 default charset utf8; 

drop database db1;  //删除数据库
select database();  //查看所在哪个数据库

c.使用数据库

use 数据库名;

d.用户管理

进入mysql,查看user,host
use mysql;
select user,host from user;

创建用户
    create user '用户名'@'IP地址' identified by '密码';
#'alex'@'192.168.1.%
删除用户
    drop user '用户名'@'IP地址';
修改用户
    rename user '用户名'@'IP地址' to '新用户名'@'IP地址';
修改密码
    set password for '用户名'@'IP地址' = Password('新密码');
修改root
    ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';

e.授权管理

show grants for '用户'@'IP地址'                  -- 查看权限
grant  权限 on 数据库.表 to   '用户'@'IP地址'      -- 授权
revoke 权限 on 数据库.表 from '用户'@'IP地址'      -- 取消权限

1.2数据表的操作

a.显示表

show tables;  //查看所有表
desc t1;   //查看表的详细信息
show create table t1; //查看创建t1表的sql语句

b.创建表

create table t1(
            列名 类型 null,
            列名 类型 not null,
            列名 类型 auto_increment primary key,
            id int,
            name char(10)
)engine=innodb default charset=utf8;

#innodb 支持事务,原子性操作
#auto_increment 表示:自增
#primary key:  表示 约束(不能重复且不能为空); 加速查找
#not null: 是否为空

c.清空,删除表

delete from 表名;   //保留了主键的id 
truncate table 表名;  //不保留主键的id
drop table 表名;

d.数据类型

数据类型:
        bit[(m)]
            二进制位(101001),m表示二进制位的长度(1-64),默认m=1

        tinyint[(m)] [unsigned] [zerofill]

            小整数,数据类型用于保存一些范围的整数数值范围:
            有符号:
                -128 ~ 127.
            无符号:
                 0 ~ 255

            特别的: MySQL中无布尔值,使用tinyint(1)构造。

        int[(m)][unsigned][zerofill]

            m是显示宽度而不是存储宽度,默认总长度的位数加1

            zerofill用0填充

            整数,数据类型用于保存一些范围的整数数值范围:
                有符号:
                    -2147483648 ~ 2147483647
                无符号:
                    0 ~ 4294967295

            特别的:整数类型中的m仅用于显示,对存储范围无限制。例如: int(5),当插入数据2时,select 时数据显示为: 00002

        bigint[(m)][unsigned][zerofill]
            大整数,数据类型用于保存一些范围的整数数值范围:
                有符号:
                    -9223372036854775808 ~ 9223372036854775807
                无符号:
                    0 ~  18446744073709551615

        decimal[(m[,d])] [unsigned] [zerofill]
            准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。

            特别的:对于精确数值计算时需要用此类型
                   decaimal能够存储精确值的原因在于其内部按照字符串存储。

        FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]
            单精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。
                无符号:
                    -3.402823466E+38 to -1.175494351E-38,
                    1.175494351E-38 to 3.402823466E+38
                有符号:
                    1.175494351E-38 to 3.402823466E+38

            **** 数值越大,越不准确 ****

        DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]
            双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。

                无符号:
                    -1.7976931348623157E+308 to -2.2250738585072014E-308
                    2.2250738585072014E-308 to 1.7976931348623157E+308
                有符号:
                    2.2250738585072014E-308 to 1.7976931348623157E+308
            **** 数值越大,越不准确 ****


        char (m)
            char数据类型用于表示固定长度的字符串,可以包含最多达255个字符。
            其中m代表字符串的长度。
            PS: 即使数据小于m长度,也会占用m长度
        varchar(m)
            varchars数据类型用于变长的字符串,可以包含最多达255个字符。
            其中m代表该数据类型所允许保存的字符串的最大长度,只要长度小于该最大值的字符串
            都可以被保存在该数据类型中。

            注:虽然varchar使用起来较为灵活,但是从整个系统的性能角度来说,
            char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。
            因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡。

        text
            text数据类型用于保存变长的大字符串,可以组多到65535 (2**16 − 1)个字符。

        mediumtext
            A TEXT column with a maximum length of 16,777,215 (2**24 − 1) characters.

        longtext
            A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 − 1) characters.


        enum
            枚举类型,
            An ENUM column can have a maximum of 65,535 distinct elements. (The practical limit is less than 3000.)
            示例:
                CREATE TABLE shirts (
                    name VARCHAR(40),
                    size ENUM('x-small', 'small', 'medium', 'large', 'x-large')
                );
                INSERT INTO shirts (name, size) VALUES ('dress shirt','large'), ('t-shirt','medium'),('polo shirt','small');

        set
            集合类型
            A SET column can have a maximum of 64 distinct members.
            示例:
                CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));
                INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');

        DATE
            YYYY-MM-DD(1000-01-01/9999-12-31)

        TIME
            HH:MM:SS('-838:59:59'/'838:59:59')

        YEAR
            YYYY(1901/2155)

        DATETIME

            YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59    Y)

        TIMESTAMP

            YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)

eg:
create table t1(d date,t time,dt datetime);
insert into t1 values(now(),now(),now());
select * from t1;

e.修改表(添加,删除,修改,主键,修改默认值)

添加列:
        alter table 表名 add 列名 类型
删除列:
        alter table 表名 drop column 列名
修改列:
        alter table 表名 modify column 列名 类型;  -- 类型
        alter table 表名 change 原列名 新列名 类型; -- 列名,类型
  
添加主键:
        alter table 表名 add primary key(列名);
删除主键:
        alter table 表名 drop primary key;
        alter table 表名  modify  列名 int, drop primary key;
  
添加外键:
        alter table 从表 add constraint 外键名称(形如:FK_从表_主表) foreign key 从表(外键 
        字段)references 主表(主键字段);
删除外键:alter table 表名 drop foreign key 外键名称
  
修改默认值:ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000;
删除默认值:ALTER TABLE testalter_tbl ALTER i DROP DEFAULT;
外键:
create table userinfo(
			uid int auto_increment primary key,
			name varchar(32),
			department_id int,
			xx_id int,
			constraint fk_user_depar foreign key (department_id) references department(id)
            on delete cascade //同步删除
            on updata cascade //同步更新
		)engine=innodb default charset=utf8;
		
		create table department(
			id int auto_increment primary key,
			title char(15)
		)engine=innodb default charset=utf8;

f.表内操作

单表查询
一、单表查询的语法
   SELECT 字段1,字段2... FROM 表名
                  WHERE 条件
                  GROUP BY field
                  HAVING 筛选
                  ORDER BY field
                  LIMIT 限制条数
二、关键字的执行优先级(重点)

重点中的重点:关键字的执行优先级
from
where
group by
having
select
distinct  //去重
order by
limit
1.找到表:from

2.拿着where指定的约束条件,去文件/表中取出一条条记录

3.将取出的一条条记录进行分组group by,如果没有group by,则整体作为一组

4.将分组的结果进行having过滤

5.执行select

6.去重  SELECT distinct 字段1 FROM 表名

7.将结果按条件排序:order by

8.限制结果的显示条数
1、增
insert into 表 (列名,列名...) values (值,值,值...);
insert into 表 (列名,列名...) values (值,值,值...),(值,值,值...);
insert into 表1 (列名,列名...) select (列名,列名...) from 表2;  //从表2复制到表1

2、删
delete from 表;
delete from 表 where id=1 and name='alex';

3、改
update 表 set name = 'alex' where id>1;

4、查
select * from 表;
select * from 表 where id > 1;
select nid,name,gender as gg from 表 where id > 1;

5、其他
a、条件
    select * from 表 where id > 1 and name != 'alex' and num = 12;
 
    select * from 表 where id between 5 and 16;  //[5,6]
 
    select * from 表 where id in (11,22,33);
    select * from 表 where id not in (11,22,33);
    select * from 表 where id in (select nid from 表);
 
b、通配符
    select * from 表 where name like 'ale%'  - ale开头的所有(多个字符串)
    select * from 表 where name like 'ale_'  - ale开头的所有(一个字符)
 
c、限制
    select * from 表 limit 5;            - 前5行
    select * from 表 limit 4,5;          - 从第4行开始的5行
    select * from 表 limit 5 offset 4    - 从第4行开始的5行
 
d、排序
    select * from 表 order by 列名 asc              - 根据 “列” 从小到大排列
    select * from 表 order by 列名 desc             - 根据 “列” 从大到小排列
    select * from 表 order by 列1 desc,列2 asc    - 根据 “列1” 从大到小排列,如果相同则按列2从小到大排序
 

e、分组
    select num from 表 group by num
    select num,nid from 表 group by num,nid
    select num,nid from 表  where nid > 10 group by num,nid order nid desc
    select num,nid,count(*),sum(score),max(score),min(score),avg(score) from 表 group by num,nid
 
    **聚合函数后进行二次筛选必须用having
    select num from 表 group by num having max(id) > 10
 
    特别的:group by 必须在where之后,order by之前
 
f、连表
    无对应关系则不显示
    select A.num, A.name, B.name
    from A,B
    Where A.nid = B.nid
 
    无对应关系则不显示
    select A.num, A.name, B.name
    from A inner join B
    on A.nid = B.nid
 
    A表所有显示,如果B中无对应关系,则值为null
    select A.num, A.name, B.name
    from A left join B
    on A.nid = B.nid
 
    B表所有显示,如果B中无对应关系,则值为null
    select A.num, A.name, B.name
    from A right join B
    on A.nid = B.nid

    上下链表:union 去重 
             union all 不去重
    select sid,name from student
    union 
    select tid,name from teacher;
 
g、组合
    组合,自动处理重合
    select nickname
    from A
    union
    select name
    from B
 
    组合,不处理重合
    select nickname
    from A
    union all
    select name
    from B
h、对于自增补充:
		desc t10; 查看表中的数据类型,默认值
		
		show create table t10;查看表示怎么创建的
		
		show create table t10 \G;
		
		alter table t10 AUTO_INCREMENT=20; 修改自增的值,下一个ID序号为20
			
			
		MySQL: 自增步长
			基于会话级别:
				show session variables like 'auto_inc%';	查看全局变量
            				 set session auto_increment_increment=2; 	设置会话步长
				# set session auto_increment_offset=10;          设置初始位置
			基于全局级别:
				show global variables like 'auto_inc%';	    查看全局变量
                			 set global auto_increment_increment=2; 	    设置会话步长
				# set global auto_increment_offset=10;
				
				
		SqlServer:自增步长:
			基础表级别:
				CREATE TABLE `t5` (
				  `nid` int(11) NOT NULL AUTO_INCREMENT,
				  `pid` int(11) NOT NULL,
				  `num` int(11) DEFAULT NULL,
				  PRIMARY KEY (`nid`,`pid`)
				) ENGINE=InnoDB AUTO_INCREMENT=4, 步长=2 DEFAULT CHARSET=utf8
				
				CREATE TABLE `t6` (
				  `nid` int(11) NOT NULL AUTO_INCREMENT,
				  `pid` int(11) NOT NULL,
				  `num` int(11) DEFAULT NULL,
				  PRIMARY KEY (`nid`,`pid`)
				) ENGINE=InnoDB AUTO_INCREMENT=4, 步长=20 DEFAULT CHARSET=utf8
i、unique
   单列唯一:
   create table department(
       id int,
       name char(10) unique
   );
   多列唯一:
   create table department(
       id int,
       name char(10) ,
       unique(id),
       unique(name)
   );
   组合唯一;
   create table services(
           id int,
           ip char(15),
           port int,
           unique(id),
           unique(ip,port)
   );

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值