답변 2개
채택된 답변
+20 포인트
6년 전
function drop_column($find, $position = 0) {
$sql =" SELECT table_name FROM information_schema.tables where table_schema= `" . G5_MYSQL_DB . "`";
$result = sql_query($sql);
$report = '';
while ($row = sql_fetch_array($result)) {
$sql_1 = ' describe ' . $row['table_name'];
$result_1 = sql_query($sql_1);
while ($row_1 = sql_fetch_array($result_1)) {
$flag = false;
switch ($position) {
case 1:
$flag = strpos($row_1['Field'], $find) === 0;
break;
case 2:
$flag = substr($row_1['Field'], - strlen($find)) == $find;
break;
case 0:
$flag = strpos($row_1['Field'], $find) !== false;
break;
}
if ($flag) {
$sql = " ALTER TABLE `{$row['table_name']}` DROP COLUMN `{$row_1['Field']}` ";
if (sql_query($sql))
$report .= $row['table_name'] . ' : ' . $row_1['Field'] . '
';
}
}
}
return $report;
}</p>
<p>/**
* drop_column('검색어', 찾는조건)
* drop_column('검색어', 1) 접두어
* drop_column('검색어', 2) 접미어
* drop_column('검색어') 전체
*/
echo drop_column('sir_', 1); </p>
<p>
로그인 후 평가할 수 있습니다
답변에 대한 댓글 3개
s
sinbi
6년 전
�
슈와이
6년 전
// 수정본
<?php
include_once('./_common.php');
function drop_column($find, $position = 0) {
$sql =" SELECT table_name FROM information_schema.tables where table_schema='" . G5_MYSQL_DB . "'";
$result = sql_query($sql, true);
$report = '';
while ($row = sql_fetch_array($result)) {
$sql_1 = ' describe ' . $row['table_name'];
$result_1 = sql_query($sql_1, true);
while ($row_1 = sql_fetch_array($result_1)) {
$flag = false;
switch ($position) {
case 1:
$flag = strpos($row_1['Field'], $find) === 0;
break;
case 2:
$flag = substr($row_1['Field'], - strlen($find)) == $find;
break;
case 0:
$flag = strpos($row_1['Field'], $find) !== false;
break;
}
if ($flag) {
$sql = " ALTER TABLE `{$row['table_name']}` DROP COLUMN `{$row_1['Field']}` ";
if (sql_query($sql, true))
$report .= $row['table_name'] . ' : ' . $row_1['Field'] . '<br>';
}
}
}
return $report;
}
/**
* drop_column('검색어', 찾는조건)
* drop_column('검색어', 1) 접두어
* drop_column('검색어', 2) 접미어
* drop_column('검색어') 전체
*/
echo drop_column('sir_', 1);
?>
<?php
include_once('./_common.php');
function drop_column($find, $position = 0) {
$sql =" SELECT table_name FROM information_schema.tables where table_schema='" . G5_MYSQL_DB . "'";
$result = sql_query($sql, true);
$report = '';
while ($row = sql_fetch_array($result)) {
$sql_1 = ' describe ' . $row['table_name'];
$result_1 = sql_query($sql_1, true);
while ($row_1 = sql_fetch_array($result_1)) {
$flag = false;
switch ($position) {
case 1:
$flag = strpos($row_1['Field'], $find) === 0;
break;
case 2:
$flag = substr($row_1['Field'], - strlen($find)) == $find;
break;
case 0:
$flag = strpos($row_1['Field'], $find) !== false;
break;
}
if ($flag) {
$sql = " ALTER TABLE `{$row['table_name']}` DROP COLUMN `{$row_1['Field']}` ";
if (sql_query($sql, true))
$report .= $row['table_name'] . ' : ' . $row_1['Field'] . '<br>';
}
}
}
return $report;
}
/**
* drop_column('검색어', 찾는조건)
* drop_column('검색어', 1) 접두어
* drop_column('검색어', 2) 접미어
* drop_column('검색어') 전체
*/
echo drop_column('sir_', 1);
?>
s
sinbi
6년 전
방금 한방에 깨끗이 청소가 되었습니다.
덕분에 DB가 아주 깨끗해 졌습니다. ^^
감사해용. ( ^ ________ ^ ) ======b
덕분에 DB가 아주 깨끗해 졌습니다. ^^
감사해용. ( ^ ________ ^ ) ======b
댓글을 작성하려면 로그인이 필요합니다.
6년 전
알려주신 링크의 '왕계란'님의 답을 응용하는 개념으로 컬럼을 삭제하시려면
Alter table 테이블명 drop colunm 컬럼명 ;
명령이 있습니다.
https://www.w3schools.com/sql/sql_alter.asp
를 참고해보세요
로그인 후 평가할 수 있습니다
답변에 대한 댓글 1개
s
sinbi
6년 전
sql 낱개 구문, php 반복 구문...다 ...공부 한 건데....
제 실력의 한계가 응용력 부족인지라..... ^^;;;
제 실력의 한계가 응용력 부족인지라..... ^^;;;
댓글을 작성하려면 로그인이 필요합니다.
답변을 작성하려면 로그인이 필요합니다.
로그인
매번 좋은 코드 선물 주셔서 감사합니다.