tags:

views:

61

answers:

5

This code doesn't return data from table:

var pom = from k in dataContext.student_gods
                      where k.skgod == System.Convert.ToString(2002/03)
                      select k.id_stud;

This code does return data from table:

var pom = from k in dataContext.student_gods
                      where k.skgod== "2002/03" 
                      select k;

How to convert a string variable without quotes???

A: 

How to convert a string variable without quotes???

That doesn't make sense. String literals must be surrounded with quotes, that is what makes it a string. You cannot just try to convert undeclared variables into strings by their name, it doesn't work that way. You just need to compare against an actual string, like you do in your second example.

Ed Swangren
+1  A: 

Unlike "2002/03", 2002/03 is not a string but the integer division of 2002 by 03 (= 667).

Are you looking how to convert a DateTime to a string?

new DateTime(2002, 3, 1).ToString("yyyy/MM", CultureInfo.InvariantCulture)

This returns "2002/03".

dtb
Of course, converting a date time like this would make absolutely no sense whatsoever...
configurator
From the OP's comments to his earlier question, this looks like what he's trying to do. "This means that I will get all students from 2002/03 year" http://stackoverflow.com/questions/1778586/problem-with-linq-c
Michael Petrotta
Michael is right I will get all students from 2002/03 year
Ognjen
In second query I need something like this > where k.skgod== tempwhere is data type of temp char(10) . Temp is column from database table
Ognjen
A: 

The string "2002/03" and 2002/03 are very different things. In C# there are no such things as string literals without quotes. C# is not PHP :-)

2002/03 is simply an integer division, namely 2002/3 = 667 (note that there are no decimal places, since this is an integer division).

So if you want to compare something with a string, then by all means use a string and not an arbitrary calculation result. Keep in mind though, that the == operator behaves somewhat erratically when applied to operands of object and string (since it might be not immediately obvious whether you are doing value or reference equality).

Joey
+1  A: 

Your problem is 2002/03 is not what you mean. What are you trying to convert here? 2002/03 is two integers and a division, and it's value is 2002 / 03 = 667. If you want the string "2002/03" you need to enter that string, "2002/03".

I hope this made sense :)

configurator
+1  A: 

Taking a stab at what the OP might be running into, I suspect you have a DateTime object that you'd like to use in a query to compare against a date stored as a string. If that's the case, you can modify your query to look like:

DateTime t = ...
var pom = from k in dataContext.student_gods
         where k.skgod == t.ToString("yyyy/MM")
         select k;

Here, you're formatting the date to match what you're expecting to see in your database. The ToString method is formatting the date to return just the year and month components. Look to the MSDN article on Custom date and Time Format Strings for more.

To extend the example, it's currently about 3pm on Sunday, November 22nd. If I run the following code:

DateTime t = DateTime.Now();
string s = t.ToString("yyyy/MM");
Console.WriteLine(s);

...I will see 2009/11 printed.

Michael Petrotta