ให้เรตสมาชิก: 3 / 5

ดาวใช้งานดาวใช้งานดาวใช้งานดาวไม่ได้ใช้งานดาวไม่ได้ใช้งาน
 

mysqli_change_user()

ในการจัดการกับระบบฐานข้อมูลนั้นเราจำเป็นต้องระบุผู้ใช้รวามถึงรหัสผ่านเพื่อเข้าถึงฐานข้อมูลนั้นได้ โดยปกติแล้วในการกำหนดผู้ใช้จะถูกกำนดในช่วงของการติดตั้งฐานข้อมูล  เราสามารถปรับเปลี่ยนผู้ใช้ให้เชื่อมกับฐานข้อมูลตัวอื่นได้โดยใช้ ฟังก์ชัน mysqli_change_user()

 

ฟังก์ชัน mysqli_change_user เป็นฟังก์ชันที่ใช้เพื่อเปลี่ยนผู้ใช้ในการเชื่อมต่อฐานข้อมูลที่ระบุหรือต้องการ  ซึ่งมีรูปแบบ syntex ดังนี้ 

mysqli_change_user ( mysqli $link , string $user , string $password , string $database ) : bool

เปลี่ยนผู้ใช้ของการเชื่อมต่อฐานข้อมูลที่ระบุและตั้งค่าฐานข้อมูลปัจจุบัน

เพื่อไม่ให้เกิดข้อผิดพลาดในการเปลี่ยนผู้ใช้    พารามิเตอร์ username และ password จะต้องระบุให้ครบถ้วนและผู้ใช้ต้องมีสิทธิ์เพียงพอในการเข้าถึงฐานข้อมูลที่ต้องการ  หากเกิดความล้มเหลวในการเปลี่ยนไม่ว่าด้วยเหตุผลใด ๆ ผู้ใช้เดิมจะยังคงใช้งานได้อยู่

Parameters

  • link   :  รูปแบบขั้นตอนเท่านั้น: ตัวระบุลิงก์ที่ส่งคืนโดยการใช้งานฟังก์ชัน mysqli_connect()  หรือ mysqli_init()
  • user    :    ชื่อผู้ใช้ MySQL
  • password  :  รหัสผ่าน MySQL
  • database   :   ฐานข้อมูลที่จะเปลี่ยน

ค่า NULL อาจถูกส่งผ่านทำให้มีการเปลี่ยนแปลงเฉพาะผู้ใช้เท่านั้นและจะไม่เลือกฐานข้อมูล ในกรณีนี้หากต้องการเลือกฐานข้อมูลให้ใช้ฟังก์ชัน mysqli_select_db() 

การคืนค่า จะคืนค่าTRUE หากสำเร็จหรือ FALSE เมื่อเกิดความล้มเหลว

 ตัวอย่างโค้ดดังนี้

<?php
/* connect database test */
$link = mysqli_connect("localhost", "my_user", "my_password", "test");

/* check connection */
if (!$link) {
    printf("Connect failed: %s\n", mysqli_connect_error());
    exit();
}

/* Set Variable a */
mysqli_query($link, "SET @a:=1");

/* reset all and select a new database */
mysqli_change_user($link, "my_user", "my_password", "world");

if ($result = mysqli_query($link, "SELECT DATABASE()")) {
    $row = mysqli_fetch_row($result);
    printf("Default database: %s\n", $row[0]);
    mysqli_free_result($result);
}

if ($result = mysqli_query($link, "SELECT @a")) {
    $row = mysqli_fetch_row($result);
    if ($row[0] === NULL) {
        printf("Value of variable a is NULL\n");
    }
    mysqli_free_result($result);
}

/* close connection */
mysqli_close($link);
?>

 ผลลัพธ์ที่ได้  

Default database: world
Value of variable a is NULL

 จะผลลัพธ์จะเห็นได้ว่า ฐานข้อมูลเริ่มต้นถูกเปลี่ยนเป็น "world" จากเดิมที่เป็น "test"  และค่าของตัวแปร a เท่ากับ  NULL จากเดิมที่เรา set ให้ a=1 แสดงให้เห็นว่าฐานข้อมูลตอนนี้ถูกเปลี่ยนให้ผู้ใช้เดิมมาเชื่อมต่อหรือเข้าถึงได้เรียบร้อยแล้ว

 

 

