首頁 資料庫 mysql教程 MySQL 建库、建用户及建表事项

MySQL 建库、建用户及建表事项

May 31, 2016 am 08:49 AM

1,MySQL建库语句比较简单,一句话:

1 create database tppamltest3
登入後複製

2,创建用户及授权:

1 insert into mysql.user(Host,User,Password,ssl_cipher,x509_issuer,x509_subject) values("localhost","用户名",password("密码"),"","","");2 flush privileges; 3 grant all privileges on tppamltest3.* to 用户名@localhost identified by '密码';4 flush privileges;
登入後複製

其中授权语句給用户分配了全部权限,具体其他看百度。

3,建表脚本:

 1 use tppamltest3; 2  3 SET FOREIGN_KEY_CHECKS=0; 4  5 -- ---------------------------- 6 -- Table structure for cfg_auto_mend 7 -- ---------------------------- 8 DROP TABLE IF EXISTS `cfg_auto_mend`; 9 CREATE TABLE `cfg_auto_mend` (10 `ID` varchar(32) NOT NULL,11 `MEND_SQL` text,12 PRIMARY KEY (`ID`)13 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
登入後複製

注意最后有默认编码设置。

---------------------------完成-----------------------------

=================================

一些异常情况的处理

=================================

乱码问题:

首先,shell里可以查看MYSQL目前编码

show variables like '%character%';
登入後複製
+--------------------------+-------------------------------------+| Variable_name| Value |+--------------------------+-------------------------------------+| character_set_client | utf8|| character_set_connection | utf8|| character_set_database | gbk || character_set_filesystem | binary|| character_set_results| utf8|| character_set_server | utf8|| character_set_system | utf8|| character_sets_dir | E:/anzhuan/MySQL5.5/share/charsets/ |+--------------------------+-------------------------------------+8 rows in set (0.00 sec)
登入後複製

可以更改

set character_set_client = 字符集
登入後複製

只要编码保持一致就不会出现乱码。

================================一下内容为摘抄========================================

1.系统编码

>show variables like '%character%';  

            mysql> show variables like '%collation%';

改变系统编码:修改my.cnf(/etc/my.cnf)中默认的编码选项[mysqld]下添加default-charcter-set=utf8  mysql 5.5以上版本换成了character-set-server=utf8 重新启动mysql

   命令形式   mysql> SET NAMES 'utf8'; 重新启动mysql的时候所有的设置将失效

2.数据库编码

查看数据库编码: mysql> show create database db_name;

修改数据库编码: mysql> ALTER DATABASE db_name ####这里修改整个数据库的编码

               CHARACTER SET utf8

                    DEFAULT CHARACTER SET utf8

                    COLLATE utf8_general_ci

                    DEFAULT COLLATE utf8_general_ci;

在在建数据库的时候指定编码:

        mysql> CREATE DATABASE db_name

               CHARACTER SET utf8

               DEFAULT CHARACTER SET utf8

               COLLATE utf8_general_ci

               DEFAULT COLLATE utf8_general_ci ;

3.数据库表和字段编码

查看数据库表和字段编码: mysql> show create table table_name;

>ALTER TABLE table_name DEFAULT CHARACTER SET utf8; 

修改字段编码: mysql> ALTER TABLE `table_name` CHANGE `dd` `dd` VARCHAR( 45 ) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL             该命令就是将MYSQL数据库table_name表中 dd的字段编码改为utf8

4.命令行下插入汉字时指定编码:mysql> set names utf8;   有时候这一句很关键!

                mysql> insert into test(name) values('王东伟');

总之,不管采用那一种编码方式,只要做到完全统一将能达到相应的效果。

-------------------------------------------------------------------分隔-----------------------------------------------------------------------

在查询结果中可以看到mysql 数据库系统中客户端、数据库连接、数据库、文件系统、查询结果、服务器、系统的字符集设置在这里,文件系统字符集是固定的,系统、服务器的字符集在安装时 确定,与乱码问题无关。乱码的问题与客户端、数据库连接、数据库、查询结果的字符集设置有关。

*注:客户端是看访问mysql 数据库的方式,通过命令行访问,命令行窗口就是客户端,通过JDBC 等连接访问,程序就是客户端我们在向mysql 写入中文数据时,在客户端、数据库连接、写入数据库时分别要进行编码转换。在执行查询时,在返回结果、数据库连接、客户端分别进行编码转换。现在我们应该 清楚,乱码发生在数据库、客户端、查询结果以及数据库连接这其中一个或多

个环节

接下来我们来解决这个问题

在登录数据库时,我们用mysql --default-character-set=字符集-u root -p 进行连接,这时我们

再用show variables like '%char%';命令查看字符集设置情况,可以发现客户端、数据库连接、

查询结果的字符集已经设置成登录时选择的字符集了

如果是已经登录了,可以使用set names 字符集;命令来实现上述效果,等同于下面的命令:

set character_set_client = 字符集

set character_set_connection = 字符集

set character_set_results = 字符集

如果是通过JDBC 连接数据库,可以这样写URL:

URL=jdbc:mysql://localhost:3306/abs?useUnicode=true&characterEncoding=字符集

JSP 页面等终端也要设置相应的字符集

数据库的字符集可以修改mysql 的启动配置来指定字符集,也可以在create database 时加上

default character set 字符集来强制设置database 的字符集

通过这样的设置,整个数据写入读出流程中都统一了字符集,就不会出现乱码了

为什么从命令行直接写入中文不设置也不会出现乱码?

可以明确的是从命令行下,客户端、数据库连接、查询结果的字符集设置没有变化

输入的中文经过一系列转码又转回初始的字符集,我们查看到的当然不是乱码

但这并不代表中文在数据库里被正确作为中文字符存储

举例来说,现在有一个utf8 编码数据库,客户端连接使用GBK 编码,connection 使用默认

的ISO8859-1(也就是mysql 中的latin1),我们在客户端发送"中文"这个字符串,客户端

将发送一串GBK 格式的二进制码给connection 层,connection 层以ISO8859-1 格式将这段

二进制码发送给数据库,数据库将这段编码以utf8 格式存储下来,我们将这个字段以utf8

格式读取出来,肯定是得到乱码,也就是说中文数据在写入数据库时是以乱码形式存储的,

在同一个客户端进行查询操作时,做了一套和写入时相反的操作,错误的utf8 格式二进制

码又被转换成正确的GBK 码并正确显示出来。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何使用Alter Table語句在MySQL中更改表? 如何使用Alter Table語句在MySQL中更改表? Mar 19, 2025 pm 03:51 PM

本文討論了使用MySQL的Alter Table語句修改表,包括添加/刪除列,重命名表/列以及更改列數據類型。

說明InnoDB全文搜索功能。 說明InnoDB全文搜索功能。 Apr 02, 2025 pm 06:09 PM

InnoDB的全文搜索功能非常强大,能够显著提高数据库查询效率和处理大量文本数据的能力。1)InnoDB通过倒排索引实现全文搜索,支持基本和高级搜索查询。2)使用MATCH和AGAINST关键字进行搜索,支持布尔模式和短语搜索。3)优化方法包括使用分词技术、定期重建索引和调整缓存大小,以提升性能和准确性。

