mysql增删改查语句以及常用方法_MySQL常用命令和增删改查语句
mysql增删改查语句以及常⽤⽅法_MySQL常⽤命令和增删改
查语句
连接命令:mysql -h[主机地址] -u[⽤户名] -p[⽤户密码]
创建数据库:create database [库名]
显⽰所有数据库: show databases;
打开数据库:use [库名]
当前选择的库状态:SELECT DATABASE();
创建数据表:CREATE TABLE [表名]([字段名] [字段类型]([字段要求]) [字段参数], ......);
显⽰数据表字段:describe 表名;
当前库数据表结构:show tables;
更改表格
ALTER TABLE [表名] ADD COLUMN [字段名] DATATYPE
说明:增加⼀个栏位(没有删除某个栏位的语法。
ALTER TABLE [表名] ADD PRIMARY KEY ([字段名])
说明:更改表得的定义把某个栏位设为主键。
ALTER TABLE [表名] DROP PRIMARY KEY ([字段名])
说明:把主键的定义删除。
修改表中字段的名:  MSSQL:  EXECUTE sp_rename  N'dbo.e_table.date',  N'datetest',  'COLUMN';
(sqlite 不⽀持)      MySQL:  ALTER TABLE 表名 CHANGE 旧字段名 新字段名 新数据类型
显⽰当前表字段:show columns from tablename;
删库:drop database [库名];
删表:drop table [表名];
数据操作
添加:INSERT INTO [表名] VALUES('','',......顺序排列的数据);
查询: SELECT * FROM [表名] WHERE ([条件]);
建⽴索引:CREATE INDEX [索引⽂件名] ON [表名] ([字段名]);
删除:DELETE FROM [表名] WHERE ([条件]);
修改:UPDATE [表名] SET [修改内容如name='Mary'] WHERE [条件];
导⼊外部数据⽂本:
1.执⾏外部的sql脚本
当前数据库上执⾏:mysql
指定数据库上执⾏:mysql [表名]
2.数据传⼊命令 load data local infile "[⽂件名]" into table [表名];
备份数据库:(dos下)
mysqldump --opt school>school.bbb
提⽰:常⽤MySQL命令以";"结束,有少量特殊命令不能加";"结束,如备份数据库
⼀. 增删改查操作
================================================================================= 1. 增:
insert into 表名 values(0,'测试');
注:如上语句,表结构中有⾃动增长的列,也必须为其指定⼀个值,通常为0
insert into 表名(id,name) values(0,'尹当')--同上
2.删数据:
delete from 表名;
delete from 表名 where id=1;
删除结构:
删数据库:drop database 数据库名;
删除表:drop table 表名;
新学期开学寄语删除表中的列:alter table 表名 drop column 列名;
3. 改:
修改所有:update 表名 set 列名='新的值,⾮数字加单引号' ;
带条件的修改:update 表名 set 列名='新的值,⾮数字加单引号' where id=6;
4.查:
查询所有的数据:select *from 表名;
带条件的查询:
select *from 表名 where 列名=条件值;
Select * from 表名 where 列名 not like(like) '字符值'
分页查询:select *from 表名 limit 每页数量 offset 偏移量;
⼆.操作命令
=================================================================================
1. 查看数据库信息:show databases;
2.查看表信息:show tables;
3.查看表的结构:desc 表名
4. 新建数据库:create database 数据库名;
5.操作指定数据库:use 数据库名;
6.新建数据表(先use 操作库);
create table 表名(规范为tbl_表名)
(
id int auto_increment primary key,( auto_increment为⾃动增长)
name varchar(20) primary key
)ENGINE=InnoDBDEFAULTCHARSET=gbk//⽀持事务和设置表的编码
6.2添加主外键:
alter table 外表名  add constraint FK_名称 foreign key(外列) references 主表名(主列)
如现有两表 主表tbl_order ⼦表tbl_orderdetail 现⼦表tbl_orderdetail的oid列引⽤了主表tbl_order的oid列
则命令如下:
alter table tbl_orderdetail  add constraint FK_oid foreign key(oid) references tbl_order(oid)
7.导出表,备份到⼀个⽂件中,如.txt,.doc
12306网上订火车票时间
cmd命令窗⼝:mysqldump -u ⽤户名  -p  需要备份的数据库名 >备份的⽂件的保存路径和⽂件名
注:如指定的⽂件不存在,mysql会⾃动添加⼀个⽂件,此命令不能加分号结尾(⽂件没有备份建数据库操作)
8.导⼊数据库备份⽂件:
(1).在mysql命令窗⼝
(2).新建⼀个要导⼊的数据库(因为备份中没有备份建数据库操作)
(3).use 当前库名
(4).source 备份的⽂件的保存路径和⽂件名(此命令不能加分号结尾)
三:系统操作
=================================================================================
1. 打开服务:net start mysql(mysql为配置时,可⾃定名称)
2.关闭服务:net stop mysql
3.从cmd 模式进⼊mysql
(1).mysql -u ⽤户名 -p 回车>输⼊正确密码>进⼊欢迎
南京有什么地方好玩(2).mysql -h IP(本机localhost) -u ⽤户名 -p 回车>输⼊正确密码>进⼊欢迎
3.退出:exit/quit;
4.修改⽤户密码:mysqladmin -u ⽤户名 -p password 新密码
5.处理中⽂乱码:
(1).在D:/MySQL /MySQL Server 5.0/data的操作数据为⽂件中查看是否为以下:
default-character-set=gbk
default-collation=gbk_chinese_ci
(2).查看安装⽂件默认编码:D:/MySQL/MySQL Server 5.0>my>default-character-set=gbk
=================================================================================启动:net start mySql;
进⼊:mysql -u root -p/mysql -h localhost -u root -p databaseName;
列出数据库:show databases;
选择数据库:use databaseName;
列出表格:show tables;
显⽰表格列的属性:show columns from tableName;
手机蓝牙上网建⽴数据库:;
匹配字符:可以⽤通配符_代表任何⼀个字符,%代表任何字符串;
增加⼀个字段:alter table tabelName add column fieldName dateType;
增加多个字段:alter table tabelName add column fieldName1 dateType,add columns fieldName2 dateType;
多⾏命令输⼊:注意不能将单词断开;当插⼊或更改数据时,不能将字段的字符串展开到多⾏⾥,否则硬回车将被储存到数据中;增加⼀个管理员帐户:grant all on *.* to user@localhost identified by "password";
每条语句输⼊完毕后要在末尾填加分号';',或者填加'/g'也可以;
查询时间:select now();
查询当前⽤户:select user();
查询数据库版本:select version();
查询当前使⽤的数据库:select database();
1、删除student_course数据库中的students数据表:
rm -f student_course/students.*
2、备份数据库:(将数据库test备份)
mysqldump -u root -p test>c:/
备份表格:(备份test数据库下的mytable表格)
mysqldump -u root -p test mytable>c:/
将备份数据导⼊到数据库:(导回test数据库)
mysql -u root -p test
3、创建临时表:(建⽴临时表zengchao)
create temporary table zengchao(name varchar(10));
4、创建表是先判断表是否存在
create table if not exists students(……);
5、从已经有的表中复制表的结构
create table table2 select * from table1 where 1<>1;
6、复制表
create table table2 select * from table1;
7、对表重新命名
alter table table1 rename as table2;
8、修改列的类型
alter table table1 modify id int unsigned;//修改列id的类型为int unsigned
二十大召开闭幕时间alter table table1 change id sid int unsigned;//修改列id的名字为sid,⽽且把属性修改为int unsigned
9、创建索引
alter table table1 add index ind_id (id);
祝老师教师节快乐短语
create index ind_id on table1 (id);
create unique index ind_id on table1 (id);//建⽴唯⼀性索引
10、删除索引
drop index idx_id on table1;
alter table table1 drop index ind_id;
11、联合字符或者多个列(将列id与":"和列name和"="连接)
select concat(id,':',name,'=') from students;
12、limit(选出10到20条)
select * from students order by id limit 9,10;
13、MySQL不⽀持的功能
事务,视图,外键和引⽤完整性,存储过程和触发器
14、MySQL会使⽤索引的操作符号
=,>,=,between,in,不带%或者_开头的like
15、使⽤索引的缺点
1)减慢增删改数据的速度;
2)占⽤磁盘空间;
3)增加查询优化器的负担;
当查询优化器⽣成执⾏计划时,会考虑索引,太多的索引会给查询优化器增加⼯作量,导致⽆法选择最优的查询⽅案;
16、分析索引效率
⽅法:在⼀般的SQL语句前加上explain;
分析结果的含义:
1)table:表名;
2)type:连接的类型,(ALL/Range/Ref)。其中ref是最理想的;
3)possible_keys:查询可以利⽤的索引名;
4)key:实际使⽤的索引;
5)key_len:索引中被使⽤部分的长度(字节);
6)ref:显⽰列名字或者"const"(不明⽩什么意思);
7)rows:显⽰MySQL认为在到正确结果之前必须扫描的⾏数;
8)extra:MySQL的建议;
17、使⽤较短的定长列

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。