ช่องทางการศึกษาเพิ่มเติมข่าวที่น่าสนใจเกี่ยวกับ : ฟังก์ชัน PHP

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
c# example formt digit
โดย jataz2 อ 14 ก.ค. 2020 10:29 am บอร์ด Programming - C/C++ & java & Python
0
6
อ 14 ก.ค. 2020 10:29 am โดย jataz2
c# example read csv file
โดย jataz2 อ 14 ก.ค. 2020 10:20 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
4
อ 14 ก.ค. 2020 10:20 am โดย jataz2
งานประจำวันที่ 14 กรกฏาคม 2563
โดย Phakakrong อ 14 ก.ค. 2020 9:36 am บอร์ด M105 - ผกากรอง กุสาวดี
0
6
อ 14 ก.ค. 2020 9:36 am โดย Phakakrong
การเขียนโพสต์แชร์ในบอร์ดด้วยรูปแบบที่ถูกต้อง
โดย Phakakrong จ 13 ก.ค. 2020 5:33 pm บอร์ด Share Knowledge
0
16
จ 13 ก.ค. 2020 5:33 pm โดย Phakakrong
สรุปการศึกษา Work Instruction Logged Calls รับ / โทรออก
โดย Phakakrong จ 13 ก.ค. 2020 2:52 pm บอร์ด M105 - ผกากรอง กุสาวดี
0
11
จ 13 ก.ค. 2020 2:52 pm โดย Phakakrong
ขอความช่วยเหลือ ดู Code สไลด์ แบบมีลูกศรกดด้านข้างครับ
โดย dzjp จ 13 ก.ค. 2020 2:43 pm บอร์ด Programming - PHP
0
12
จ 13 ก.ค. 2020 2:43 pm โดย dzjp
ร่วมใจให้ชุมชนดีเด่นกับโครงการธนาคารเห็ด
โดย medalezga จ 13 ก.ค. 2020 12:12 pm บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
24
จ 13 ก.ค. 2020 12:12 pm โดย medalezga
การนำเอาข้อมูลหลายๆ Sheet(Excel ) มารวมกันด้วย Power Query
โดย Phakakrong จ 13 ก.ค. 2020 11:37 am บอร์ด Microsoft Office Knowledge & line & Etc
0
18
จ 13 ก.ค. 2020 11:37 am โดย Phakakrong
งานประจำวันที่ 13 กรกฏาคม 2563
โดย Phakakrong จ 13 ก.ค. 2020 9:43 am บอร์ด M105 - ผกากรอง กุสาวดี
4
58
จ 13 ก.ค. 2020 7:03 pm โดย Phakakrong
ถ้าต้องการจะส่งเมล เเล้วแนบไฟล์ไปด้วยใน phpbb ทำยังไงคะ
โดย thatsawan ส 11 ก.ค. 2020 11:33 am บอร์ด Programming - PHP
6
99
จ 13 ก.ค. 2020 11:04 pm โดย thatsawan
การเพิ่มกรอบจอโทรศัพท์มือถือบน Google Chrome
โดย natthanit.r2538 ส 11 ก.ค. 2020 10:41 am บอร์ด Share Knowledge
0
18
ส 11 ก.ค. 2020 10:41 am โดย natthanit.r2538
งานประจำวันที่ 11 กรกฏาคม 2563
โดย Phakakrong ส 11 ก.ค. 2020 9:22 am บอร์ด M105 - ผกากรอง กุสาวดี
3
24
ส 11 ก.ค. 2020 6:48 pm โดย Phakakrong
ถ้าต้องการเช็คค่าว่าง select ให้ alert ก่อนก่อนปุ่มอื่นๆ ทำยังไงได้บ้างคะ
โดย thatsawan ศ 10 ก.ค. 2020 4:18 pm บอร์ด JavaScript & Jquery Ajax
1
50
ศ 10 ก.ค. 2020 4:59 pm โดย tsukasaz
งานประจำวันที่ 10 กรกฏาคม 2563
โดย Phakakrong ศ 10 ก.ค. 2020 9:35 am บอร์ด M105 - ผกากรอง กุสาวดี
5
24
ศ 10 ก.ค. 2020 7:58 pm โดย Phakakrong
Google Sheet : วิธีการเปลี่ยนภาษา (ไทย เป็น อังกฤษ)
โดย Phakakrong พฤ 09 ก.ค. 2020 6:34 pm บอร์ด Share Knowledge
0
28
พฤ 09 ก.ค. 2020 6:34 pm โดย Phakakrong
มาลองใช้งาน Google Drive กันแบบฉบับง่ายๆ
โดย Phakakrong พฤ 09 ก.ค. 2020 4:08 pm บอร์ด Microsoft Office Knowledge & line & Etc
0
29
พฤ 09 ก.ค. 2020 4:08 pm โดย Phakakrong
ข้อมูลไม่ขึ้นมาแสดง รบกวนช่วยดูโค้ดให้ทีคะ คือทำหน้าแบบฟอร์ม แล้วต้องการแก้ไขข้อมูลตามไอดี
โดย Jakkrit Saengngoenon พฤ 09 ก.ค. 2020 1:24 pm บอร์ด Programming - PHP
0
50
พฤ 09 ก.ค. 2020 1:24 pm โดย Jakkrit Saengngoenon
งานประจำวันที่ 9 กรกฏาคม 2563
โดย Phakakrong พฤ 09 ก.ค. 2020 9:40 am บอร์ด M105 - ผกากรอง กุสาวดี
1
28
พฤ 09 ก.ค. 2020 6:51 pm โดย Phakakrong
สรุปผลการเรียน Process help desk
โดย Phakakrong พ 08 ก.ค. 2020 7:05 pm บอร์ด M105 - ผกากรอง กุสาวดี
1
12
พฤ 09 ก.ค. 2020 10:29 am โดย Phakakrong
ISO 29110 คืออะไร มาตรฐานที่ให้การรับรองคุณภาพการบริหารงาน หรือผลิตภัณฑ์ซอร์ฟแวร์ มีขั้นตอนการขออย่างไหร่
โดย natthanit.r2538 พ 08 ก.ค. 2020 7:02 pm บอร์ด Microsoft Office Knowledge & line & Etc
1
41
พ 08 ก.ค. 2020 9:59 pm โดย UoIU112