如何為MySQL連接配置SSL/TLS加密? 如何為MySQL連接配置SSL/TLS加密? Mar 18, 2025 pm 12:01 PM

文章討論了為MySQL配置SSL/TLS加密,包括證書生成和驗證。主要問題是使用自簽名證書的安全含義。[角色計數:159]

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什麼? 哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什麼? Mar 21, 2025 pm 06:28 PM

文章討論了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比較了它們對初學者和高級用戶的功能和適合性。[159個字符]

您如何處理MySQL中的大型數據集? 您如何處理MySQL中的大型數據集? Mar 21, 2025 pm 12:15 PM

文章討論了處理MySQL中大型數據集的策略,包括分區,碎片,索引和查詢優化。

如何使用Drop Table語句將表放入MySQL中? 如何使用Drop Table語句將表放入MySQL中? Mar 19, 2025 pm 03:52 PM

本文討論了使用Drop Table語句在MySQL中放下表,並強調了預防措施和風險。它強調,沒有備份,該動作是不可逆轉的,詳細介紹了恢復方法和潛在的生產環境危害。

說明不同類型的MySQL索引(B樹,哈希,全文,空間)。 說明不同類型的MySQL索引(B樹,哈希,全文,空間)。 Apr 02, 2025 pm 07:05 PM

MySQL支持四種索引類型:B-Tree、Hash、Full-text和Spatial。 1.B-Tree索引適用於等值查找、範圍查詢和排序。 2.Hash索引適用於等值查找,但不支持範圍查詢和排序。 3.Full-text索引用於全文搜索,適合處理大量文本數據。 4.Spatial索引用於地理空間數據查詢,適用於GIS應用。

如何在JSON列上創建索引? 如何在JSON列上創建索引? Mar 21, 2025 pm 12:13 PM

本文討論了在PostgreSQL,MySQL和MongoDB等各個數據庫中的JSON列上創建索引,以增強查詢性能。它解釋了索引特定的JSON路徑的語法和好處,並列出了支持的數據庫系統。

See all articles