电脑上怎么安装两个mysql数据库?
(推荐教程:mysql视频教程)
在实际开发中,一些低版本数据库,不支持一些特殊的sql语句,因此高版本数据库数据导入低版本的时候就会出问题,因此,在一些特殊情况下,低版本数据库不能动,高版本mysql数据又无法导入低版本mysql,我们不得不在同一台机器上安装两个版本mysql.
低版本mysql不支持的sql语句举例,比如下面的这个:
CREATE TABLE `storage` ( `storageid` INT(11) NOT NULL AUTO_INCREMENT, `createTime` TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP, `updateTime` TIMESTAMP NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`storageid`) ) ENGINE=INNODB AUTO_INCREMENT=292 DEFAULT CHARSET=utf8 COMMENT='仓库'
在5.1版本的mysql上执行上面语句会报错
而在5.7版本的mysql就支持双时间戳timestamp.可以正常执行上述sql语句
正文正式开始:
一 先停止之前安装的低版本mysql服务:
二 将我其他电脑上安装好的mysql5.7拷贝过来(我在其他电脑上安装过mysql-5.7.22-winx64.zip版本)
三 拷贝过来之后,进入该文件夹,删除掉data目录,然后打开my.ini,进行修改端口号,端口号改为3307,basedir和datadir也要重新配一下
修改内容如图:
配置文件内容想要的可以拿去:------>
[mysqld] port = 3307 basedir=C:\mysql-5.7.22-winx64 datadir=C:\mysql-5.7.22-winx64\data max_connections=200 character-set-server=utf8 default-storage-engine=INNODB sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES [mysql] default-character-set=utf8
四 开始执行安装和添加服务的步骤:
4.1 以管理员身份去运行命令行窗口
4.2 进入mysql5.7的bin目录下
4.3 安装mysql服务,指定该mysql服务名为mysql2,并根据my.ini文件进行安装,命令如下:
C:\mysql-5.7.22-winx64\bin>mysqld install mysql2 --default-file="C:\mysql-5.7.22-winx64\my.ini" 成功安装后会提示: Service successfully installed.
去服务里面,可查看到此时多了一个mysql2服务
五 初始化数据库
mysql服务安装成功后,就需要初始化数据库了,否则是无法启动服务的。
在bin目录下执行如下命令
C:\mysql-5.7.22-winx64\bin>mysqld --initialize
初始化成功后,命令行没有任何提示。但在mysql5.7文件夹中已自动生成了data目录
六 打开注册表,找到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\mysql2,修改ImagePath参数,更正mysql2服务相关路径。
修改ImagePath参数:
七 启动数据库,修改密码
使用net start mysql2 命令启动mysql2服务
C:\mysql-5.7.22-winx64\bin>net start mysql2 mysql2 服务正在启动 . mysql2 服务已经启动成功。
(若mysql2 启动失败,请检查自己是否已经停止了之前的mysql服务,见第一步)
mysql2服务启动后,去data/xxx.err文件中找到临时密码,进行登录
使用临时密码进行登录(注意:P 端口,p 密码)
C:\mysql-5.7.22-winx64\bin>mysql -P3307 -uroot -p
Enter password: ************ (此处输入的是临时密码)
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.22Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
修改密码
mysql> set password for root@localhost=password('001nX123456'); Query OK, 0 rows affected, 1 warning (0.00 sec)
使用 quit 退出,使用新密码登录。
mysql> quit Bye C:\mysql-5.7.22-winx64\bin>mysql -P3307 -uroot -p Enter password: ************* Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 3 Server version: 5.7.22 MySQL Community Server (GPL)
结束。
Atas ialah kandungan terperinci 电脑上怎么安装两个mysql数据库?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Pengoptimuman prestasi pertanyaan MySQL perlu bermula dari titik teras, termasuk penggunaan indeks rasional, pengoptimuman penyata SQL, reka bentuk struktur meja dan strategi pembahagian, dan penggunaan alat cache dan pemantauan. 1. Gunakan indeks dengan munasabah: Buat indeks pada medan pertanyaan yang biasa digunakan, elakkan pengimbasan jadual penuh, perhatikan urutan indeks gabungan, jangan tambah indeks dalam medan terpilih yang rendah, dan elakkan indeks berlebihan. 2. Mengoptimumkan pertanyaan SQL: Elakkan pilih*, jangan gunakan fungsi di mana, mengurangkan bersarang subquery, dan mengoptimumkan kaedah pertanyaan paging. 3. Reka Bentuk dan Pembahagian Struktur Jadual: Pilih paradigma atau anti-paradigma mengikut senario membaca dan menulis, pilih jenis medan yang sesuai, data bersih secara teratur, dan pertimbangkan jadual mendatar untuk membahagikan jadual atau partition mengikut masa. 4. Menggunakan cache dan pemantauan: Gunakan cache redis untuk mengurangkan tekanan pangkalan data dan membolehkan pertanyaan perlahan

