Rumah pangkalan data tutorial mysql MySQL 建库、建用户及建表事项

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

May 31, 2016 am 08:49 AM

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

1

1 create database tppamltest3

Salin selepas log masuk

2,创建用户及授权:

1

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;

Salin selepas log masuk

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

3,建表脚本:

1

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;

Salin selepas log masuk

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

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

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

一些异常情况的处理

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

乱码问题:

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

1

show variables like '%character%';

Salin selepas log masuk

1

+--------------------------+-------------------------------------+| 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)

Salin selepas log masuk

可以更改

1

set character_set_client = 字符集

Salin selepas log masuk

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

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

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 码并正确显示出来。

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bilakah imbasan jadual penuh lebih cepat daripada menggunakan indeks di MySQL? Bilakah imbasan jadual penuh lebih cepat daripada menggunakan indeks di MySQL? Apr 09, 2025 am 12:05 AM

Pengimbasan jadual penuh mungkin lebih cepat dalam MySQL daripada menggunakan indeks. Kes -kes tertentu termasuk: 1) jumlah data adalah kecil; 2) apabila pertanyaan mengembalikan sejumlah besar data; 3) Apabila lajur indeks tidak selektif; 4) Apabila pertanyaan kompleks. Dengan menganalisis rancangan pertanyaan, mengoptimumkan indeks, mengelakkan lebih banyak indeks dan tetap mengekalkan jadual, anda boleh membuat pilihan terbaik dalam aplikasi praktikal.

Bolehkah saya memasang mysql pada windows 7 Bolehkah saya memasang mysql pada windows 7 Apr 08, 2025 pm 03:21 PM

Ya, MySQL boleh dipasang pada Windows 7, dan walaupun Microsoft telah berhenti menyokong Windows 7, MySQL masih serasi dengannya. Walau bagaimanapun, perkara berikut harus diperhatikan semasa proses pemasangan: Muat turun pemasang MySQL untuk Windows. Pilih versi MySQL yang sesuai (komuniti atau perusahaan). Pilih direktori pemasangan yang sesuai dan set aksara semasa proses pemasangan. Tetapkan kata laluan pengguna root dan simpan dengan betul. Sambung ke pangkalan data untuk ujian. Perhatikan isu keserasian dan keselamatan pada Windows 7, dan disyorkan untuk menaik taraf ke sistem operasi yang disokong.

Terangkan keupayaan carian teks penuh InnoDB. Terangkan keupayaan carian teks penuh InnoDB. Apr 02, 2025 pm 06:09 PM

Keupayaan carian teks penuh InnoDB sangat kuat, yang dapat meningkatkan kecekapan pertanyaan pangkalan data dan keupayaan untuk memproses sejumlah besar data teks. 1) InnoDB melaksanakan carian teks penuh melalui pengindeksan terbalik, menyokong pertanyaan carian asas dan maju. 2) Gunakan perlawanan dan terhadap kata kunci untuk mencari, menyokong mod boolean dan carian frasa. 3) Kaedah pengoptimuman termasuk menggunakan teknologi segmentasi perkataan, membina semula indeks dan menyesuaikan saiz cache untuk meningkatkan prestasi dan ketepatan.

Perbezaan antara indeks kluster dan indeks bukan clustered (indeks sekunder) di InnoDB. Perbezaan antara indeks kluster dan indeks bukan clustered (indeks sekunder) di InnoDB. Apr 02, 2025 pm 06:25 PM

Perbezaan antara indeks clustered dan indeks bukan cluster adalah: 1. Klustered Index menyimpan baris data dalam struktur indeks, yang sesuai untuk pertanyaan oleh kunci dan julat utama. 2. Indeks Indeks yang tidak berkumpul indeks nilai utama dan penunjuk kepada baris data, dan sesuai untuk pertanyaan lajur utama bukan utama.

Mysql: Konsep mudah untuk pembelajaran mudah Mysql: Konsep mudah untuk pembelajaran mudah Apr 10, 2025 am 09:29 AM

MySQL adalah sistem pengurusan pangkalan data sumber terbuka. 1) Buat Pangkalan Data dan Jadual: Gunakan perintah Createdatabase dan Createtable. 2) Operasi Asas: Masukkan, Kemas kini, Padam dan Pilih. 3) Operasi lanjutan: Sertai, subquery dan pemprosesan transaksi. 4) Kemahiran Debugging: Semak sintaks, jenis data dan keizinan. 5) Cadangan Pengoptimuman: Gunakan indeks, elakkan pilih* dan gunakan transaksi.

Hubungan antara pengguna dan pangkalan data MySQL Hubungan antara pengguna dan pangkalan data MySQL Apr 08, 2025 pm 07:15 PM

Dalam pangkalan data MySQL, hubungan antara pengguna dan pangkalan data ditakrifkan oleh kebenaran dan jadual. Pengguna mempunyai nama pengguna dan kata laluan untuk mengakses pangkalan data. Kebenaran diberikan melalui perintah geran, sementara jadual dibuat oleh perintah membuat jadual. Untuk mewujudkan hubungan antara pengguna dan pangkalan data, anda perlu membuat pangkalan data, membuat pengguna, dan kemudian memberikan kebenaran.

Terangkan pelbagai jenis indeks MySQL (B-Tree, Hash, Full-Text, Spatial). Terangkan pelbagai jenis indeks MySQL (B-Tree, Hash, Full-Text, Spatial). Apr 02, 2025 pm 07:05 PM

MySQL menyokong empat jenis indeks: B-Tree, Hash, Full-Text, dan Spatial. 1. B-Tree Index sesuai untuk carian nilai yang sama, pertanyaan dan penyortiran. 2. Indeks hash sesuai untuk carian nilai yang sama, tetapi tidak menyokong pertanyaan dan penyortiran pelbagai. 3. Indeks teks penuh digunakan untuk carian teks penuh dan sesuai untuk memproses sejumlah besar data teks. 4. Indeks spatial digunakan untuk pertanyaan data geospatial dan sesuai untuk aplikasi GIS.

Bolehkah Mysql dan Mariadb wujud bersama Bolehkah Mysql dan Mariadb wujud bersama Apr 08, 2025 pm 02:27 PM

MySQL dan Mariadb boleh wujud bersama, tetapi perlu dikonfigurasikan dengan berhati -hati. Kuncinya adalah untuk memperuntukkan nombor port dan direktori data yang berbeza untuk setiap pangkalan data, dan menyesuaikan parameter seperti peruntukan memori dan saiz cache. Konfigurasi sambungan, konfigurasi aplikasi, dan perbezaan versi juga perlu dipertimbangkan dan perlu diuji dengan teliti dan dirancang untuk mengelakkan perangkap. Menjalankan dua pangkalan data secara serentak boleh menyebabkan masalah prestasi dalam situasi di mana sumber terhad.

See all articles