Mysql

来源:互联网 发布:js多级联动选项卡 编辑:程序博客网 时间:2024/06/13 04:43
 

操作库

创建库

CREATE DATABASE [IF NOT EXISTS]数据库名 [参数[参数] [参数]...];

参数:

CHARACTER SET码表名

COLLATE校对规则名,详见文档10.10.1

显示库

SHOW DATABASES;

显示数据库创建语句

SHOW CREATE DATABASE数据库名;

修改库

ALTER DATABASE数据库名[参数[参数][参数]...];

注意:不能改数据库的名字

删除库

DROP DATABASE [IF EXISTS]数据库名;

练习:

创建一个数据库db1

创建一个数据库db2指定字符编码,校对规则

create database db2 character set utf8 collate utf8_bin;

显示所有数据库

显示db2的字符编码

db2的字符编码设置为gbk alter database db2 character set gbk;


删除db2数据库drop database db3;

操作表

操作表之前使用需要先确定使用哪个数据库

USE数据库名

创建表

CREATE TABLE表名(列名类型[,列名类型][,列名类型]...);


具体类型说明可参见MySQL文档第11

查看所有表

SHOW TABLES;

查看表的创建语句

SHOW CREATE TABLE表名;

显示表结构

DESC表名;

修改表名

RENAME TABLE原表名 TO 新表名;


操作数据(增删改)

插入

语法:

INSERT INTO表名[(列名[,列名]...)] VALUES([,]...);

注意事项:

插入值类型必须与对应列的数据类型一致

数据不能超出长度

插入值得为之必须与列名顺序一致

字符和日期数据要放在单引号中

插入空值使用null

如果不指定插入哪一列,就是插入所有列

中文数据

由于默认码表是utf8,cmd.exe的码表是gbk,在插入中文数据的时候会报错, 所以我们需要修改客户端码表

先查看系统变量:SHOW VARIABLES LIKE 'character%';

修改客户端码表:SET character_set_client=gbk;

这样就解决了中文插入的问题,但在查询数据的时候仍然显示为乱码, 这是因为mysqlcmd传输数据的时候使用的是utf8

修改输出数据的码表: SET character_set_results=gbk;

删除

语法

DELETE FROM表名 [where 条件语句]

注意事项

如果不加where子句,将删除表中所有记录

delete只能用作删除行,不能删除某一列的值, 需要用update

deleteupdate的时候需要注意表与表之间的关联关系

删除表中所有数据可以使用: TRANCATE表名,这种方式会删除旧表重新创建,在数据较多的时候使用

原创粉丝点击