1. 2. Prestasi tinggi memerlukan pergantungan pada cache (redis), pengoptimuman pangkalan data, CDN dan giliran tak segerak; 3. Keselamatan mesti dilakukan dengan penapisan input, perlindungan CSRF, HTTPS, penyulitan kata laluan dan kawalan kebenaran; 4. Pengiklanan pilihan wang, langganan ahli, ganjaran, komisen, pembayaran pengetahuan dan model lain, terasnya adalah untuk memadankan nada komuniti dan keperluan pengguna.

CTE adalah hasil sementara yang ditetapkan dalam MySQL yang digunakan untuk memudahkan pertanyaan kompleks. Ia boleh dirujuk beberapa kali dalam pertanyaan semasa, meningkatkan kebolehbacaan dan penyelenggaraan kod. Sebagai contoh, apabila mencari pesanan terkini untuk setiap pengguna dalam jadual pesanan, anda boleh terlebih dahulu mendapatkan tarikh pesanan terkini untuk setiap pengguna melalui CTE, dan kemudian mengaitkannya dengan jadual asal untuk mendapatkan rekod lengkap. Berbanding dengan subqueries, struktur CTE lebih jelas dan logik lebih mudah untuk debug. Petua penggunaan termasuk alias eksplisit, menggabungkan pelbagai CTE, dan memproses data pokok dengan CTE rekursif. Menguasai CTE boleh menjadikan SQL lebih elegan dan cekap.

Whensettingupmysqltables, memilihTheRightDatypesiscialforfiencyandscalability.1) pemahamanThedataeachcolumnwillstore-umbers, text, date, orflags-andchooseaccordingly.2)

Jadual sementara adalah jadual dengan skop terhad, dan jadual memori adalah jadual dengan kaedah penyimpanan yang berbeza. Jadual sementara dapat dilihat dalam sesi semasa dan secara automatik dipadamkan selepas sambungan diputuskan. Pelbagai enjin penyimpanan boleh digunakan, yang sesuai untuk menjimatkan hasil pertengahan dan mengelakkan pengiraan berulang; 1. Jadual sementara menyokong pengindeksan, dan beberapa sesi boleh membuat jadual dengan nama yang sama tanpa menjejaskan satu sama lain; 2. Jadual memori menggunakan enjin memori, dan data disimpan dalam ingatan, dan permulaannya hilang, yang sesuai untuk set data kecil cache dengan akses frekuensi tinggi; 3. Jadual memori menyokong pengindeksan hash, dan tidak menyokong jenis gumpalan dan teks, jadi anda perlu memberi perhatian kepada penggunaan memori; 4. Kitaran hayat jadual sementara adalah terhad kepada sesi semasa, dan jadual memori dikongsi oleh semua sambungan. Apabila memilih, ia harus diputuskan berdasarkan sama ada data itu adalah peribadi, sama ada akses berkelajuan tinggi diperlukan dan sama ada ia boleh mentolerir kerugian.

Langkah-langkah untuk menetapkan replikasi semi mysql adalah seperti berikut: 1. Sahkan versi menyokong dan memuatkan pemalam; 2. Hidupkan dan aktifkan mod separa sinkron; 3. Periksa status status dan operasi; 4. Perhatikan tetapan masa tamat, konfigurasi perpustakaan multi-hamba dan pemprosesan suis master-hamba. Adalah perlu untuk memastikan bahawa versi mysql 5.5 dan ke atas dipasang, rpl_semi_sync_master

Untuk mencapai automasi penempatan MySQL, kunci adalah menggunakan Terraform untuk menentukan sumber, konfigurasi pengurusan ansible, Git untuk kawalan versi, dan mengukuhkan pengurusan keselamatan dan kebenaran. 1. Gunakan Terraform untuk menentukan contoh MySQL, seperti versi, jenis, kawalan akses dan atribut sumber lain AWSRDS; 2. Gunakan AnsiblePlayBook untuk merealisasikan konfigurasi terperinci seperti penciptaan pengguna pangkalan data, tetapan kebenaran, dan lain -lain; 3. Semua fail konfigurasi dimasukkan dalam pengurusan Git, pengesanan perubahan sokongan dan pembangunan kolaboratif; 4. Elakkan maklumat sensitif keras, gunakan Vault atau Ansiblevault untuk menguruskan kata laluan, dan tetapkan kawalan akses dan prinsip kebenaran minimum.

Kesalahan MySQL "IncorrectstringValueForColumn" biasanya kerana set aksara medan tidak menyokong aksara empat-bait seperti emoji. 1. Sebab kesilapan: Set aksara UTF8 MySQL hanya menyokong aksara tiga-bait dan tidak dapat menyimpan emoji empat-bait; 2. Penyelesaian: Tukar pangkalan data, jadual, medan dan sambungan ke set aksara UTF8MB4; 3. Juga periksa sama ada fail konfigurasi, jadual sementara, pengekodan lapisan aplikasi dan pemandu pelanggan semua menyokong UTF8MB4; 4. Penyelesaian Alternatif: Jika anda tidak perlu menyokong aksara empat-bait, anda boleh menapis aksara khas seperti emoji pada lapisan aplikasi.
