MySQL数据库的基本命令有哪些
小编给大家分享一下MySQL数据库的基本命令有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
一、概述数据库结构数据库–>数据表–>行(记录):用来描述一个对象的信息列(字段):用来描述对象的一个属性常用数据类型类型 说明 int整型float单精度浮点-------4字节32位double双精度浮点-------8字节64位char固定长度的字符类型varchar可变长度的字符类型text文本image图片decimal (5,2)5个有效长度数字,小数点后面有2位
补充
char 最多能存放字符个数255个,char 如果存入数据的实际长度比指定长度要小,会补空格至指定长度;如果存入的数据的实际长度大于指定长度,低版本会被截取,高版本会报错。
char的长度是不可变的,而varchar的长度是可变的,也就是说,定义一个char[10]和varchar[10],如果存进去的是‘csdn’,那么char所占的长度依然为10,除了字符‘csdn’外,后面跟六个空格,而varchar就立马把长度变为4了
varchar存储规则:
4.0版本以下,varchar(20),指的是20字节,如果存放UTF8汉字时,只能存6个(每个汉字3字节)
5.0版本以上,varchar(20),指的是20字符,无论存放的是数字、字母还是UTF8汉字(每个汉字3字节),都可以存放20个,最大大小是65532字节。
SHOWDATABASES;#不区分大小写,分号“;”表示结束
查看数据库中包含的表USE数据库名;SHOWTABLES;
查看表的结构(字段)方法1USE数据库名;可缩写成:DESC表名;方法2DESCRIBE数据库名.表名;
三、SQL语句介绍SQL语句用于维护管理数据库,包括数据查询、数据更新、访问控制、对象管理等功能。
CREATEDATABASE数据库名;例如:createdatabasearts;
创建新的表CREATETABLE表名(字段1数据类型,字段2数据类型[,...][,PRIMARYKEY(主键名)]);#主键一般选择能代表唯一性的字段不允许取空值(NULL),一个表只能有一个主键。例:createdatabasearts;usearts;createtablestar(idintnotnull,namechar(20)notnull,sexchar(2),primarykey(id));descstar;
删除指定数据表如不用USE进入库中,则需加上数据库名DROPTABLE数据库名.表名;进入数据库,则直接加表名droptable表名
删除指定的数据库DROPDATABASE数据库名;
五、管理表中数据记录(DML)向数据表中插入新的数据记录INSERTINTO表名(字段1,字段2[,...])VALUES(字段1的值,字段2的值,...);例:createdatabasemarket;usemarket;createtablestar(idint(3)notnull,namechar(20),sexchar(2),ageint(3),passwdvarchar(50),primarykey(id));insertintostar(id,name,sex,age,passwd)values(1,'zz','男',18,12345678);select*fromstar;
补充密码加密
SELECT字段名1,字段名2[,...]FROM表名[WHERE条件表达式];例:select*fromstar;selectname,sexfromstarwhereid=1;
以列表方式竖向显示
只显示头2行
显示第2行后的前3行
UPDATE表名SET字段名1=字段值1[,字段名2=字段值2][WHERE条件表达式];例:updatestarsetage=33wherename='pp';select*fromstar;
在数据表中删除指定的数据记录DELETEFROM表名[WHERE条件表达式];例:deletefromstarwhereid=6;select*fromstar;
六、修改表名和表结构修改表名ALTERTABLE旧表名RENAME新表名;例:altertablestarrenameart;
扩展表结构(增加字段)ALTERTABLE表名ADDaddressvarchar(50)default'地址不详';#default‘地址不详’:表示此字段设置默认值地址不详;可与NOTNULL配合使用例:altertablestaraddaddressvarchar(50)default'地址不详';
修改字段(列)名,添加唯一键ALTERTABLE表名CHANGE旧列名新列名数据类型[uniquekey];例:altertablestarchangenameart_namevarchar(20)uniquekey;select*fromstar;
删除字段ALTERTABLE表名DROP字段名;例:altertablestardropaddress;
扩展CREATEDATABASEschool;useschool;createtableifnotexistsinfo(idint(4)zerofillprimarykeyauto_increment,#指定主键的第二种方式namevarchar(10)notnull,cardidint(18)notnulluniquekey,hobbyvarchar(50));#---------------命令解释--------------------------------#ifnotexists:表示检测要创建的表是否已存在,如果不存在就继续创建#int(4)zerofill:表示若数值不满4位数,则前面用“0”填充,例0001#auto_increment:表示此字段为自增长字段,即每条记录自动递增1,默认从1开始递增;自增长字段数据不可以重复;自增长字段必须是主键;如添加的记录数据没有指定此字段的值且添加失败也会自动递增一次#uniquekey:表示此字段唯一键约束,此字段数据不可以重复;一张表中只能有一个主键,但是一张表中可以有多个唯一键#notnull:表示此字段不允许为NULL
createtabletest1likeinfo;#通过LIKE方法,复制info表结构生成test1表insertintotest1select*frominfo;
方法二CREATETABLEtest2(SELECT*frominfo);showcreatetabletest2\G;#获取数据表的表结构、索引等信息SELECT*fromtest2;
deletefromtest1;#DELETE清空表后,返回的结果内有删除的记录条目;DELETE工作时是一行一行的删除记录数据的;如果表中有自增长字段,使用DELETEFROM删除所有记录后,再次新添加的记录会从原来最大的记录ID后面继续自增写入记录。
方法二:删除记录IDtruncatetabletest2;#TRUNCATE清空表后,没有返回被删除的条目;TRUNCATE工作时是将表结构按原样重新建立,因此在速度上TRUNCATE会比DELETE清空表快;使用TRUNCATETABLE清空表内数据后,ID会从1开始重新记录。
创建临时表临时表创建成功之后,使用SHOW TABLES命令是看不到创建的临时表的,临时表会在连接退出后被销毁。 如果在退出连接之前,也可以可执行增删改查等操作,比如使用 DROP TABLE 语句手动直接删除临时表。
CREATETEMPORARYTABLE表名(字段1数据类型,字段2数据类型[,...][,PRIMARYKEY(主键名)]);例:createtemporarytabletest3(idint(4)zerofillprimarykeyauto_increment,namevarchar(10)notnull,sexchar(2)notnull);insertintotest3values(1,'as','男');select*fromtest3;showtables;quit;mysql-uroot-pselect*fromtest3;
创建外键约束,保证数据的完整性和一致性外键的定义:如果同一个属性字段X在表一中是主键,而在表二中不是主键,则字段X称为表二的外键。
主键表和外键表的理解:
以公共关键字作主键的表为主键表(父表、主表)
以公共关键字作外键的表为外键表(从表、外表)
注意:与外键关联的主表的字段必须设置为主键。要求从表不能是临时表,主从表的字段具备相同的数据类型、字符长度和约束。
#创建主表test4createtabletest4(hobidint(4),hobnamevarchar(50));#创建从表test5createtabletest5(idint(4)primarykeyauto_increment,namevarchar(10),ageint(3),hobidint(4));#为主表test4添加一个主键约束,主键名建议以“PK_”开头altertabletest4addconstraintPK_hobidprimarykey(hobid);#为从表test5表添加外键,并将test5表的hobid字段和test4表的hobid字段建立外键关联,外键名建议以“FK_”开头altertabletest5addconstraintFK_hobforeignkey(hobid)referencestest4(hobid);desctest5;
插入新的数据记录时,要先主表再从表
insertintotest4values(1,'reading');insertintotest5values(1,'ad',18,1);
删数据记录时,要先从表再主表,也就是说删除主键表时必须要先删除其他与之相关联的表
droptablestest5;droptablestest4;
查看和删除外键约束
showcreatetabletest5\G;altertabletest5dropforeignkeyFK_hob;altertabletest5dropkeyFK_hob;desctest5;
MySQL中6种常见的约束主键约束(primarykey)外键约束(foreignkey)非空约束(notnull)唯一性约束(unique[key|index])默认值约束(default)自增约束(auto_increment)八、数据库用户授权新建用户
USER'用户名'@'来源地址'[IDENTIFIEDBY[PASSWORD]'密码'];#----------------------解释部分-----------------------------------------'用户名':指定将创建的用户名'来源地址':指定新创建的用户可在哪些主机上登录,可使用IP地址、网段、主机名的形式,本地用户可用localhost,允许任意主机登录可用通配符%'密码':若使用明文密码,直接输入'密码',插入到数据库时由Mysql自动加密;若使用加密密码,需要先使用SELECTPASSWORD('密码');获取密文,再在语句中添加PASSWORD'密文';若省略“IDENTIFIEDBY”部分,则用户的密码将为空(不建议使用)#----------------------------------------------------------------------例如:createuser'test1'@'localhost'IDENTIFIEDBY'123456';selectpassword('123456');createuser'test2'@'localhost'IDENTIFIEDBYPASSWORD'*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9';
查看用户信息#创建后的用户保存在mysql数据库的user表里usemysql;selectuser,authentication_string,Hostfromuser;
重命名用户renameuser'test1'@'localhost'to'zz'@'localhost';
删除用户dropuser'test2'@'localhost';
修改当前登录用户密码当前密码为abc123
setPASSWORD=PASSWORD('123456');
修改其他用户密码setPASSWORDfor'zz'@'localhost'=PASSWORD('abc123');
忘记 root 密码的解决办法方法一:修改 /etc/my.cnf 配置文件,不使用密码直接登录到 mysqlvim/etc/my.cnf[mysqld]skip-grant-tables#添加,使登录mysql不使用授权表systemctlrestartmysqld.servicemysql#直接登录
updatemysql.usersetAUTHENTICATION_STRING=PASSWORD('abc123')whereuser='root';FLUSHPRIVILEGES;quit;mysql-uroot-pabc123注意:最后再把/etc/my.cnf配置文件里的skip-grant-tables删除或注释,并重启mysql服务。
九、数据库用户授权授予权限GRANT语句:专门用来设置数据库用户的访问权限。
当指定的用户名不存在时,GRANT语句将会创建新的用户;
当指定的用户名存在时,GRANT 语句用于修改用户信息。
格式GRANT权限列表ON数据库名.表名TO'用户名'@'来源地址'[IDENTIFIEDBY'密码'];#-------------------------------参数解释---------------------------------------------------------------------------权限列表:用于列出授权使用的各种数据库操作,以逗号进行分隔,如“select,insert,update”。使用“all”表示所有权限,可授权执行任何操作。数据库名.表名:用于指定授权操作的数据库和表的名称,其中可以使用通配符“*”。例如,使用“test.*”表示授权操作的对象为test数据库中的所有表。'用户名'@'来源地址':用于指定用户名称和允许访问的客户机地址,即谁能连接、能从哪里连接。来源地址可以是域名、IP地址,还可以使用“%”通配符,表示某个区域或网段内的所有地址,如“%.test.com”、“192.168.19.%”等。IDENTIFIEDBY:用于设置用户连接数据库时所使用的密码字符串。在新建用户时,若省略“IDENTIFIEDBY”部分,则用户的密码将为空。例如:#允许用户lili在本地查询kky数据库中所有表的数据记录,但禁止查询其他数据库中的表的记录。GRANTselectONkky.*TO'lili'@'localhost'IDENTIFIEDBY'abc123';flushprivileges;quit;mysql-ulili-pabc123usekky;showtables;select*frominfo;其他授权例子:#允许用户pp在所有终端远程连接mysql,并拥有所有权限。GRANTALLPRIVILEGES(可不写)ON*.*TO'pp'@'%'IDENTIFIEDBY'123456';
SHOWGRANTSFOR用户名@来源地址;例如:SHOWGRANTSFOR'lili'@'localhost';
撤销权限REVOKE权限列表ON数据库名.表名FROM用户名@来源地址;例如:REVOKESELECTONkky.*FROM'lili'@'localhost';SHOWGRANTSFOR'lili'@'localhost';#USAGE权限只能用于数据库登陆,不能执行任何操作;USAGE权限不能被回收,即REVOKE不能删除用户。flushprivileges;REVOKEALLON*.*FROM'lili'@'localhost';
以上是“MySQL数据库的基本命令有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。