前些时候,写的代码(数据库添加数据I),往数据库添加数据都是很基本的一条一条地添加。但是平常用于测试时,总不可能一条一条地添加测试数据吧,然后我就尝试着一次性添加几百上千条,但是再次操作的时候,就出问题了。因为平常看书的时候,都只是一瞥而过,而且书上写的基本都是函数原型,函数原型相当‘简单’!但是用的时候就容易出错了,所以特意写一篇如何往数据库添加数据。

首先在test数据库中建一个users表,users(UserID,UserName,UserStatus),下划线表示主键,然后开始进行操作,代码见下:

首先是最常用的“一条一条地添加”:

<!DOCTYPE html>
<html>
<head>
	<meta charset="UTF-8">
	<title>Document</title>
</head>
<body>
	<form action='insert.php' method='post'>
		<p>编号:<input type='text' name='UserID'></p>
		<p>姓名:<input type='text' name='UserName'></p>
		<p>状态:<input type='text' name='UserStatus'></p>
		<p><input type='submit' name='submit' value='保存'><input type='reset' name='reset' value='重置'></p>
	</form>
</body>
</html>

insert.php代码如下:

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>insert</title>
</head>
<body>
<?php
	mysql_connect('localhost','root','root') or die(mysql_error());
	mysql_select_db('test')  or die(mysql_error());
	mysql_query('set names utf8');
	if(isset($_POST['submit'])){
	 	$UserID=$_POST['UserID'];
		$UserName=$_POST['UserName'];
		$UserStatus=$_POST['UserStatus'];

		//错误的
		//$sql="insert into users set UserID=$UserID,UserName=$UserName,UserStatus=$UserStatus";

		//正确
		//$sql="insert into users (UserID,UserName,UserStatus) values($UserID,'$UserName',$UserStatus)";

		//正确
		//$sql="insert into users set UserID=$UserID,UserName='$UserName',UserStatus=$UserStatus";

		//正确
		$sql="insert into users set UserID='$UserID',UserName='$UserName',UserStatus=$UserStatus";

		$result=mysql_query($sql);
		if($result){
			echo "<script>alert('添加成功!');</script>";
		} else{
			echo "<script>alert('添加失败!');</script>";
		}
} ?> </body> </html>

注意在写SQL语句的时候,一定要注意单引号和双引号的使用:对于字符串,必须用引号包含;数字可以用,也可以不用。最重要的一点便是,双引号与单引号同时嵌套使用的时候,一定要注意不要弄混,必须遵从“双引号包含单引号”或者“单引号包含双引号”,绝对不能下面这三个例子(全是错误的):

$sql="insert into users set UserID=$UserID,UserName="$UserName",UserStatus=$UserStatus";
$sql='insert into users set UserID=$UserID,UserName='$UserName',UserStatus=$UserStatus';
$sql="insert into users set UserID=$UserID,UserName='$UserName",UserStatus=$UserStatus";

添加多个,代码如下:

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>insert</title>
</head>
<body>
	<?php
		$conn=mysql_connect("localhost","root","root")or die("数据库连接失败");
		$select_db=mysql_select_db("test")or die("选择数据库失败");
		mysql_query("set names utf8");

		$sql="insert into page (ID,NAME) values ";
		$s='';
		for($i=1;$i<=200;$i++){
			if($i!=200){
				$s.="('$i','name$i'),";
			} else {
			$s.="('$i','name$i')";
			}
		}
		$sql=$sql.$s;
		$result=mysql_query($sql);
		if($result){
			echo "YES";
		} else {
			echo "添加失败"."<br>".mysql_error();
		}
	 ?>
</body>
</html>

