connect_test.c
上传用户:romrleung
上传日期:2022-05-23
资源大小:18897k
文件大小:2k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. /* Copyright (C) 2000 MySQL AB
  2.    This program is free software; you can redistribute it and/or modify
  3.    it under the terms of the GNU General Public License as published by
  4.    the Free Software Foundation; either version 2 of the License, or
  5.    (at your option) any later version.
  6.    This program is distributed in the hope that it will be useful,
  7.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  8.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  9.    GNU General Public License for more details.
  10.    You should have received a copy of the GNU General Public License
  11.    along with this program; if not, write to the Free Software
  12.    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
  13. #include <stdio.h>
  14. #include <stdlib.h>
  15. #include "mysql.h"
  16. static void change_user(MYSQL *sock,const char *user, const char *password,
  17. const char *db,my_bool warning)
  18. {
  19.   if (mysql_change_user(sock,user,password,db) != warning)
  20.   {
  21.     fprintf(stderr,"Couldn't change user to: user: '%s', password: '%s', db: '%s':  Error: %sn",
  22.     user, password ? password : "", db ? db : "",
  23.     mysql_error(sock));
  24.   }
  25. }
  26. int main(int argc, char **argv)
  27. {
  28.   MYSQL *sock;
  29.   if (!(sock=mysql_init(0)))
  30.   {
  31.     fprintf(stderr,"Couldn't initialize mysql structn");
  32.     exit(1);
  33.   }
  34.   mysql_options(sock,MYSQL_READ_DEFAULT_GROUP,"connect");
  35.   if (!mysql_real_connect(sock,NULL,NULL,NULL,NULL,0,NULL,0))
  36.   {
  37.     fprintf(stderr,"Couldn't connect to engine!n%sn",mysql_error(sock));
  38.     perror("");
  39.     exit(1);
  40.   }
  41.   if (mysql_select_db(sock,"test"))
  42.   {
  43.     fprintf(stderr,"Couldn't select database test: Error: %sn",
  44.     mysql_error(sock));
  45.   }
  46.   change_user(sock,"test_user","test_user","test",0);
  47.   change_user(sock,"test",NULL,"test",0);
  48.   change_user(sock,"test_user",NULL,"test",1);
  49.   change_user(sock,"test_user",NULL,NULL,1);
  50.   change_user(sock,"test_user","test_user","mysql",1);
  51.   mysql_close(sock);
  52.   exit(0);
  53.   return 0;
  54. }