基本语法:Create database 数据库名字 [库选项];
库选项用来约束数据库,分为两个选项:1.字符集设定:charset/character 具体字符集(数据存储的编码格式) 常用的字符集:GBK和UTF8(UTF8中间不能加中划线或者下划线)
2.校对集设定:collate 具体校对集(数据比较的规则)
创建一个扩展名为sql的文件,比如sql_2018_0503.sql(将其内容复制到Mysql命令窗口中)
-- sql_2018_0503.sql内容: -- 双中划线+空格:注释(单行注释),也可以使用#号(只能在开头,不能在句中) # 创建数据库 create database mydatabase charset utf8;-- 创建一个名为mydatabase的数据库
注意:#号做注释只能在开头,不能在句中
其中:数据库名字不能用关键字(已经被使用的字符)或者保留字(将来可能会用到的)
# 创建关键字数据库(出错) create database database charset utf8;-- 创建一个名为database的数据库
如果非要使用关键字或者保留字,name必须使用两个反引号(esc键下面的键在英文状态下的输出:`)
# 使用反引号 create database `database` charset utf8;
使用中文数据库是可以的,但是有前提条件:保证服务器能够识别(建议不用)
-- 创建中文数据库(直接创建是错误的,无论加不及反引号,本身不需要加反引号 create database 中国 charset utf8; create database `中国` charset utf8; -- 解决方法:告诉服务器当前中文的字符集是什么(查看方法:命令窗口左上角->属性->选项) set names gbk; create database 中国 charset utf8;-- 没有必要加反引号
当创建数据库的SQL语句执行之后,发生了什么?
3.每个数据库下都有一个opt 文件:保存了数据库选项
注:校对集依赖字符集指的是:字符集改变校对集也会改变
原文:https://www.cnblogs.com/tianqizhi/p/8987906.html