数据库添加数据II及SQL语句错误的更多相关文章

  1. 1.4 数据库和常用SQL语句(正文)——MySQL数据库命令和SQL语句

    前面我们已经讲述了,登录时,我们使用mysql –u root –p命令进行,此时如果设置了密码,则需要输入密码. 输入密码后即进入MySQL的操作界面,此时,命令行窗体左侧显示"mysql ...

  2. 项目总结04:SQL批量导入数据:将具有多表关联的Excel数据,通过sql语句脚本的形式,导入到数据库

    将具有多表关联的Excel数据,通过sql语句脚本的形式,导入到数据库 写在前面:本文用的语言是java:数据库是MySql: 需求:在实际项目中,经常会被客户要求,做批量导入数据:一般的简单的单表数 ...

  3. (转载)异构数据库之间完全可以用SQL语句导数据

    <来源网址:http://www.delphifans.com/infoview/Article_398.html>异构数据库之间完全可以用SQL语句导数据 告诉你一个最快的方法,用SQL ...

  4. 使用C#类向数据库添加数据的例子源码

    在上一篇中,增加了sql server数据库操作类SqlOperator,用于操作sql server数据库.还有一个SqlStringHelper类,用于处理sql语句的单引号.那么这两个类怎么使用 ...

  5. 使用excel中的数据快速生成sql语句

    在小公司的话,总是会有要开发去导入历史数据(数据从旧系统迁移到新系统上)的时候.这个时候,现场实施或客户会给你一份EXCEL文档,里面包含了一些别的系统上的历史数据,然后就让你导入到现在的系统上面去. ...

  6. 如何在MyEclipse中通过hibernate使用jtds驱动连接数据库,并向数据库添加数据的方法

    最近学习了下如何在MyEclipse中通过hibernate使用jtds驱动连接数据库,并向数据库添加数据的方法,虽然MyEclipse中自带了连接数据库的方法,我也尝试了下其他方法,如有不当之处请指 ...

  7. Mysql下在某一列后即表的某一位置添加新列的sql语句

    Mysql简介 MySQL是一个开放源码的小型关联式数据库管理系统,开发者为瑞典MySQL AB公司.MySQL被广泛地应用在Internet上的中小型网站中.由于其体积小.速度快.总体拥有成本低,尤 ...

  8. Oracle数据库查找持有锁的SQL语句,而不是请求锁的SQL语句(原创)

    Oracle数据库查找持有锁的SQL语句,而不是请求锁的SQL语句 查找活动的事务以及活动事务关联的会话信息 select s.sid 会话ID, s.serial# 会话序列号, s.usernam ...

  9. 学习Angularjs向数据库添加数据

    今天学习angularjs向数据库添加数据. 学习此篇,得从以往几篇开始,因为那还有创建数据表等演示. 现在来创建一个添加的存储过程: SET ANSI_NULLS ON GO SET QUOTED_ ...

随机推荐

  1. Shell基础:变量类型 & 运算符

    Shell变量 Shell支持三种类型的变量 用户自定义变量:用户自定义的变量,变量名以英文字母或下划线开头,区分大小写. 位置变量:根据位置传递参数给脚本的变量,默认支持9个位置变量 $1,$2,$ ...

  2. IP的正则表达式

    首先分析IP地址0-255: 0-9:       [0-9]或 \d表示数字 10-99:   [1-9]\d 100-199: 1/d{2} 200-249:    2[0-4]\d 250-25 ...

  3. Reverse Nodes in k-Group [LeetCode]

    Problem Description: http://oj.leetcode.com/problems/reverse-nodes-in-k-group/ Basic Idea: Do it lik ...

  4. 输出有序数组的中两个元素差值为指定值diff的两个元素

    题目: 输出有序数组的中两个元素差值为指定值diff的两个元素. 思路: 这与输出两个元素的和的值为一定值类似,需要两个指针,不同的是:指针不是一左一右,而是一前一后. 如果差值等于diff,则返回: ...

  5. 去除DataTable重复数据的三种方法

    业务需求 最近做一个把源数据库的数据批次导出到目标数据库.源数据库是采集程序采集而来的原始数据库,所以需要对其进行一些处理(过滤一些为空,长度太短或太长,非法字符,重复数据)然后在进行入库. 其中要避 ...

  6. PLSQL DEVELOPER 连接远程数据库 OCI客户端安装方法

    安装使用过PLSQL Dev都知道,要连接数据库,必须配置TNS(Transparence Network Substrate),而直接安装PLSQL Dev 之后,本机是没有Oracle HOME的 ...

  7. 布隆过滤器(Bloom Filter)详解——基于多hash的概率查找思想

    转自:http://www.cnblogs.com/haippy/archive/2012/07/13/2590351.html   布隆过滤器[1](Bloom Filter)是由布隆(Burton ...

  8. 更改电脑与eclpse热键冲突

  9. SQL逻辑读变成零

    使用缓存HINT 让逻辑读变成0. create table t as select * from dba_objects; insert into t select * from t; commit ...

  10. Xwindow 连接 RHEL 5

    cd /etc/gdm/custom.conf ----------------------------------------- [security] AllowRemoteRoot=true [x ...